From 48f76c6dc91fd9b375bd41ccca6762317977b336 Mon Sep 17 00:00:00 2001 From: Andreas Hocevar Date: Thu, 12 Dec 2024 23:04:13 +0100 Subject: [PATCH] Add dist for v12.4.0 --- dist/MapboxVectorLayer.d.ts | 275 + dist/apply.d.ts | 309 + dist/examples/apply-layergroup.css | 357 + dist/examples/apply-layergroup.css.map | 1 + dist/examples/apply-layergroup.html | 8 + dist/examples/apply-layergroup.js | 2 + dist/examples/apply-layergroup.js.map | 1 + dist/examples/common.js | 2 + dist/examples/common.js.map | 1 + dist/examples/data/circles-style.json | 111 + dist/examples/data/geojson-inline.json | 1049 ++ dist/examples/data/geojson-wfs.json | 55 + dist/examples/data/geojson-wms.json | 61 + dist/examples/data/geojson.json | 84 + dist/examples/data/polygons-style.json | 20 + dist/examples/data/protomaps-dark-style.json | 10661 +++++++++++++++ dist/examples/data/sprites.json | 1 + dist/examples/data/sprites.png | Bin 0 -> 2089 bytes dist/examples/data/sprites@2x.json | 1 + dist/examples/data/sprites@2x.png | Bin 0 -> 4461 bytes dist/examples/data/states.geojson | 11807 +++++++++++++++++ dist/examples/data/states.json | 82 + dist/examples/data/tilejson.json | 26 + dist/examples/data/wms.json | 43 + dist/examples/esri-4326.css | 357 + dist/examples/esri-4326.css.map | 1 + dist/examples/esri-4326.html | 8 + dist/examples/esri-4326.js | 2 + dist/examples/esri-4326.js.map | 1 + dist/examples/esri-transformrequest.css | 357 + dist/examples/esri-transformrequest.css.map | 1 + dist/examples/esri-transformrequest.html | 8 + dist/examples/esri-transformrequest.js | 2 + dist/examples/esri-transformrequest.js.map | 1 + dist/examples/geojson-featurestate.css | 357 + dist/examples/geojson-featurestate.css.map | 1 + dist/examples/geojson-featurestate.html | 8 + dist/examples/geojson-featurestate.js | 2 + dist/examples/geojson-featurestate.js.map | 1 + dist/examples/geojson-inline.css | 357 + dist/examples/geojson-inline.css.map | 1 + dist/examples/geojson-inline.html | 8 + dist/examples/geojson-inline.js | 2 + dist/examples/geojson-inline.js.map | 1 + dist/examples/geojson-layer.css | 357 + dist/examples/geojson-layer.css.map | 1 + dist/examples/geojson-layer.html | 8 + dist/examples/geojson-layer.js | 2 + dist/examples/geojson-layer.js.map | 1 + dist/examples/geojson-wfs.css | 357 + dist/examples/geojson-wfs.css.map | 1 + dist/examples/geojson-wfs.html | 8 + dist/examples/geojson-wfs.js | 2 + dist/examples/geojson-wfs.js.map | 1 + dist/examples/geojson.css | 357 + dist/examples/geojson.css.map | 1 + dist/examples/geojson.html | 8 + dist/examples/geojson.js | 2 + dist/examples/geojson.js.map | 1 + dist/examples/index.html | 39 + dist/examples/mapbox.css | 357 + dist/examples/mapbox.css.map | 1 + dist/examples/mapbox.html | 8 + dist/examples/mapbox.js | 2 + dist/examples/mapbox.js.map | 1 + dist/examples/maptiler-hillshading.css | 357 + dist/examples/maptiler-hillshading.css.map | 1 + dist/examples/maptiler-hillshading.html | 8 + dist/examples/maptiler-hillshading.js | 2 + dist/examples/maptiler-hillshading.js.map | 1 + dist/examples/openmaptiles-layer.css | 357 + dist/examples/openmaptiles-layer.css.map | 1 + dist/examples/openmaptiles-layer.html | 8 + dist/examples/openmaptiles-layer.js | 2 + dist/examples/openmaptiles-layer.js.map | 1 + dist/examples/openmaptiles.css | 357 + dist/examples/openmaptiles.css.map | 1 + dist/examples/openmaptiles.html | 8 + dist/examples/openmaptiles.js | 2 + dist/examples/openmaptiles.js.map | 1 + dist/examples/pmtiles.css | 357 + dist/examples/pmtiles.css.map | 1 + dist/examples/pmtiles.html | 8 + dist/examples/pmtiles.js | 2 + dist/examples/pmtiles.js.map | 1 + dist/examples/sdf-sprites.css | 357 + dist/examples/sdf-sprites.css.map | 1 + dist/examples/sdf-sprites.html | 8 + dist/examples/sdf-sprites.js | 2 + dist/examples/sdf-sprites.js.map | 1 + dist/examples/stylefunction.css | 357 + dist/examples/stylefunction.css.map | 1 + dist/examples/stylefunction.html | 8 + dist/examples/stylefunction.js | 2 + dist/examples/stylefunction.js.map | 1 + dist/examples/terrarium-hillshading.css | 357 + dist/examples/terrarium-hillshading.css.map | 1 + dist/examples/terrarium-hillshading.html | 8 + dist/examples/terrarium-hillshading.js | 2 + dist/examples/terrarium-hillshading.js.map | 1 + dist/examples/tilejson-vectortile.css | 357 + dist/examples/tilejson-vectortile.css.map | 1 + dist/examples/tilejson-vectortile.html | 8 + dist/examples/tilejson-vectortile.js | 2 + dist/examples/tilejson-vectortile.js.map | 1 + dist/examples/tilejson.css | 357 + dist/examples/tilejson.css.map | 1 + dist/examples/tilejson.html | 8 + dist/examples/tilejson.js | 2 + dist/examples/tilejson.js.map | 1 + dist/examples/wms.css | 357 + dist/examples/wms.css.map | 1 + dist/examples/wms.html | 8 + dist/examples/wms.js | 2 + dist/examples/wms.js.map | 1 + dist/index.d.ts | 3 + dist/index.js | 8816 ++++++++++++ dist/index.js.map | 1 + dist/mapbox.d.ts | 34 + dist/olms.js | 2 + dist/olms.js.map | 1 + dist/shaders.d.ts | 8 + dist/stylefunction.d.ts | 136 + dist/text.d.ts | 9 + dist/util.d.ts | 90 + 125 files changed, 40738 insertions(+) create mode 100644 dist/MapboxVectorLayer.d.ts create mode 100644 dist/apply.d.ts create mode 100644 dist/examples/apply-layergroup.css create mode 100644 dist/examples/apply-layergroup.css.map create mode 100644 dist/examples/apply-layergroup.html create mode 100644 dist/examples/apply-layergroup.js create mode 100644 dist/examples/apply-layergroup.js.map create mode 100644 dist/examples/common.js create mode 100644 dist/examples/common.js.map create mode 100644 dist/examples/data/circles-style.json create mode 100644 dist/examples/data/geojson-inline.json create mode 100644 dist/examples/data/geojson-wfs.json create mode 100644 dist/examples/data/geojson-wms.json create mode 100644 dist/examples/data/geojson.json create mode 100644 dist/examples/data/polygons-style.json create mode 100644 dist/examples/data/protomaps-dark-style.json create mode 100644 dist/examples/data/sprites.json create mode 100644 dist/examples/data/sprites.png create mode 100644 dist/examples/data/sprites@2x.json create mode 100644 dist/examples/data/sprites@2x.png create mode 100644 dist/examples/data/states.geojson create mode 100644 dist/examples/data/states.json create mode 100644 dist/examples/data/tilejson.json create mode 100644 dist/examples/data/wms.json create mode 100644 dist/examples/esri-4326.css create mode 100644 dist/examples/esri-4326.css.map create mode 100644 dist/examples/esri-4326.html create mode 100644 dist/examples/esri-4326.js create mode 100644 dist/examples/esri-4326.js.map create mode 100644 dist/examples/esri-transformrequest.css create mode 100644 dist/examples/esri-transformrequest.css.map create mode 100644 dist/examples/esri-transformrequest.html create mode 100644 dist/examples/esri-transformrequest.js create mode 100644 dist/examples/esri-transformrequest.js.map create mode 100644 dist/examples/geojson-featurestate.css create mode 100644 dist/examples/geojson-featurestate.css.map create mode 100644 dist/examples/geojson-featurestate.html create mode 100644 dist/examples/geojson-featurestate.js create mode 100644 dist/examples/geojson-featurestate.js.map create mode 100644 dist/examples/geojson-inline.css create mode 100644 dist/examples/geojson-inline.css.map create mode 100644 dist/examples/geojson-inline.html create mode 100644 dist/examples/geojson-inline.js create mode 100644 dist/examples/geojson-inline.js.map create mode 100644 dist/examples/geojson-layer.css create mode 100644 dist/examples/geojson-layer.css.map create mode 100644 dist/examples/geojson-layer.html create mode 100644 dist/examples/geojson-layer.js create mode 100644 dist/examples/geojson-layer.js.map create mode 100644 dist/examples/geojson-wfs.css create mode 100644 dist/examples/geojson-wfs.css.map create mode 100644 dist/examples/geojson-wfs.html create mode 100644 dist/examples/geojson-wfs.js create mode 100644 dist/examples/geojson-wfs.js.map create mode 100644 dist/examples/geojson.css create mode 100644 dist/examples/geojson.css.map create mode 100644 dist/examples/geojson.html create mode 100644 dist/examples/geojson.js create mode 100644 dist/examples/geojson.js.map create mode 100644 dist/examples/index.html create mode 100644 dist/examples/mapbox.css create mode 100644 dist/examples/mapbox.css.map create mode 100644 dist/examples/mapbox.html create mode 100644 dist/examples/mapbox.js create mode 100644 dist/examples/mapbox.js.map create mode 100644 dist/examples/maptiler-hillshading.css create mode 100644 dist/examples/maptiler-hillshading.css.map create mode 100644 dist/examples/maptiler-hillshading.html create mode 100644 dist/examples/maptiler-hillshading.js create mode 100644 dist/examples/maptiler-hillshading.js.map create mode 100644 dist/examples/openmaptiles-layer.css create mode 100644 dist/examples/openmaptiles-layer.css.map create mode 100644 dist/examples/openmaptiles-layer.html create mode 100644 dist/examples/openmaptiles-layer.js create mode 100644 dist/examples/openmaptiles-layer.js.map create mode 100644 dist/examples/openmaptiles.css create mode 100644 dist/examples/openmaptiles.css.map create mode 100644 dist/examples/openmaptiles.html create mode 100644 dist/examples/openmaptiles.js create mode 100644 dist/examples/openmaptiles.js.map create mode 100644 dist/examples/pmtiles.css create mode 100644 dist/examples/pmtiles.css.map create mode 100644 dist/examples/pmtiles.html create mode 100644 dist/examples/pmtiles.js create mode 100644 dist/examples/pmtiles.js.map create mode 100644 dist/examples/sdf-sprites.css create mode 100644 dist/examples/sdf-sprites.css.map create mode 100644 dist/examples/sdf-sprites.html create mode 100644 dist/examples/sdf-sprites.js create mode 100644 dist/examples/sdf-sprites.js.map create mode 100644 dist/examples/stylefunction.css create mode 100644 dist/examples/stylefunction.css.map create mode 100644 dist/examples/stylefunction.html create mode 100644 dist/examples/stylefunction.js create mode 100644 dist/examples/stylefunction.js.map create mode 100644 dist/examples/terrarium-hillshading.css create mode 100644 dist/examples/terrarium-hillshading.css.map create mode 100644 dist/examples/terrarium-hillshading.html create mode 100644 dist/examples/terrarium-hillshading.js create mode 100644 dist/examples/terrarium-hillshading.js.map create mode 100644 dist/examples/tilejson-vectortile.css create mode 100644 dist/examples/tilejson-vectortile.css.map create mode 100644 dist/examples/tilejson-vectortile.html create mode 100644 dist/examples/tilejson-vectortile.js create mode 100644 dist/examples/tilejson-vectortile.js.map create mode 100644 dist/examples/tilejson.css create mode 100644 dist/examples/tilejson.css.map create mode 100644 dist/examples/tilejson.html create mode 100644 dist/examples/tilejson.js create mode 100644 dist/examples/tilejson.js.map create mode 100644 dist/examples/wms.css create mode 100644 dist/examples/wms.css.map create mode 100644 dist/examples/wms.html create mode 100644 dist/examples/wms.js create mode 100644 dist/examples/wms.js.map create mode 100644 dist/index.d.ts create mode 100644 dist/index.js create mode 100644 dist/index.js.map create mode 100644 dist/mapbox.d.ts create mode 100644 dist/olms.js create mode 100644 dist/olms.js.map create mode 100644 dist/shaders.d.ts create mode 100644 dist/stylefunction.d.ts create mode 100644 dist/text.d.ts create mode 100644 dist/util.d.ts diff --git a/dist/MapboxVectorLayer.d.ts b/dist/MapboxVectorLayer.d.ts new file mode 100644 index 00000000..49400cee --- /dev/null +++ b/dist/MapboxVectorLayer.d.ts @@ -0,0 +1,275 @@ +/** + * @typedef {Object} Options + * @property {string} styleUrl The URL of the Mapbox/MapLibre Style object to use for this layer. For a + * style created with Mapbox Studio and hosted on Mapbox, this will look like + * 'mapbox://styles/you/your-style'. + * @property {string} [accessToken] The access token for your Mapbox/MapLibre style. This has to be provided + * for `mapbox://` style urls. For `https://` and other urls, any access key must be the last query + * parameter of the style url. + * @property {string} [source] If your style uses more than one source, you need to use either the + * `source` property or the `layers` property to limit rendering to a single vector source. The + * `source` property corresponds to the id of a vector source in your Mapbox/MapLibre style. + * @property {Array} [layers] Limit rendering to the list of included layers. All layers + * must share the same vector source. If your style uses more than one source, you need to use + * either the `source` property or the `layers` property to limit rendering to a single vector + * source. + * @property {boolean} [declutter=true] Declutter images and text. Decluttering is applied to all + * image and text styles of all Vector and VectorTile layers that have set this to `true`. The priority + * is defined by the z-index of the layer, the `zIndex` of the style and the render order of features. + * Higher z-index means higher priority. Within the same z-index, a feature rendered before another has + * higher priority. + * + * As an optimization decluttered features from layers with the same `className` are rendered above + * the fill and stroke styles of all of those layers regardless of z-index. To opt out of this + * behavior and place declutterd features with their own layer configure the layer with a `className` + * other than `ol-layer`. + * @property {import("ol/layer/Base.js").BackgroundColor|false} [background] Background color for the layer. + * If not specified, the background from the Mapbox/MapLibre Style object will be used. Set to `false` to prevent + * the Mapbox/MapLibre style's background from being used. + * @property {string} [className='ol-layer'] A CSS class name to set to the layer element. + * @property {number} [opacity=1] Opacity (0, 1). + * @property {boolean} [visible=true] Visibility. + * @property {import("ol/extent.js").Extent} [extent] The bounding extent for layer rendering. The layer will not be + * rendered outside of this extent. + * @property {number} [zIndex] The z-index for layer rendering. At rendering time, the layers + * will be ordered, first by Z-index and then by position. When `undefined`, a `zIndex` of 0 is assumed + * for layers that are added to the map's `layers` collection, or `Infinity` when the layer's `setMap()` + * method was used. + * @property {number} [minResolution] The minimum resolution (inclusive) at which this layer will be + * visible. + * @property {number} [maxResolution] The maximum resolution (exclusive) below which this layer will + * be visible. If neither `maxResolution` nor `minZoom` are defined, the layer's `maxResolution` will + * match the style source's `minzoom`. + * @property {number} [minZoom] The minimum view zoom level (exclusive) above which this layer will + * be visible. If neither `maxResolution` nor `minZoom` are defined, the layer's `minZoom` will match + * the style source's `minzoom`. + * @property {number} [maxZoom] The maximum view zoom level (inclusive) at which this layer will + * be visible. + * @property {import("ol/render.js").OrderFunction} [renderOrder] Render order. Function to be used when sorting + * features before rendering. By default features are drawn in the order that they are created. Use + * `null` to avoid the sort, but get an undefined draw order. + * @property {number} [renderBuffer=100] The buffer in pixels around the tile extent used by the + * renderer when getting features from the vector tile for the rendering or hit-detection. + * Recommended value: Vector tiles are usually generated with a buffer, so this value should match + * the largest possible buffer of the used tiles. It should be at least the size of the largest + * point symbol or line width. + * @property {import("ol/layer/VectorTile.js").VectorTileRenderType} [renderMode='hybrid'] Render mode for vector tiles: + * * `'hybrid'`: Polygon and line elements are rendered as images, so pixels are scaled during zoom + * animations. Point symbols and texts are accurately rendered as vectors and can stay upright on + * rotated views. + * * `'vector'`: Everything is rendered as vectors. Use this mode for improved performance on vector + * tile layers with only a few rendered features (e.g. for highlighting a subset of features of + * another layer with the same source). + * @property {import("ol/Map.js").default} [map] Sets the layer as overlay on a map. The map will not manage + * this layer in its layers collection, and the layer will be rendered on top. This is useful for + * temporary layers. The standard way to add a layer to a map and have it managed by the map is to + * use `map.addLayer()`. + * @property {boolean} [updateWhileAnimating=false] When set to `true`, feature batches will be + * recreated during animations. This means that no vectors will be shown clipped, but the setting + * will have a performance impact for large amounts of vector data. When set to `false`, batches + * will be recreated when no animation is active. + * @property {boolean} [updateWhileInteracting=false] When set to `true`, feature batches will be + * recreated during interactions. See also `updateWhileAnimating`. + * @property {number} [preload=0] Preload. Load low-resolution tiles up to `preload` levels. `0` + * means no preloading. + * @property {boolean} [useInterimTilesOnError=true] Use interim tiles on error. + * @property {Object} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`. + */ +/** + * @classdesc + * ```js + * import {MapboxVectorLayer} from 'ol-mapbox-style'; + * ``` + * A vector tile layer based on a Mapbox/MapLibre style that uses a single vector source. Configure + * the layer with the `styleUrl` and `accessToken` shown in Mapbox Studio's share panel. + * If the style uses more than one source, use the `source` property to choose a single + * vector source. If you want to render a subset of the layers in the style, use the `layers` + * property (all layers must share the same vector source). See the constructor options for + * more detail. + * + * const map = new Map({ + * view: new View({ + * center: [0, 0], + * zoom: 1, + * }), + * layers: [ + * new MapboxVectorLayer({ + * styleUrl: 'mapbox://styles/mapbox/bright-v9', + * accessToken: 'your-mapbox-access-token-here', + * }), + * ], + * target: 'map', + * }); + * + * On configuration or loading error, the layer will trigger an `'error'` event. Listeners + * will receive an object with an `error` property that can be used to diagnose the problem. + * + * **Note for users of the full build**: The `MapboxVectorLayer` requires the + * [ol-mapbox-style](https://github.com/openlayers/ol-mapbox-style) library to be loaded as well. + * + * @param {Options} options Options. + * @extends {VectorTileLayer} + * @fires module:ol/events/Event~BaseEvent#event:error + * @api + */ +export default class MapboxVectorLayer extends VectorTileLayer, import("ol/render/Feature.js").default> { + /** + * @param {Options} options Layer options. At a minimum, `styleUrl` and `accessToken` + * must be provided. + */ + constructor(options: Options); + accessToken: string | undefined; +} +export type Map = import("ol/Map.js").default; +export type Options = { + /** + * The URL of the Mapbox/MapLibre Style object to use for this layer. For a + * style created with Mapbox Studio and hosted on Mapbox, this will look like + * 'mapbox://styles/you/your-style'. + */ + styleUrl: string; + /** + * The access token for your Mapbox/MapLibre style. This has to be provided + * for `mapbox://` style urls. For `https://` and other urls, any access key must be the last query + * parameter of the style url. + */ + accessToken?: string | undefined; + /** + * If your style uses more than one source, you need to use either the + * `source` property or the `layers` property to limit rendering to a single vector source. The + * `source` property corresponds to the id of a vector source in your Mapbox/MapLibre style. + */ + source?: string | undefined; + /** + * Limit rendering to the list of included layers. All layers + * must share the same vector source. If your style uses more than one source, you need to use + * either the `source` property or the `layers` property to limit rendering to a single vector + * source. + */ + layers?: string[] | undefined; + /** + * Declutter images and text. Decluttering is applied to all + * image and text styles of all Vector and VectorTile layers that have set this to `true`. The priority + * is defined by the z-index of the layer, the `zIndex` of the style and the render order of features. + * Higher z-index means higher priority. Within the same z-index, a feature rendered before another has + * higher priority. + * + * As an optimization decluttered features from layers with the same `className` are rendered above + * the fill and stroke styles of all of those layers regardless of z-index. To opt out of this + * behavior and place declutterd features with their own layer configure the layer with a `className` + * other than `ol-layer`. + */ + declutter?: boolean | undefined; + /** + * Background color for the layer. + * If not specified, the background from the Mapbox/MapLibre Style object will be used. Set to `false` to prevent + * the Mapbox/MapLibre style's background from being used. + */ + background?: false | import("ol/layer/Base.js").BackgroundColor | undefined; + /** + * A CSS class name to set to the layer element. + */ + className?: string | undefined; + /** + * Opacity (0, 1). + */ + opacity?: number | undefined; + /** + * Visibility. + */ + visible?: boolean | undefined; + /** + * The bounding extent for layer rendering. The layer will not be + * rendered outside of this extent. + */ + extent?: import("ol/extent.js").Extent | undefined; + /** + * The z-index for layer rendering. At rendering time, the layers + * will be ordered, first by Z-index and then by position. When `undefined`, a `zIndex` of 0 is assumed + * for layers that are added to the map's `layers` collection, or `Infinity` when the layer's `setMap()` + * method was used. + */ + zIndex?: number | undefined; + /** + * The minimum resolution (inclusive) at which this layer will be + * visible. + */ + minResolution?: number | undefined; + /** + * The maximum resolution (exclusive) below which this layer will + * be visible. If neither `maxResolution` nor `minZoom` are defined, the layer's `maxResolution` will + * match the style source's `minzoom`. + */ + maxResolution?: number | undefined; + /** + * The minimum view zoom level (exclusive) above which this layer will + * be visible. If neither `maxResolution` nor `minZoom` are defined, the layer's `minZoom` will match + * the style source's `minzoom`. + */ + minZoom?: number | undefined; + /** + * The maximum view zoom level (inclusive) at which this layer will + * be visible. + */ + maxZoom?: number | undefined; + /** + * Render order. Function to be used when sorting + * features before rendering. By default features are drawn in the order that they are created. Use + * `null` to avoid the sort, but get an undefined draw order. + */ + renderOrder?: import("ol/render.js").OrderFunction | undefined; + /** + * The buffer in pixels around the tile extent used by the + * renderer when getting features from the vector tile for the rendering or hit-detection. + * Recommended value: Vector tiles are usually generated with a buffer, so this value should match + * the largest possible buffer of the used tiles. It should be at least the size of the largest + * point symbol or line width. + */ + renderBuffer?: number | undefined; + /** + * Render mode for vector tiles: + * * `'hybrid'`: Polygon and line elements are rendered as images, so pixels are scaled during zoom + * animations. Point symbols and texts are accurately rendered as vectors and can stay upright on + * rotated views. + * * `'vector'`: Everything is rendered as vectors. Use this mode for improved performance on vector + * tile layers with only a few rendered features (e.g. for highlighting a subset of features of + * another layer with the same source). + */ + renderMode?: import("ol/layer/VectorTile.js").VectorTileRenderType | undefined; + /** + * Sets the layer as overlay on a map. The map will not manage + * this layer in its layers collection, and the layer will be rendered on top. This is useful for + * temporary layers. The standard way to add a layer to a map and have it managed by the map is to + * use `map.addLayer()`. + */ + map?: import("ol/Map.js").default | undefined; + /** + * When set to `true`, feature batches will be + * recreated during animations. This means that no vectors will be shown clipped, but the setting + * will have a performance impact for large amounts of vector data. When set to `false`, batches + * will be recreated when no animation is active. + */ + updateWhileAnimating?: boolean | undefined; + /** + * When set to `true`, feature batches will be + * recreated during interactions. See also `updateWhileAnimating`. + */ + updateWhileInteracting?: boolean | undefined; + /** + * Preload. Load low-resolution tiles up to `preload` levels. `0` + * means no preloading. + */ + preload?: number | undefined; + /** + * Use interim tiles on error. + */ + useInterimTilesOnError?: boolean | undefined; + /** + * Arbitrary observable properties. Can be accessed with `#get()` and `#set()`. + */ + properties?: { + [x: string]: any; + } | undefined; +}; +import VectorTileSource from 'ol/source/VectorTile.js'; +import VectorTileLayer from 'ol/layer/VectorTile.js'; diff --git a/dist/apply.d.ts b/dist/apply.d.ts new file mode 100644 index 00000000..d3d81e63 --- /dev/null +++ b/dist/apply.d.ts @@ -0,0 +1,309 @@ +/** + * Applies a style function to an `ol/layer/VectorTile` or `ol/layer/Vector` + * with an `ol/source/VectorTile` or an `ol/source/Vector`. If the layer does not have a source + * yet, it will be created and populated from the information in the `glStyle` (unless `updateSource` is + * set to `false`). + * + * **Example:** + * ```js + * import {applyStyle} from 'ol-mapbox-style'; + * import {VectorTile} from 'ol/layer.js'; + * + * const layer = new VectorTile({declutter: true}); + * applyStyle(layer, 'https://api.maptiler.com/maps/basic/style.json?key=YOUR_OPENMAPTILES_TOKEN'); + * ``` + * + * The style function will render all layers from the `glStyle` object that use the source + * of the first layer, the specified `source`, or a subset of layers from the same source. The + * source needs to be a `"type": "vector"` or `"type": "geojson"` source. + * + * Two additional properties will be set on the provided layer: + * + * * `mapbox-source`: The `id` of the Mapbox/MapLibre Style document's source that the + * OpenLayers layer was created from. Usually `apply()` creates one + * OpenLayers layer per Mapbox/MapLibre Style source, unless the layer stack has + * layers from different sources in between. + * * `mapbox-layers`: The `id`s of the Mapbox/MapLibre Style document's layers that are + * included in the OpenLayers layer. + * + * @param {VectorTileLayer|VectorLayer} layer OpenLayers layer. When the layer has a source configured, + * it will be modified to use the configuration from the glStyle's `source`. Options specified on the + * layer's source will override those from the glStyle's `source`, except for `url` and + * `tileUrlFunction`. When the source projection is the default (`EPSG:3857`), the `tileGrid` will + * also be overridden. If you'd rather not have ol-mapbox-style modify the source, configure `applyStyle()` + * with the `updateSource: false` option. + * @param {string|Object} glStyle Mapbox/MapLibre Style object. + * @param {string|Array|Options&ApplyStyleOptions} [sourceOrLayersOrOptions] Options or + * `source` key or an array of layer `id`s from the Mapbox/MapLibre Style object. When a `source` key is + * provided, all layers for the specified source will be included in the style function. When layer + * `id`s are provided, they must be from layers that use the same source. When not provided or a falsey + * value, all layers using the first source specified in the glStyle will be rendered. + * @param {Options&ApplyStyleOptions|string} [optionsOrPath] **Deprecated**. Options. Alternatively the path of the style file + * (only required when a relative path is used for the `"sprite"` property of the style). + * @param {Array} [resolutions] **Deprecated**. Resolutions for mapping resolution to zoom level. + * Only needed when working with non-standard tile grids or projections, can also be supplied with + * options. + * @return {Promise} Promise which will be resolved when the style can be used + * for rendering. + */ +export function applyStyle(layer: VectorTileLayer | VectorLayer, glStyle: string | any, sourceOrLayersOrOptions?: string | string[] | (Options & ApplyStyleOptions) | undefined, optionsOrPath?: string | (Options & ApplyStyleOptions) | undefined, resolutions?: number[] | undefined): Promise; +/** + * Applies properties of the Mapbox/MapLibre Style's first `background` layer to the + * provided map or layer (group). + * + * **Example:** + * ```js + * import {applyBackground} from 'ol-mapbox-style'; + * import {Map} from 'ol'; + * + * const map = new Map({target: 'map'}); + * applyBackground(map, 'https://api.maptiler.com/maps/basic/style.json?key=YOUR_OPENMAPTILES_TOKEN'); + * ``` + * @param {Map|import("ol/layer/Base.js").default} mapOrLayer OpenLayers Map or layer (group). + * @param {Object|string} glStyle Mapbox/MapLibre Style object or url. + * @param {Options} options Options. + * @return {Promise} Promise that resolves when the background is applied. + */ +export function applyBackground(mapOrLayer: Map | import("ol/layer/Base.js").default, glStyle: any | string, options?: Options): Promise; +/** + * Creates an OpenLayers VectorTile source for a gl source entry. + * @param {Object} glSource "source" entry from a Mapbox/MapLibre Style object. + * @param {string|undefined} styleUrl URL to use for the source. This is expected to be the complete http(s) url, + * with access key applied. + * @param {Options} options Options. + * @return {Promise} Promise resolving to a VectorTile source. + * @private + */ +export function setupVectorSource(glSource: any, styleUrl: string | undefined, options: Options): Promise; +export function setupLayer(glStyle: any, styleUrl: any, glLayer: any, options: any): Layer> | undefined; +/** + * Loads and applies a Mapbox/MapLibre Style object into an OpenLayers Map or LayerGroup. + * This includes the map background, the layers, and for Map instances that did not + * have a View defined yet also the center and the zoom. + * + * **Example:** + * ```js + * import apply from 'ol-mapbox-style'; + * + * apply('map', 'mapbox://styles/mapbox/bright-v9', {accessToken: 'YOUR_MAPBOX_TOKEN'}); + * ``` + * + * The center and zoom will only be set if present in the Mapbox/MapLibre Style document, + * and if not already set on the OpenLayers map. + * + * Layers will be added to the OpenLayers map, without affecting any layers that + * might already be set on the map. + * + * Layers added by `apply()` will have two additional properties: + * + * * `mapbox-source`: The `id` of the Mapbox/MapLibre Style document's source that the + * OpenLayers layer was created from. Usually `apply()` creates one + * OpenLayers layer per Mapbox/MapLibre Style source, unless the layer stack has + * layers from different sources in between. + * * `mapbox-layers`: The `id`s of the Mapbox/MapLibre Style document's layers that are + * included in the OpenLayers layer. + * + * This function sets an additional `mapbox-style` property on the OpenLayers + * Map or LayerGroup instance, which holds the Mapbox/MapLibre Style object. + * + * @param {Map|HTMLElement|string|LayerGroup} mapOrGroupOrElement Either an existing + * OpenLayers Map instance, or a HTML element, or the id of a HTML element that will be + * the target of a new OpenLayers Map, or a layer group. If layer group, styles + * releated to the map and view will be ignored. + * @param {string|Object} style JSON style object or style url pointing to a + * Mapbox/MapLibre Style object. When using Mapbox APIs, the url is the `styleUrl` + * shown in Mapbox Studio's "share" panel. In addition, the `accessToken` option + * (see below) must be set. + * When passed as JSON style object, all OpenLayers layers created by `apply()` + * will be immediately available, but they may not have a source yet (i.e. when + * they are defined by a TileJSON url in the Mapbox/MapLibre Style document). When passed + * as style url, layers will be added to the map when the Mapbox/MapLibre Style document + * is loaded and parsed. + * @param {Options} options Options. + * @return {Promise} A promise that resolves after all layers have been added to + * the OpenLayers Map instance or LayerGroup, their sources set, and their styles applied. The + * `resolve` callback will be called with the OpenLayers Map instance or LayerGroup as + * argument. + */ +export function apply(mapOrGroupOrElement: Map | HTMLElement | string | LayerGroup, style: string | any, options?: Options): Promise; +/** + * If layerIds is not empty, applies the style specified in glStyle to the layer, + * and adds the layer to the map. + * + * The layer may not yet have a source when the function is called. If so, the style + * is applied to the layer via a once listener on the 'change:source' event. + * + * @param {Layer} layer An OpenLayers layer instance. + * @param {Array} layerIds Array containing layer ids of already-processed layers. + * @param {Object} glStyle Style as a JSON object. + * @param {string|undefined} styleUrl The original style URL. Only required + * when a relative path is used with the `"sprite"` property of the style. + * @param {Map|LayerGroup} mapOrGroup OpenLayers Map. + * @param {Options} options Options. + * @return {Promise} Returns a promise that resolves after the source has + * been set on the specified layer, and the style has been applied. + */ +export function finalizeLayer(layer: Layer, layerIds: Array, glStyle: any, styleUrl: string | undefined, mapOrGroup: Map | LayerGroup, options?: Options): Promise; +/** + * Get the Mapbox Layer object for the provided `layerId`. + * @param {Map|LayerGroup} mapOrGroup Map or LayerGroup. + * @param {string} layerId Mapbox Layer id. + * @return {Object} Mapbox Layer object. + */ +export function getMapboxLayer(mapOrGroup: Map | LayerGroup, layerId: string): any; +/** + * Add a new Mapbox Layer object to the style. The map will be re-rendered. + * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on. + * @param {Object} mapboxLayer Mapbox Layer object. + * @param {string} [beforeLayerId] Optional id of the Mapbox Layer before the new layer that will be added. + * @return {Promise} Resolves when the added layer is available. + */ +export function addMapboxLayer(mapOrGroup: Map | LayerGroup, mapboxLayer: any, beforeLayerId?: string | undefined): Promise; +/** + * Update a Mapbox Layer object in the style. The map will be re-rendered with the new style. + * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on. + * @param {Object} mapboxLayer Updated Mapbox Layer object. + */ +export function updateMapboxLayer(mapOrGroup: Map | LayerGroup, mapboxLayer: any): void; +/** + * Updates a Mapbox source object in the style. The according OpenLayers source will be replaced + * and the map will be re-rendered. + * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on. + * @param {string} id Key of the source in the `sources` object literal. + * @param {Object} mapboxSource Mapbox source object. + * @return {Promise} Promise that resolves when the source has been updated. + */ +export function updateMapboxSource(mapOrGroup: Map | LayerGroup, id: string, mapboxSource: any): Promise; +/** + * Remove a Mapbox Layer object from the style. The map will be re-rendered. + * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on. + * @param {string|Object} mapboxLayerIdOrLayer Mapbox Layer id or Mapbox Layer object. + */ +export function removeMapboxLayer(mapOrGroup: Map | LayerGroup, mapboxLayerIdOrLayer: string | any): void; +/** + * Get the OpenLayers layer instance that contains the provided Mapbox/MapLibre Style + * `layer`. Note that multiple Mapbox/MapLibre Style layers are combined in a single + * OpenLayers layer instance when they use the same Mapbox/MapLibre Style `source`. + * @param {Map|LayerGroup} map OpenLayers Map or LayerGroup. + * @param {string} layerId Mapbox/MapLibre Style layer id. + * @return {Layer} OpenLayers layer instance. + */ +export function getLayer(map: Map | LayerGroup, layerId: string): Layer; +/** + * Get the OpenLayers layer instances for the provided Mapbox/MapLibre Style `source`. + * @param {Map|LayerGroup} map OpenLayers Map or LayerGroup. + * @param {string} sourceId Mapbox/MapLibre Style source id. + * @return {Array} OpenLayers layer instances. + */ +export function getLayers(map: Map | LayerGroup, sourceId: string): Array; +/** + * Get the OpenLayers source instance for the provided Mapbox/MapLibre Style `source`. + * @param {Map|LayerGroup} map OpenLayers Map or LayerGroup. + * @param {string} sourceId Mapbox/MapLibre Style source id. + * @return {Source} OpenLayers source instance. + */ +export function getSource(map: Map | LayerGroup, sourceId: string): Source; +/** + * Sets or removes a feature state. The feature state is taken into account for styling, + * just like the feature's properties, and can be used e.g. to conditionally render selected + * features differently. + * + * The feature state will be stored on the OpenLayers layer matching the feature identifier, in the + * `mapbox-featurestate` property. + * @param {Map|VectorLayer|VectorTileLayer} mapOrLayer OpenLayers Map or layer to set the feature + * state on. + * @param {FeatureIdentifier} feature Feature identifier. + * @param {Object|null} state Feature state. Set to `null` to remove the feature state. + */ +export function setFeatureState(mapOrLayer: Map | VectorLayer | VectorTileLayer, feature: FeatureIdentifier, state: any | null): void; +/** + * Sets or removes a feature state. The feature state is taken into account for styling, + * just like the feature's properties, and can be used e.g. to conditionally render selected + * features differently. + * @param {Map|VectorLayer|VectorTileLayer} mapOrLayer Map or layer to set the feature state on. + * @param {FeatureIdentifier} feature Feature identifier. + * @return {Object|null} Feature state or `null` when no feature state is set for the given + * feature identifier. + */ +export function getFeatureState(mapOrLayer: Map | VectorLayer | VectorTileLayer, feature: FeatureIdentifier): any | null; +export type FeatureIdentifier = { + /** + * The feature id. + */ + id: string | number; + /** + * The source id. + */ + source: string; +}; +export type Options = { + /** + * Access token for 'mapbox://' urls. + */ + accessToken?: string | undefined; + /** + * Function for controlling how `ol-mapbox-style` fetches resources. Can be used for modifying + * the url, adding headers or setting credentials options. Called with the url and the resource + * type as arguments, this function is supposed to return a `Request` or a url `string`, or a promise tehereof. + * Without a return value the original request will not be modified. + */ + transformRequest?: ((arg0: string, arg1: import("./util.js").ResourceType) => (Request | string | Promise | void)) | undefined; + /** + * Only useful when working with non-standard projections. + * Code of a projection registered with OpenLayers. All sources of the style must be provided in this + * projection. The projection must also have a valid extent defined, which will be used to determine the + * origin and resolutions of the tile grid for all tiled sources of the style. When provided, the bbox + * placeholder in tile and geojson urls changes: the default is `{bbox-epsg-3857}`, when projection is e.g. + * set to `EPSG:4326`, the bbox placeholder will be `{bbox-epsg-4326}`. + */ + projection?: string | undefined; + /** + * Only useful when working with non-standard projections. + * Resolutions for mapping resolution to the `zoom` used in the Mapbox/MapLibre style. + */ + resolutions?: number[] | undefined; + /** + * URL of the Mapbox GL style. Required for styles that were provided + * as object, when they contain a relative sprite url, or sources referencing data by relative url. + */ + styleUrl?: string | undefined; + /** + * Template for resolving webfonts. Can be used to specify where to fetch + * web fonts when no `ol:webfonts` metadata is set in the style object. See `getFonts()` and the + * "Font handling" section in `README.md` for details. + */ + webfonts?: string | undefined; + /** + * Function that returns an image for an icon name. If the result is an HTMLImageElement, it must already be + * loaded. The layer can be used to call layer.changed() when the loading and processing of the image has finished. + * This function be used for icons not in the sprite or to override sprite icons. + */ + getImage?: ((arg0: VectorLayer | VectorTileLayer, arg1: string) => HTMLImageElement | HTMLCanvasElement | string | undefined) | undefined; + /** + * Access token param. For internal use. + */ + accessTokenParam?: string | undefined; +}; +export type ApplyStyleOptions = { + /** + * Source. Default is `''`, which causes the first source in the + * style to be used. + */ + source?: string | undefined; + /** + * Layers. If no source is provided, the layers with the + * provided ids will be used from the style's `layers` array. All layers need to use the same source. + */ + layers?: string[] | undefined; + /** + * Update or create vector (tile) layer source with parameters + * specified for the source in the mapbox style definition. + */ + updateSource?: boolean | undefined; +}; +import VectorTileLayer from 'ol/layer/VectorTile.js'; +import VectorLayer from 'ol/layer/Vector.js'; +import Map from 'ol/Map.js'; +import Source from 'ol/source/Source.js'; +import Layer from 'ol/layer/Layer.js'; +import LayerGroup from 'ol/layer/Group.js'; diff --git a/dist/examples/apply-layergroup.css b/dist/examples/apply-layergroup.css new file mode 100644 index 00000000..f49e6cdb --- /dev/null +++ b/dist/examples/apply-layergroup.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=apply-layergroup.css.map*/ \ No newline at end of file diff --git a/dist/examples/apply-layergroup.css.map b/dist/examples/apply-layergroup.css.map new file mode 100644 index 00000000..0035763d --- /dev/null +++ b/dist/examples/apply-layergroup.css.map @@ -0,0 +1 @@ +{"version":3,"file":"apply-layergroup.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/apply-layergroup.html b/dist/examples/apply-layergroup.html new file mode 100644 index 00000000..9d21d60e --- /dev/null +++ b/dist/examples/apply-layergroup.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/apply-layergroup.js b/dist/examples/apply-layergroup.js new file mode 100644 index 00000000..7b5be3b9 --- /dev/null +++ b/dist/examples/apply-layergroup.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[122],{2847:(e,s,a)=>{a(8508);var o=a(5598),n=a(3317),t=a(1765),l=a(316);const w=new o.A;(0,l.Bb)(w,"data/geojson-wms.json"),new n.A({target:"map",view:new t.Ay({center:[-10203186.115192635,4475744.563386],zoom:4}),layers:[w]})}},e=>{e(e.s=2847)}]); +//# sourceMappingURL=apply-layergroup.js.map \ No newline at end of file diff --git a/dist/examples/apply-layergroup.js.map b/dist/examples/apply-layergroup.js.map new file mode 100644 index 00000000..f844255f --- /dev/null +++ b/dist/examples/apply-layergroup.js.map @@ -0,0 +1 @@ +{"version":3,"file":"apply-layergroup.js","mappings":"oKAKA,MAAMA,EAAa,IAAI,KACvB,QAAMA,EAAY,yBAElB,IAAI,IAAI,CACNC,OAAQ,MACRC,KAAM,IAAI,KAAK,CACbC,OAAQ,EAAE,mBAAoB,gBAC9BC,KAAM,IAERC,OAAQ,CAACL,I","sources":["webpack://ol-mapbox-style/./examples/apply-layergroup.js"],"sourcesContent":["import 'ol/ol.css';\nimport {Group as LayerGroup} from 'ol/layer.js';\nimport {Map, View} from 'ol';\nimport {apply} from 'ol-mapbox-style';\n\nconst layerGroup = new LayerGroup();\napply(layerGroup, 'data/geojson-wms.json');\n\nnew Map({\n target: 'map',\n view: new View({\n center: [-10203186.115192635, 4475744.563386],\n zoom: 4,\n }),\n layers: [layerGroup],\n});\n"],"names":["layerGroup","target","view","center","zoom","layers"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/common.js b/dist/examples/common.js new file mode 100644 index 00000000..367b5d4c --- /dev/null +++ b/dist/examples/common.js @@ -0,0 +1,2 @@ +(()=>{var t,e={5380:t=>{function e(t,e,i,n){this.cx=3*t,this.bx=3*(i-t)-this.cx,this.ax=1-this.cx-this.bx,this.cy=3*e,this.by=3*(n-e)-this.cy,this.ay=1-this.cy-this.by,this.p1x=t,this.p1y=n,this.p2x=i,this.p2y=n}t.exports=e,e.prototype.sampleCurveX=function(t){return((this.ax*t+this.bx)*t+this.cx)*t},e.prototype.sampleCurveY=function(t){return((this.ay*t+this.by)*t+this.cy)*t},e.prototype.sampleCurveDerivativeX=function(t){return(3*this.ax*t+2*this.bx)*t+this.cx},e.prototype.solveCurveX=function(t,e){var i,n,r,s,o;for(void 0===e&&(e=1e-6),r=t,o=0;o<8;o++){if(s=this.sampleCurveX(r)-t,Math.abs(s)(n=1))return n;for(;is?i=r:n=r,r=.5*(n-i)+i}return r},e.prototype.solve=function(t,e){return this.sampleCurveY(this.solveCurveX(t,e))}},8959:(t,e)=>{var i={transparent:[0,0,0,0],aliceblue:[240,248,255,1],antiquewhite:[250,235,215,1],aqua:[0,255,255,1],aquamarine:[127,255,212,1],azure:[240,255,255,1],beige:[245,245,220,1],bisque:[255,228,196,1],black:[0,0,0,1],blanchedalmond:[255,235,205,1],blue:[0,0,255,1],blueviolet:[138,43,226,1],brown:[165,42,42,1],burlywood:[222,184,135,1],cadetblue:[95,158,160,1],chartreuse:[127,255,0,1],chocolate:[210,105,30,1],coral:[255,127,80,1],cornflowerblue:[100,149,237,1],cornsilk:[255,248,220,1],crimson:[220,20,60,1],cyan:[0,255,255,1],darkblue:[0,0,139,1],darkcyan:[0,139,139,1],darkgoldenrod:[184,134,11,1],darkgray:[169,169,169,1],darkgreen:[0,100,0,1],darkgrey:[169,169,169,1],darkkhaki:[189,183,107,1],darkmagenta:[139,0,139,1],darkolivegreen:[85,107,47,1],darkorange:[255,140,0,1],darkorchid:[153,50,204,1],darkred:[139,0,0,1],darksalmon:[233,150,122,1],darkseagreen:[143,188,143,1],darkslateblue:[72,61,139,1],darkslategray:[47,79,79,1],darkslategrey:[47,79,79,1],darkturquoise:[0,206,209,1],darkviolet:[148,0,211,1],deeppink:[255,20,147,1],deepskyblue:[0,191,255,1],dimgray:[105,105,105,1],dimgrey:[105,105,105,1],dodgerblue:[30,144,255,1],firebrick:[178,34,34,1],floralwhite:[255,250,240,1],forestgreen:[34,139,34,1],fuchsia:[255,0,255,1],gainsboro:[220,220,220,1],ghostwhite:[248,248,255,1],gold:[255,215,0,1],goldenrod:[218,165,32,1],gray:[128,128,128,1],green:[0,128,0,1],greenyellow:[173,255,47,1],grey:[128,128,128,1],honeydew:[240,255,240,1],hotpink:[255,105,180,1],indianred:[205,92,92,1],indigo:[75,0,130,1],ivory:[255,255,240,1],khaki:[240,230,140,1],lavender:[230,230,250,1],lavenderblush:[255,240,245,1],lawngreen:[124,252,0,1],lemonchiffon:[255,250,205,1],lightblue:[173,216,230,1],lightcoral:[240,128,128,1],lightcyan:[224,255,255,1],lightgoldenrodyellow:[250,250,210,1],lightgray:[211,211,211,1],lightgreen:[144,238,144,1],lightgrey:[211,211,211,1],lightpink:[255,182,193,1],lightsalmon:[255,160,122,1],lightseagreen:[32,178,170,1],lightskyblue:[135,206,250,1],lightslategray:[119,136,153,1],lightslategrey:[119,136,153,1],lightsteelblue:[176,196,222,1],lightyellow:[255,255,224,1],lime:[0,255,0,1],limegreen:[50,205,50,1],linen:[250,240,230,1],magenta:[255,0,255,1],maroon:[128,0,0,1],mediumaquamarine:[102,205,170,1],mediumblue:[0,0,205,1],mediumorchid:[186,85,211,1],mediumpurple:[147,112,219,1],mediumseagreen:[60,179,113,1],mediumslateblue:[123,104,238,1],mediumspringgreen:[0,250,154,1],mediumturquoise:[72,209,204,1],mediumvioletred:[199,21,133,1],midnightblue:[25,25,112,1],mintcream:[245,255,250,1],mistyrose:[255,228,225,1],moccasin:[255,228,181,1],navajowhite:[255,222,173,1],navy:[0,0,128,1],oldlace:[253,245,230,1],olive:[128,128,0,1],olivedrab:[107,142,35,1],orange:[255,165,0,1],orangered:[255,69,0,1],orchid:[218,112,214,1],palegoldenrod:[238,232,170,1],palegreen:[152,251,152,1],paleturquoise:[175,238,238,1],palevioletred:[219,112,147,1],papayawhip:[255,239,213,1],peachpuff:[255,218,185,1],peru:[205,133,63,1],pink:[255,192,203,1],plum:[221,160,221,1],powderblue:[176,224,230,1],purple:[128,0,128,1],rebeccapurple:[102,51,153,1],red:[255,0,0,1],rosybrown:[188,143,143,1],royalblue:[65,105,225,1],saddlebrown:[139,69,19,1],salmon:[250,128,114,1],sandybrown:[244,164,96,1],seagreen:[46,139,87,1],seashell:[255,245,238,1],sienna:[160,82,45,1],silver:[192,192,192,1],skyblue:[135,206,235,1],slateblue:[106,90,205,1],slategray:[112,128,144,1],slategrey:[112,128,144,1],snow:[255,250,250,1],springgreen:[0,255,127,1],steelblue:[70,130,180,1],tan:[210,180,140,1],teal:[0,128,128,1],thistle:[216,191,216,1],tomato:[255,99,71,1],turquoise:[64,224,208,1],violet:[238,130,238,1],wheat:[245,222,179,1],white:[255,255,255,1],whitesmoke:[245,245,245,1],yellow:[255,255,0,1],yellowgreen:[154,205,50,1]};function n(t){return(t=Math.round(t))<0?0:t>255?255:t}function r(t){return t<0?0:t>1?1:t}function s(t){return"%"===t[t.length-1]?n(parseFloat(t)/100*255):n(parseInt(t))}function o(t){return"%"===t[t.length-1]?r(parseFloat(t)/100):r(parseFloat(t))}function a(t,e,i){return i<0?i+=1:i>1&&(i-=1),6*i<1?t+(e-t)*i*6:2*i<1?e:3*i<2?t+(e-t)*(2/3-i)*6:t}try{e.M=function(t){var e,r=t.replace(/ /g,"").toLowerCase();if(r in i)return i[r].slice();if("#"===r[0])return 4===r.length?(e=parseInt(r.substr(1),16))>=0&&e<=4095?[(3840&e)>>4|(3840&e)>>8,240&e|(240&e)>>4,15&e|(15&e)<<4,1]:null:7===r.length&&(e=parseInt(r.substr(1),16))>=0&&e<=16777215?[(16711680&e)>>16,(65280&e)>>8,255&e,1]:null;var l=r.indexOf("("),h=r.indexOf(")");if(-1!==l&&h+1===r.length){var c=r.substr(0,l),u=r.substr(l+1,h-(l+1)).split(","),d=1;switch(c){case"rgba":if(4!==u.length)return null;d=o(u.pop());case"rgb":return 3!==u.length?null:[s(u[0]),s(u[1]),s(u[2]),d];case"hsla":if(4!==u.length)return null;d=o(u.pop());case"hsl":if(3!==u.length)return null;var p=(parseFloat(u[0])%360+360)%360/360,f=o(u[1]),g=o(u[2]),m=g<=.5?g*(f+1):g+f-g*f,y=2*g-m;return[n(255*a(y,m,p+1/3)),n(255*a(y,m,p)),n(255*a(y,m,p-1/3)),d];default:return null}}return null}}catch(t){}},9536:t=>{var e={thin:100,hairline:100,"ultra-light":200,"extra-light":200,light:300,book:300,regular:400,normal:400,plain:400,roman:400,standard:400,medium:500,"semi-bold":600,"demi-bold":600,bold:700,"extra-bold":800,"ultra-bold":800,heavy:900,black:900,"heavy-black":900,fat:900,poster:900,"ultra-black":950,"extra-black":950},i=" ",n=/(italic|oblique)$/i,r={};t.exports=function(t,s,o){var a=r[t];if(!a){Array.isArray(t)||(t=[t]);for(var l,h,c=400,u="normal",d=[],p=0,f=t.length;p1?g[g.length-2].toLowerCase():"";if(m==y||m==y.replace("-","")||_+"-"+m==y){c=l?c:e[y],g.pop(),_&&y.startsWith(_)&&g.pop();break}}l||"number"!=typeof m||(c=m,l=!0);var v=g.join(i).replace("Klokantech Noto Sans","Noto Sans");-1!==v.indexOf(i)&&(v='"'+v+'"'),d.push(v)}a=r[t]=[u,c,d]}return a[0]+i+a[1]+i+s+"px"+(o?"/"+o:"")+i+a[2]}},8508:()=>{},6889:t=>{t.exports=function t(i,n){if(!i){var r=new e(n);throw Error.captureStackTrace&&Error.captureStackTrace(r,t),r}};class e extends Error{}e.prototype.name="AssertionError"},71:(t,e,i)=>{"use strict";i.d(e,{A:()=>h});var n=i(4120),r=i(2135),s=i(1685);const o="length";class a extends s.Ay{constructor(t,e,i){super(t),this.element=e,this.index=i}}class l extends n.A{constructor(t,e){if(super(),this.on,this.once,this.un,e=e||{},this.unique_=!!e.unique,this.array_=t||[],this.unique_)for(let t=0,e=this.array_.length;t0;)this.pop()}extend(t){for(let e=0,i=t.length;ethis.getLength())throw new Error("Index out of bounds: "+t);this.unique_&&this.assertUnique_(e),this.array_.splice(t,0,e),this.updateLength_(),this.dispatchEvent(new a(r.A.ADD,e,t))}pop(){return this.removeAt(this.getLength()-1)}push(t){this.unique_&&this.assertUnique_(t);const e=this.getLength();return this.insertAt(e,t),this.getLength()}remove(t){const e=this.array_;for(let i=0,n=e.length;i=this.getLength())return;const e=this.array_[t];return this.array_.splice(t,1),this.updateLength_(),this.dispatchEvent(new a(r.A.REMOVE,e,t)),e}setAt(t,e){if(t>=this.getLength())return void this.insertAt(t,e);if(t<0)throw new Error("Index out of bounds: "+t);this.unique_&&this.assertUnique_(e,t);const i=this.array_[t];this.array_[t]=e,this.dispatchEvent(new a(r.A.REMOVE,i,t)),this.dispatchEvent(new a(r.A.ADD,e,t))}updateLength_(){this.set(o,this.array_.length)}assertUnique_(t,e){for(let i=0,n=this.array_.length;i{"use strict";i.d(e,{A:()=>n});const n={ADD:"add",REMOVE:"remove"}},25:(t,e,i)=>{"use strict";i.d(e,{A:()=>n});const n=class{constructor(){this.disposed=!1}dispose(){this.disposed||(this.disposed=!0,this.disposeInternal())}disposeInternal(){}}},6717:(t,e,i)=>{"use strict";i.d(e,{A:()=>l});var n=i(4120),r=i(6837),s=i(588),o=i(9438);class a extends n.A{constructor(t){if(super(),this.on,this.once,this.un,this.id_=void 0,this.geometryName_="geometry",this.style_=null,this.styleFunction_=void 0,this.geometryChangeKey_=null,this.addChangeListener(this.geometryName_,this.handleGeometryChanged_),t)if("function"==typeof t.getSimplifiedGeometry){const e=t;this.setGeometry(e)}else{const e=t;this.setProperties(e)}}clone(){const t=new a(this.hasProperties()?this.getProperties():null);t.setGeometryName(this.getGeometryName());const e=this.getGeometry();e&&t.setGeometry(e.clone());const i=this.getStyle();return i&&t.setStyle(i),t}getGeometry(){return this.get(this.geometryName_)}getId(){return this.id_}getGeometryName(){return this.geometryName_}getStyle(){return this.style_}getStyleFunction(){return this.styleFunction_}handleGeometryChange_(){this.changed()}handleGeometryChanged_(){this.geometryChangeKey_&&((0,o.JH)(this.geometryChangeKey_),this.geometryChangeKey_=null);const t=this.getGeometry();t&&(this.geometryChangeKey_=(0,o.KT)(t,r.A.CHANGE,this.handleGeometryChange_,this)),this.changed()}setGeometry(t){this.set(this.geometryName_,t)}setStyle(t){this.style_=t,this.styleFunction_=t?function(t){if("function"==typeof t)return t;let e;return Array.isArray(t)?e=t:((0,s.v)("function"==typeof t.getZIndex,"Expected an `ol/style/Style` or an array of `ol/style/Style.js`"),e=[t]),function(){return e}}(t):void 0,this.changed()}setId(t){this.id_=t,this.changed()}setGeometryName(t){this.removeChangeListener(this.geometryName_,this.handleGeometryChanged_),this.geometryName_=t,this.addChangeListener(this.geometryName_,this.handleGeometryChanged_),this.handleGeometryChanged_()}}const l=a},3938:(t,e,i)=>{"use strict";i.d(e,{Ay:()=>d,RA:()=>u,f6:()=>c});var n=i(9332),r=i(6837),s=i(6141),o=i(7771),a=i(9438),l=i(4238);class h extends n.A{constructor(t,e,i,n){super(),this.extent=t,this.pixelRatio_=i,this.resolution=e,this.state="function"==typeof n?s.A.IDLE:n,this.image_=null,this.loader="function"==typeof n?n:null}changed(){this.dispatchEvent(r.A.CHANGE)}getExtent(){return this.extent}getImage(){return this.image_}getPixelRatio(){return this.pixelRatio_}getResolution(){return this.resolution}getState(){return this.state}load(){if(this.state==s.A.IDLE&&this.loader){this.state=s.A.LOADING,this.changed();const t=this.getResolution(),e=Array.isArray(t)?t[0]:t;(0,l.hq)((()=>this.loader(this.getExtent(),e,this.getPixelRatio()))).then((t=>{"image"in t&&(this.image_=t.image),"extent"in t&&(this.extent=t.extent),"resolution"in t&&(this.resolution=t.resolution),"pixelRatio"in t&&(this.pixelRatio_=t.pixelRatio),(t instanceof HTMLImageElement||t instanceof ImageBitmap||t instanceof HTMLCanvasElement||t instanceof HTMLVideoElement)&&(this.image_=t),this.state=s.A.LOADED})).catch((t=>{this.state=s.A.ERROR,console.error(t)})).finally((()=>this.changed()))}}setImage(t){this.image_=t}setResolution(t){this.resolution=t}}function c(t,e,i){const n=t;let s=!0,l=!1,h=!1;const c=[(0,a.Jz)(n,r.A.LOAD,(function(){h=!0,l||e()}))];return n.src&&o.DT?(l=!0,n.decode().then((function(){s&&e()})).catch((function(t){s&&(h?e():i())}))):c.push((0,a.Jz)(n,r.A.ERROR,i)),function(){s=!1,c.forEach(a.JH)}}function u(t,e){return e&&(t.src=e),t.src&&o.DT?new Promise(((e,i)=>t.decode().then((()=>e(t))).catch((n=>t.complete&&t.width?e(t):i(n))))):function(t,e){return new Promise(((e,i)=>{function n(){s(),e(t)}function r(){s(),i(new Error("Image load error"))}function s(){t.removeEventListener("load",n),t.removeEventListener("error",r)}t.addEventListener("load",n),t.addEventListener("error",r)}))}(t)}const d=h},6141:(t,e,i)=>{"use strict";i.d(e,{A:()=>n});const n={IDLE:0,LOADING:1,LOADED:2,ERROR:3,EMPTY:4}},190:(t,e,i)=>{"use strict";i.d(e,{A:()=>l});var n=i(8143),r=i(1078),s=i(8711),o=i(3938);class a extends n.A{constructor(t,e,i,n,r,s){super(t,e,s),this.crossOrigin_=n,this.src_=i,this.key=i,this.image_=new Image,null!==n&&(this.image_.crossOrigin=n),this.unlisten_=null,this.tileLoadFunction_=r}getImage(){return this.image_}setImage(t){this.image_=t,this.state=r.A.LOADED,this.unlistenImage_(),this.changed()}handleImageError_(){this.state=r.A.ERROR,this.unlistenImage_(),this.image_=function(){const t=(0,s.Y)(1,1);return t.fillStyle="rgba(0,0,0,0)",t.fillRect(0,0,1,1),t.canvas}(),this.changed()}handleImageLoad_(){const t=this.image_;t.naturalWidth&&t.naturalHeight?this.state=r.A.LOADED:this.state=r.A.EMPTY,this.unlistenImage_(),this.changed()}load(){this.state==r.A.ERROR&&(this.state=r.A.IDLE,this.image_=new Image,null!==this.crossOrigin_&&(this.image_.crossOrigin=this.crossOrigin_)),this.state==r.A.IDLE&&(this.state=r.A.LOADING,this.changed(),this.tileLoadFunction_(this,this.src_),this.unlisten_=(0,o.f6)(this.image_,this.handleImageLoad_.bind(this),this.handleImageError_.bind(this)))}unlistenImage_(){this.unlisten_&&(this.unlisten_(),this.unlisten_=null)}}const l=a},3317:(t,e,i)=>{"use strict";i.d(e,{A:()=>Vt});var n=i(4120),r=i(71),s=i(2135),o=i(7600),a=i(25),l=i(4238),h=i(4087),c=i(9703),u=i(915),d=i(2241),p=i(764),f=i(6933);class g extends a.A{constructor(t){super(),this.map_=t}dispatchRenderEvent(t,e){(0,h.b0)()}calculateMatrices2D(t){const e=t.viewState,i=t.coordinateToPixelTransform,n=t.pixelToCoordinateTransform;(0,c.Zz)(i,t.size[0]/2,t.size[1]/2,1/e.resolution,-1/e.resolution,-e.rotation,-e.center[0],-e.center[1]),(0,c.T9)(n,i)}forEachFeatureAtCoordinate(t,e,i,n,r,s,o,a){let l;const h=e.viewState;function c(t,e,i,n){return r.call(s,e,t?i:null,n)}const d=h.projection,g=(0,f.Li)(t.slice(),d),m=[[0,0]];if(d.canWrapX()&&n){const t=d.getExtent(),e=(0,u.RG)(t);m.push([-e,0],[e,0])}const y=e.layerStatesArray,_=y.length,v=[],x=[];for(let n=0;n=0;--r){const s=y[r],u=s.layer;if(u.hasRenderer()&&(0,p.l)(s,h)&&o.call(a,u)){const r=u.getRenderer(),o=u.getSource();if(r&&o){const a=o.getWrapX()?g:t,h=c.bind(null,s.managed);x[0]=a[0]+m[n][0],x[1]=a[1]+m[n][1],l=r.forEachFeatureAtCoordinate(x,e,i,h,v)}if(l)return l}}if(0===v.length)return;const b=1/v.length;return v.forEach(((t,e)=>t.distanceSq+=e*b)),v.sort(((t,e)=>t.distanceSq-e.distanceSq)),v.some((t=>l=t.callback(t.feature,t.layer,t.geometry))),l}hasFeatureAtCoordinate(t,e,i,n,r,s){return void 0!==this.forEachFeatureAtCoordinate(t,e,i,n,l.rT,this,r,s)}getMap(){return this.map_}renderFrame(t){(0,h.b0)()}scheduleExpireIconCache(t){d.ue.canExpireCache()&&t.postRenderFunctions.push(m)}}function m(t,e){d.ue.expire()}const y=g;var _=i(8450),v=i(9960),x=i(3984),b=i(5176),w=i(8774),A=i(9438),E=i(8711);const C=class extends y{constructor(t){super(t),this.fontChangeListenerKey_=(0,A.KT)(w.yY,_.A.PROPERTYCHANGE,t.redrawText.bind(t)),this.element_=document.createElement("div");const e=this.element_.style;e.position="absolute",e.width="100%",e.height="100%",e.zIndex="0",this.element_.className=b.XI+" ol-layers";const i=t.getViewport();i.insertBefore(this.element_,i.firstChild||null),this.children_=[],this.renderedVisible_=!0}dispatchRenderEvent(t,e){const i=this.getMap();if(i.hasListener(t)){const n=new v.A(t,void 0,e);i.dispatchEvent(n)}}disposeInternal(){(0,A.JH)(this.fontChangeListenerKey_),this.element_.remove(),super.disposeInternal()}renderFrame(t){if(!t)return void(this.renderedVisible_&&(this.element_.style.display="none",this.renderedVisible_=!1));this.calculateMatrices2D(t),this.dispatchRenderEvent(x.A.PRECOMPOSE,t);const e=t.layerStatesArray.sort(((t,e)=>t.zIndex-e.zIndex));e.some((t=>t.layer instanceof o.A&&t.layer.getDeclutter()))&&(t.declutter={});const i=t.viewState;this.children_.length=0;const n=[];let r=null;for(let s=0,o=e.length;s=0;--i){const n=e[i],r=n.layer;r.getDeclutter()&&r.renderDeclutter(t,n)}e.forEach((e=>e.layer.renderDeferred(t)))}}};var S=i(6837),T=i(5598),R=i(1685);class I extends R.Ay{constructor(t,e,i){super(t),this.map=e,this.frameState=void 0!==i?i:null}}const k=I,M=class extends k{constructor(t,e,i,n,r,s){super(t,e,r),this.originalEvent=i,this.pixel_=null,this.coordinate_=null,this.dragging=void 0!==n&&n,this.activePointers=s}get pixel(){return this.pixel_||(this.pixel_=this.map.getEventPixel(this.originalEvent)),this.pixel_}set pixel(t){this.pixel_=t}get coordinate(){return this.coordinate_||(this.coordinate_=this.map.getCoordinateFromPixel(this.pixel)),this.coordinate_}set coordinate(t){this.coordinate_=t}preventDefault(){super.preventDefault(),"preventDefault"in this.originalEvent&&this.originalEvent.preventDefault()}stopPropagation(){super.stopPropagation(),"stopPropagation"in this.originalEvent&&this.originalEvent.stopPropagation()}},P={SINGLECLICK:"singleclick",CLICK:S.A.CLICK,DBLCLICK:S.A.DBLCLICK,POINTERDRAG:"pointerdrag",POINTERMOVE:"pointermove",POINTERDOWN:"pointerdown",POINTERUP:"pointerup",POINTEROVER:"pointerover",POINTEROUT:"pointerout",POINTERENTER:"pointerenter",POINTERLEAVE:"pointerleave",POINTERCANCEL:"pointercancel"},L="pointerdown";var F=i(9332),O=i(7771);class D extends F.A{constructor(t,e){super(t),this.map_=t,this.clickTimeoutId_,this.emulateClicks_=!1,this.dragging_=!1,this.dragListenerKeys_=[],this.moveTolerance_=void 0===e?1:e,this.down_=null;const i=this.map_.getViewport();this.activePointers_=[],this.trackedTouches_={},this.element_=i,this.pointerdownListenerKey_=(0,A.KT)(i,L,this.handlePointerDown_,this),this.originalPointerMoveEvent_,this.relayedListenerKey_=(0,A.KT)(i,"pointermove",this.relayMoveEvent_,this),this.boundHandleTouchMove_=this.handleTouchMove_.bind(this),this.element_.addEventListener(S.A.TOUCHMOVE,this.boundHandleTouchMove_,!!O.FT&&{passive:!1})}emulateClick_(t){let e=new M(P.CLICK,this.map_,t);this.dispatchEvent(e),void 0!==this.clickTimeoutId_?(clearTimeout(this.clickTimeoutId_),this.clickTimeoutId_=void 0,e=new M(P.DBLCLICK,this.map_,t),this.dispatchEvent(e)):this.clickTimeoutId_=setTimeout((()=>{this.clickTimeoutId_=void 0;const e=new M(P.SINGLECLICK,this.map_,t);this.dispatchEvent(e)}),250)}updateActivePointers_(t){const e=t,i=e.pointerId;if(e.type==P.POINTERUP||e.type==P.POINTERCANCEL){delete this.trackedTouches_[i];for(const t in this.trackedTouches_)if(this.trackedTouches_[t].target!==e.target){delete this.trackedTouches_[t];break}}else e.type!=P.POINTERDOWN&&e.type!=P.POINTERMOVE||(this.trackedTouches_[i]=e);this.activePointers_=Object.values(this.trackedTouches_)}handlePointerUp_(t){this.updateActivePointers_(t);const e=new M(P.POINTERUP,this.map_,t,void 0,void 0,this.activePointers_);this.dispatchEvent(e),this.emulateClicks_&&!e.defaultPrevented&&!this.dragging_&&this.isMouseActionButton_(t)&&this.emulateClick_(this.down_),0===this.activePointers_.length&&(this.dragListenerKeys_.forEach(A.JH),this.dragListenerKeys_.length=0,this.dragging_=!1,this.down_=null)}isMouseActionButton_(t){return 0===t.button}handlePointerDown_(t){this.emulateClicks_=0===this.activePointers_.length,this.updateActivePointers_(t);const e=new M(P.POINTERDOWN,this.map_,t,void 0,void 0,this.activePointers_);if(this.dispatchEvent(e),this.down_=new PointerEvent(t.type,t),Object.defineProperty(this.down_,"target",{writable:!1,value:t.target}),0===this.dragListenerKeys_.length){const t=this.map_.getOwnerDocument();this.dragListenerKeys_.push((0,A.KT)(t,P.POINTERMOVE,this.handlePointerMove_,this),(0,A.KT)(t,P.POINTERUP,this.handlePointerUp_,this),(0,A.KT)(this.element_,P.POINTERCANCEL,this.handlePointerUp_,this)),this.element_.getRootNode&&this.element_.getRootNode()!==t&&this.dragListenerKeys_.push((0,A.KT)(this.element_.getRootNode(),P.POINTERUP,this.handlePointerUp_,this))}}handlePointerMove_(t){if(this.isMoving_(t)){this.updateActivePointers_(t),this.dragging_=!0;const e=new M(P.POINTERDRAG,this.map_,t,this.dragging_,void 0,this.activePointers_);this.dispatchEvent(e)}}relayMoveEvent_(t){this.originalPointerMoveEvent_=t;const e=!(!this.down_||!this.isMoving_(t));this.dispatchEvent(new M(P.POINTERMOVE,this.map_,t,e))}handleTouchMove_(t){const e=this.originalPointerMoveEvent_;e&&!e.defaultPrevented||"boolean"==typeof t.cancelable&&!0!==t.cancelable||t.preventDefault()}isMoving_(t){return this.dragging_||Math.abs(t.clientX-this.down_.clientX)>this.moveTolerance_||Math.abs(t.clientY-this.down_.clientY)>this.moveTolerance_}disposeInternal(){this.relayedListenerKey_&&((0,A.JH)(this.relayedListenerKey_),this.relayedListenerKey_=null),this.element_.removeEventListener(S.A.TOUCHMOVE,this.boundHandleTouchMove_),this.pointerdownListenerKey_&&((0,A.JH)(this.pointerdownListenerKey_),this.pointerdownListenerKey_=null),this.dragListenerKeys_.forEach(A.JH),this.dragListenerKeys_.length=0,this.element_=null,super.disposeInternal()}}const j=D,z="postrender",N="loadstart",G="loadend",q="layergroup",W="size",Y="target",X="view";var V=i(6813),K=i(1765),U=i(2703),B=i(588);class Z extends n.A{constructor(t){super();const e=t.element;!e||t.target||e.style.pointerEvents||(e.style.pointerEvents="auto"),this.element=e||null,this.target_=null,this.map_=null,this.listenerKeys=[],t.render&&(this.render=t.render),t.target&&this.setTarget(t.target)}disposeInternal(){this.element?.remove(),super.disposeInternal()}getMap(){return this.map_}setMap(t){this.map_&&this.element?.remove();for(let t=0,e=this.listenerKeys.length;te.getAttributions(t)))));if(!this.overrideCollapsible_){const t=!e.some((t=>!1===t.getSource()?.getAttributionsCollapsible()));this.setCollapsible(t)}return i}async updateElement_(t){if(!t)return void(this.renderedVisible_&&(this.element.style.display="none",this.renderedVisible_=!1));const e=await Promise.all(this.collectSourceAttributions_(t).map((t=>(0,l.hq)((()=>t))))),i=e.length>0;if(this.renderedVisible_!=i&&(this.element.style.display=i?"":"none",this.renderedVisible_=i),!(0,$.aI)(e,this.renderedAttributions_)){(0,E.gS)(this.ulElement_);for(let t=0,i=e.length;t0&&e%(2*Math.PI)!=0?t.animate({rotation:0,duration:this.duration_,easing:Q.vT}):t.setRotation(0))}render(t){const e=t.frameState;if(!e)return;const i=e.viewState.rotation;if(i!=this.rotation_){const t="rotate("+i+"rad)";if(this.autoHide_){const t=this.element.classList.contains(b.Si);t||0!==i?t&&0!==i&&this.element.classList.remove(b.Si):this.element.classList.add(b.Si)}this.label_.style.transform=t}this.rotation_=i}},et=class extends H{constructor(t){t=t||{},super({element:document.createElement("div"),target:t.target});const e=void 0!==t.className?t.className:"ol-zoom",i=void 0!==t.delta?t.delta:1,n=void 0!==t.zoomInClassName?t.zoomInClassName:e+"-in",r=void 0!==t.zoomOutClassName?t.zoomOutClassName:e+"-out",s=void 0!==t.zoomInLabel?t.zoomInLabel:"+",o=void 0!==t.zoomOutLabel?t.zoomOutLabel:"–",a=void 0!==t.zoomInTipLabel?t.zoomInTipLabel:"Zoom in",l=void 0!==t.zoomOutTipLabel?t.zoomOutTipLabel:"Zoom out",h=document.createElement("button");h.className=n,h.setAttribute("type","button"),h.title=a,h.appendChild("string"==typeof s?document.createTextNode(s):s),h.addEventListener(S.A.CLICK,this.handleClick_.bind(this,i),!1);const c=document.createElement("button");c.className=r,c.setAttribute("type","button"),c.title=l,c.appendChild("string"==typeof o?document.createTextNode(o):o),c.addEventListener(S.A.CLICK,this.handleClick_.bind(this,-i),!1);const u=e+" "+b.XI+" "+b.$N,d=this.element;d.className=u,d.appendChild(h),d.appendChild(c),this.duration_=void 0!==t.duration?t.duration:250}handleClick_(t,e){e.preventDefault(),this.zoomByDelta_(t)}zoomByDelta_(t){const e=this.getMap().getView();if(!e)return;const i=e.getZoom();if(void 0!==i){const n=e.getConstrainedZoom(i+t);this.duration_>0?(e.getAnimating()&&e.cancelAnimations(),e.animate({zoom:n,duration:this.duration_,easing:Q.vT})):e.setZoom(n)}}},it="active";class nt extends n.A{constructor(t){super(),this.on,this.once,this.un,t&&t.handleEvent&&(this.handleEvent=t.handleEvent),this.map_=null,this.setActive(!0)}getActive(){return this.get(it)}getMap(){return this.map_}handleEvent(t){return!0}setActive(t){this.set(it,t)}setMap(t){this.map_=t}}function rt(t,e,i,n){const r=t.getZoom();if(void 0===r)return;const s=t.getConstrainedZoom(r+e),o=t.getResolutionForZoom(s);t.getAnimating()&&t.cancelAnimations(),t.animate({resolution:o,anchor:i,duration:void 0!==n?n:250,easing:Q.vT})}const st=nt,ot=class extends st{constructor(t){super(),t=t||{},this.delta_=t.delta?t.delta:1,this.duration_=void 0!==t.duration?t.duration:250}handleEvent(t){let e=!1;if(t.type==P.DBLCLICK){const i=t.originalEvent,n=t.map,r=t.coordinate,s=i.shiftKey?-this.delta_:this.delta_;rt(n.getView(),s,r,this.duration_),i.preventDefault(),e=!0}return!e}};function at(t){const e=t.length;let i=0,n=0;for(let r=0;r0}}else if(t.type==P.POINTERDOWN){const i=this.handleDownEvent(t);this.handlingDownUpSequence=i,e=this.stopDown(i)}else t.type==P.POINTERMOVE&&this.handleMoveEvent(t);return!e}handleMoveEvent(t){}handleUpEvent(t){return!1}stopDown(t){return t}updateTrackedPointers_(t){t.activePointers&&(this.targetPointers=t.activePointers)}};function ht(t){const e=arguments;return function(t){let i=!0;for(let n=0,r=e.length;n0&&this.condition_(t)){const e=t.map.getView();return this.lastCentroid=null,e.getAnimating()&&e.cancelAnimations(),this.kinetic_&&this.kinetic_.begin(),this.noKinetic_=this.targetPointers.length>1,!0}return!1}};var xt=i(4498);const bt=class extends lt{constructor(t){t=t||{},super({stopDown:l.W8}),this.condition_=t.condition?t.condition:ct,this.lastAngle_=void 0,this.duration_=void 0!==t.duration?t.duration:250}handleDragEvent(t){if(!yt(t))return;const e=t.map,i=e.getView();if(i.getConstraints().rotation===xt.b8)return;const n=e.getSize(),r=t.pixel,s=Math.atan2(n[1]/2-r[1],r[0]-n[0]/2);if(void 0!==this.lastAngle_){const t=s-this.lastAngle_;i.adjustRotationInternal(-t)}this.lastAngle_=s}handleUpEvent(t){return!yt(t)||(t.map.getView().endInteraction(this.duration_),!1)}handleDownEvent(t){return!!yt(t)&&(!(!pt(t)||!this.condition_(t))&&(t.map.getView().beginInteraction(),this.lastAngle_=void 0,!0))}};var wt=i(1064);class At extends a.A{constructor(t){super(),this.geometry_=null,this.element_=document.createElement("div"),this.element_.style.position="absolute",this.element_.style.pointerEvents="auto",this.element_.className="ol-box "+t,this.map_=null,this.startPixel_=null,this.endPixel_=null}disposeInternal(){this.setMap(null)}render_(){const t=this.startPixel_,e=this.endPixel_,i="px",n=this.element_.style;n.left=Math.min(t[0],e[0])+i,n.top=Math.min(t[1],e[1])+i,n.width=Math.abs(e[0]-t[0])+i,n.height=Math.abs(e[1]-t[1])+i}setMap(t){if(this.map_){this.map_.getOverlayContainer().removeChild(this.element_);const t=this.element_.style;t.left="inherit",t.top="inherit",t.width="inherit",t.height="inherit"}this.map_=t,this.map_&&this.map_.getOverlayContainer().appendChild(this.element_)}setPixels(t,e){this.startPixel_=t,this.endPixel_=e,this.createOrUpdateGeometry(),this.render_()}createOrUpdateGeometry(){if(!this.map_)return;const t=this.startPixel_,e=this.endPixel_,i=[t,[t[0],e[1]],e,[e[0],t[1]]].map(this.map_.getCoordinateFromPixelInternal,this.map_);i[4]=i[0].slice(),this.geometry_?this.geometry_.setCoordinates([i]):this.geometry_=new wt.Ay([i])}getGeometry(){return this.geometry_}}const Et=At,Ct="boxcancel";class St extends R.Ay{constructor(t,e,i){super(t),this.coordinate=e,this.mapBrowserEvent=i}}const Tt=class extends lt{constructor(t){super(),this.on,this.once,this.un,t=t||{},this.box_=new Et(t.className||"ol-dragbox"),this.minArea_=void 0!==t.minArea?t.minArea:64,t.onBoxEnd&&(this.onBoxEnd=t.onBoxEnd),this.startPixel_=null,this.condition_=t.condition?t.condition:pt,this.boxEndCondition_=t.boxEndCondition?t.boxEndCondition:this.defaultBoxEndCondition}defaultBoxEndCondition(t,e,i){const n=i[0]-e[0],r=i[1]-e[1];return n*n+r*r>=this.minArea_}getGeometry(){return this.box_.getGeometry()}handleDragEvent(t){this.startPixel_&&(this.box_.setPixels(this.startPixel_,t.pixel),this.dispatchEvent(new St("boxdrag",t.coordinate,t)))}handleUpEvent(t){if(!this.startPixel_)return!1;this.box_.setMap(null);const e=this.boxEndCondition_(t,this.startPixel_,t.pixel);return e&&this.onBoxEnd(t),this.dispatchEvent(new St(e?"boxend":Ct,t.coordinate,t)),!1}handleDownEvent(t){return!!this.condition_(t)&&(this.startPixel_=t.pixel,this.box_.setMap(t.map),this.box_.setPixels(this.startPixel_,this.startPixel_),this.dispatchEvent(new St("boxstart",t.coordinate,t)),!0)}onBoxEnd(t){}setActive(t){t||(this.box_.setMap(null),this.startPixel_&&(this.dispatchEvent(new St(Ct,this.startPixel_,null)),this.startPixel_=null)),super.setActive(t)}},Rt=class extends Tt{constructor(t){super({condition:(t=t||{}).condition?t.condition:gt,className:t.className||"ol-dragzoom",minArea:t.minArea}),this.duration_=void 0!==t.duration?t.duration:200,this.out_=void 0!==t.out&&t.out}onBoxEnd(t){const e=this.getMap().getView();let i=this.getGeometry();if(this.out_){const t=e.rotatedExtentForGeometry(i),n=e.getResolutionForExtentInternal(t),r=e.getResolution()/n;i=i.clone(),i.scale(r*r)}e.fitInternal(i,{duration:this.duration_,easing:Q.vT})}},It="ArrowLeft",kt="ArrowRight",Mt="ArrowDown",Pt=class extends st{constructor(t){super(),t=t||{},this.defaultCondition_=function(t){return ft(t)&&mt(t)},this.condition_=void 0!==t.condition?t.condition:this.defaultCondition_,this.duration_=void 0!==t.duration?t.duration:100,this.pixelDelta_=void 0!==t.pixelDelta?t.pixelDelta:128}handleEvent(t){let e=!1;if(t.type==S.A.KEYDOWN){const i=t.originalEvent,n=i.key;if(this.condition_(t)&&(n==Mt||n==It||n==kt||"ArrowUp"==n)){const r=t.map.getView(),s=r.getResolution()*this.pixelDelta_;let o=0,a=0;n==Mt?a=-s:n==It?o=-s:n==kt?o=s:a=s;const l=[o,a];(0,f.e$)(l,r.getRotation()),function(t,e,i){const n=t.getCenterInternal();if(n){const r=[n[0]+e[0],n[1]+e[1]];t.animateInternal({duration:void 0!==i?i:250,easing:Q.sn,center:t.getConstrainedCenter(r)})}}(r,l,this.duration_),i.preventDefault(),e=!0}}return!e}},Lt=class extends st{constructor(t){super(),t=t||{},this.condition_=t.condition?t.condition:function(t){return!function(t){const e=t.originalEvent;return O.ew?e.metaKey:e.ctrlKey}(t)&&mt(t)},this.delta_=t.delta?t.delta:1,this.duration_=void 0!==t.duration?t.duration:100}handleEvent(t){let e=!1;if(t.type==S.A.KEYDOWN||t.type==S.A.KEYPRESS){const i=t.originalEvent,n=i.key;if(this.condition_(t)&&("+"===n||"-"===n)){const r=t.map,s="+"===n?this.delta_:-this.delta_;rt(r.getView(),s,void 0,this.duration_),i.preventDefault(),e=!0}}return!e}},Ft=class{constructor(t,e,i){this.decay_=t,this.minVelocity_=e,this.delay_=i,this.points_=[],this.angle_=0,this.initialVelocity_=0}begin(){this.points_.length=0,this.angle_=0,this.initialVelocity_=0}update(t,e){this.points_.push(t,e,Date.now())}end(){if(this.points_.length<6)return!1;const t=Date.now()-this.delay_,e=this.points_.length-3;if(this.points_[e+2]0&&this.points_[i+2]>t;)i-=3;const n=this.points_[e+2]-this.points_[i+2];if(n<1e3/60)return!1;const r=this.points_[e]-this.points_[i],s=this.points_[e+1]-this.points_[i+1];return this.angle_=Math.atan2(s,r),this.initialVelocity_=Math.sqrt(r*r+s*s)/n,this.initialVelocity_>this.minVelocity_}getDistance(){return(this.minVelocity_-this.initialVelocity_)/this.decay_}getAngle(){return this.angle_}};var Ot=i(1597);const Dt=class extends st{constructor(t){super(t=t||{}),this.totalDelta_=0,this.lastDelta_=0,this.maxDelta_=void 0!==t.maxDelta?t.maxDelta:1,this.duration_=void 0!==t.duration?t.duration:250,this.timeout_=void 0!==t.timeout?t.timeout:80,this.useAnchor_=void 0===t.useAnchor||t.useAnchor,this.constrainResolution_=void 0!==t.constrainResolution&&t.constrainResolution;const e=t.condition?t.condition:dt;this.condition_=t.onFocusOnly?ht(ut,e):e,this.lastAnchor_=null,this.startTime_=void 0,this.timeoutId_,this.mode_=void 0,this.trackpadEventGap_=400,this.trackpadTimeoutId_,this.deltaPerZoom_=300}endInteraction_(){this.trackpadTimeoutId_=void 0;const t=this.getMap();t&&t.getView().endInteraction(void 0,this.lastDelta_?this.lastDelta_>0?1:-1:0,this.lastAnchor_)}handleEvent(t){if(!this.condition_(t))return!0;if(t.type!==S.A.WHEEL)return!0;const e=t.map,i=t.originalEvent;let n;if(i.preventDefault(),this.useAnchor_&&(this.lastAnchor_=t.coordinate),t.type==S.A.WHEEL&&(n=i.deltaY,O._p&&i.deltaMode===WheelEvent.DOM_DELTA_PIXEL&&(n/=O.cr),i.deltaMode===WheelEvent.DOM_DELTA_LINE&&(n*=40)),0===n)return!1;this.lastDelta_=n;const r=Date.now();void 0===this.startTime_&&(this.startTime_=r),(!this.mode_||r-this.startTime_>this.trackpadEventGap_)&&(this.mode_=Math.abs(n)<4?"trackpad":"wheel");const s=e.getView();if("trackpad"===this.mode_&&!s.getConstrainResolution()&&!this.constrainResolution_)return this.trackpadTimeoutId_?clearTimeout(this.trackpadTimeoutId_):(s.getAnimating()&&s.cancelAnimations(),s.beginInteraction()),this.trackpadTimeoutId_=setTimeout(this.endInteraction_.bind(this),this.timeout_),s.adjustZoom(-n/this.deltaPerZoom_,this.lastAnchor_),this.startTime_=r,!1;this.totalDelta_+=n;const o=Math.max(this.timeout_-(r-this.startTime_),0);return clearTimeout(this.timeoutId_),this.timeoutId_=setTimeout(this.handleWheelZoom_.bind(this,e),o),!1}handleWheelZoom_(t){const e=t.getView();e.getAnimating()&&e.cancelAnimations();let i=-(0,Ot.qE)(this.totalDelta_,-this.maxDelta_*this.deltaPerZoom_,this.maxDelta_*this.deltaPerZoom_)/this.deltaPerZoom_;(e.getConstrainResolution()||this.constrainResolution_)&&(i=i?i>0?1:-1:0),rt(e,i,this.lastAnchor_,this.duration_),this.mode_=void 0,this.totalDelta_=0,this.lastAnchor_=null,this.startTime_=void 0,this.timeoutId_=void 0}setMouseAnchor(t){this.useAnchor_=t,t||(this.lastAnchor_=null)}},jt=class extends lt{constructor(t){const e=t=t||{};e.stopDown||(e.stopDown=l.W8),super(e),this.anchor_=null,this.lastAngle_=void 0,this.rotating_=!1,this.rotationDelta_=0,this.threshold_=void 0!==t.threshold?t.threshold:.3,this.duration_=void 0!==t.duration?t.duration:250}handleDragEvent(t){let e=0;const i=this.targetPointers[0],n=this.targetPointers[1],r=Math.atan2(n.clientY-i.clientY,n.clientX-i.clientX);if(void 0!==this.lastAngle_){const t=r-this.lastAngle_;this.rotationDelta_+=t,!this.rotating_&&Math.abs(this.rotationDelta_)>this.threshold_&&(this.rotating_=!0),e=t}this.lastAngle_=r;const s=t.map,o=s.getView();o.getConstraints().rotation!==xt.b8&&(this.anchor_=s.getCoordinateFromPixelInternal(s.getEventPixel(at(this.targetPointers))),this.rotating_&&(s.render(),o.adjustRotationInternal(e,this.anchor_)))}handleUpEvent(t){return!(this.targetPointers.length<2)||(t.map.getView().endInteraction(this.duration_),!1)}handleDownEvent(t){if(this.targetPointers.length>=2){const e=t.map;return this.anchor_=null,this.lastAngle_=void 0,this.rotating_=!1,this.rotationDelta_=0,this.handlingDownUpSequence||e.getView().beginInteraction(),!0}return!1}},zt=class extends lt{constructor(t){const e=t=t||{};e.stopDown||(e.stopDown=l.W8),super(e),this.anchor_=null,this.duration_=void 0!==t.duration?t.duration:400,this.lastDistance_=void 0,this.lastScaleDelta_=1}handleDragEvent(t){let e=1;const i=this.targetPointers[0],n=this.targetPointers[1],r=i.clientX-n.clientX,s=i.clientY-n.clientY,o=Math.sqrt(r*r+s*s);void 0!==this.lastDistance_&&(e=this.lastDistance_/o),this.lastDistance_=o;const a=t.map,l=a.getView();1!=e&&(this.lastScaleDelta_=e),this.anchor_=a.getCoordinateFromPixelInternal(a.getEventPixel(at(this.targetPointers))),a.render(),l.adjustResolutionInternal(e,this.anchor_)}handleUpEvent(t){if(this.targetPointers.length<2){const e=t.map.getView(),i=this.lastScaleDelta_>1?1:-1;return e.endInteraction(this.duration_,i),!1}return!0}handleDownEvent(t){if(this.targetPointers.length>=2){const e=t.map;return this.anchor_=null,this.lastDistance_=void 0,this.lastScaleDelta_=1,this.handlingDownUpSequence||e.getView().beginInteraction(),!0}return!1}};var Nt=i(594),Gt=i(6782),qt=i(4422);function Wt(t){t instanceof p.A?t.setMapInternal(null):t instanceof T.A&&t.getLayers().forEach(Wt)}function Yt(t,e){if(t instanceof p.A)t.setMapInternal(e);else if(t instanceof T.A){const i=t.getLayers().getArray();for(let t=0,n=i.length;tthis.updateSize())),this.controls=e.controls||function(t){t=t||{};const e=new r.A;return(void 0===t.zoom||t.zoom)&&e.push(new et(t.zoomOptions)),(void 0===t.rotate||t.rotate)&&e.push(new tt(t.rotateOptions)),(void 0===t.attribution||t.attribution)&&e.push(new J(t.attributionOptions)),e}(),this.interactions=e.interactions||function(t){t=t||{};const e=new r.A,i=new Ft(-.005,.05,100);return(void 0===t.altShiftDragRotate||t.altShiftDragRotate)&&e.push(new bt),(void 0===t.doubleClickZoom||t.doubleClickZoom)&&e.push(new ot({delta:t.zoomDelta,duration:t.zoomDuration})),(void 0===t.dragPan||t.dragPan)&&e.push(new vt({onFocusOnly:t.onFocusOnly,kinetic:i})),(void 0===t.pinchRotate||t.pinchRotate)&&e.push(new jt),(void 0===t.pinchZoom||t.pinchZoom)&&e.push(new zt({duration:t.zoomDuration})),(void 0===t.keyboard||t.keyboard)&&(e.push(new Pt),e.push(new Lt({delta:t.zoomDelta,duration:t.zoomDuration}))),(void 0===t.mouseWheelZoom||t.mouseWheelZoom)&&e.push(new Dt({onFocusOnly:t.onFocusOnly,duration:t.zoomDuration})),(void 0===t.shiftDragZoom||t.shiftDragZoom)&&e.push(new Rt({duration:t.zoomDuration})),e}({onFocusOnly:!0}),this.overlays_=e.overlays,this.overlayIdIndex_={},this.renderer_=null,this.postRenderFunctions_=[],this.tileQueue_=new V.A(this.getTilePriority.bind(this),this.handleTileChange_.bind(this)),this.addChangeListener(q,this.handleLayerGroupChanged_),this.addChangeListener(X,this.handleViewChanged_),this.addChangeListener(W,this.handleSizeChanged_),this.addChangeListener(Y,this.handleTargetChanged_),this.setProperties(e.values);const i=this;!t.view||t.view instanceof K.Ay||t.view.then((function(t){i.setView(new K.Ay(t))})),this.controls.addEventListener(s.A.ADD,(t=>{t.element.setMap(this)})),this.controls.addEventListener(s.A.REMOVE,(t=>{t.element.setMap(null)})),this.interactions.addEventListener(s.A.ADD,(t=>{t.element.setMap(this)})),this.interactions.addEventListener(s.A.REMOVE,(t=>{t.element.setMap(null)})),this.overlays_.addEventListener(s.A.ADD,(t=>{this.addOverlayInternal_(t.element)})),this.overlays_.addEventListener(s.A.REMOVE,(t=>{const e=t.element.getId();void 0!==e&&delete this.overlayIdIndex_[e.toString()],t.element.setMap(null)})),this.controls.forEach((t=>{t.setMap(this)})),this.interactions.forEach((t=>{t.setMap(this)})),this.overlays_.forEach(this.addOverlayInternal_.bind(this))}addControl(t){this.getControls().push(t)}addInteraction(t){this.getInteractions().push(t)}addLayer(t){this.getLayerGroup().getLayers().push(t)}handleLayerAdd_(t){Yt(t.layer,this)}addOverlay(t){this.getOverlays().push(t)}addOverlayInternal_(t){const e=t.getId();void 0!==e&&(this.overlayIdIndex_[e.toString()]=t),t.setMap(this)}disposeInternal(){this.controls.clear(),this.interactions.clear(),this.overlays_.clear(),this.resizeObserver_.disconnect(),this.setTarget(null),super.disposeInternal()}forEachFeatureAtPixel(t,e,i){if(!this.frameState_||!this.renderer_)return;const n=this.getCoordinateFromPixelInternal(t),r=void 0!==(i=void 0!==i?i:{}).hitTolerance?i.hitTolerance:0,s=void 0!==i.layerFilter?i.layerFilter:l.rT,o=!1!==i.checkWrapped;return this.renderer_.forEachFeatureAtCoordinate(n,this.frameState_,r,o,e,null,s,null)}getFeaturesAtPixel(t,e){const i=[];return this.forEachFeatureAtPixel(t,(function(t){i.push(t)}),e),i}getAllLayers(){const t=[];return function e(i){i.forEach((function(i){i instanceof T.A?e(i.getLayers()):t.push(i)}))}(this.getLayers()),t}hasFeatureAtPixel(t,e){if(!this.frameState_||!this.renderer_)return!1;const i=this.getCoordinateFromPixelInternal(t),n=void 0!==(e=void 0!==e?e:{}).layerFilter?e.layerFilter:l.rT,r=void 0!==e.hitTolerance?e.hitTolerance:0,s=!1!==e.checkWrapped;return this.renderer_.hasFeatureAtCoordinate(i,this.frameState_,r,s,n,null)}getEventCoordinate(t){return this.getCoordinateFromPixel(this.getEventPixel(t))}getEventCoordinateInternal(t){return this.getCoordinateFromPixelInternal(this.getEventPixel(t))}getEventPixel(t){const e=this.viewport_.getBoundingClientRect(),i=this.getSize(),n=e.width/i[0],r=e.height/i[1],s="changedTouches"in t?t.changedTouches[0]:t;return[(s.clientX-e.left)/n,(s.clientY-e.top)/r]}getTarget(){return this.get(Y)}getTargetElement(){return this.targetElement_}getCoordinateFromPixel(t){return(0,Nt.te)(this.getCoordinateFromPixelInternal(t),this.getView().getProjection())}getCoordinateFromPixelInternal(t){const e=this.frameState_;return e?(0,c.Bb)(e.pixelToCoordinateTransform,t.slice()):null}getControls(){return this.controls}getOverlays(){return this.overlays_}getOverlayById(t){const e=this.overlayIdIndex_[t.toString()];return void 0!==e?e:null}getInteractions(){return this.interactions}getLayerGroup(){return this.get(q)}setLayers(t){const e=this.getLayerGroup();if(t instanceof r.A)return void e.setLayers(t);const i=e.getLayers();i.clear(),i.extend(t)}getLayers(){return this.getLayerGroup().getLayers()}getLoadingOrNotReady(){const t=this.getLayerGroup().getLayerStatesArray();for(let e=0,i=t.length;e=0;i--){const n=e[i];if(n.getMap()===this&&n.getActive()&&this.getTargetElement()&&(!n.handleEvent(t)||t.propagationStopped))break}}}handlePostRender(){const t=this.frameState_,e=this.tileQueue_;if(!e.isEmpty()){let i=this.maxTilesLoading_,n=i;if(t){const e=t.viewHints;if(e[U.A.ANIMATING]||e[U.A.INTERACTING]){const e=Date.now()-t.time>8;i=e?0:8,n=e?0:2}}e.getTilesLoading(){this.postRenderTimeoutHandle_=void 0,this.handlePostRender()}),0))}setLayerGroup(t){const e=this.getLayerGroup();e&&this.handleLayerRemove_(new T.i("removelayer",e)),this.set(q,t)}setSize(t){this.set(W,t)}setTarget(t){this.set(Y,t)}setView(t){if(!t||t instanceof K.Ay)return void this.set(X,t);this.set(X,new K.Ay);const e=this;t.then((function(t){e.setView(new K.Ay(t))}))}updateSize(){const t=this.getTargetElement();let e;if(t){const i=getComputedStyle(t),n=t.offsetWidth-parseFloat(i.borderLeftWidth)-parseFloat(i.paddingLeft)-parseFloat(i.paddingRight)-parseFloat(i.borderRightWidth),r=t.offsetHeight-parseFloat(i.borderTopWidth)-parseFloat(i.paddingTop)-parseFloat(i.paddingBottom)-parseFloat(i.borderBottomWidth);isNaN(n)||isNaN(r)||(e=[Math.max(0,n),Math.max(0,r)],!(0,Gt.Ie)(e)&&(t.offsetWidth||t.offsetHeight||t.getClientRects().length)&&(0,qt.R8)("No map visible because the map container's width or height are 0."))}const i=this.getSize();!e||i&&(0,$.aI)(e,i)||(this.setSize(e),this.updateViewportSize_(e))}updateViewportSize_(t){const e=this.getView();e&&e.setViewportSize(t)}}const Vt=Xt},4120:(t,e,i)=>{"use strict";i.d(e,{A:()=>c});var n=i(1685),r=i(8450),s=i(1854),o=i(4087),a=i(3530);class l extends n.Ay{constructor(t,e,i){super(t),this.key=e,this.oldValue=i}}class h extends s.A{constructor(t){super(),this.on,this.once,this.un,(0,o.v6)(this),this.values_=null,void 0!==t&&this.setProperties(t)}get(t){let e;return this.values_&&this.values_.hasOwnProperty(t)&&(e=this.values_[t]),e}getKeys(){return this.values_&&Object.keys(this.values_)||[]}getProperties(){return this.values_&&Object.assign({},this.values_)||{}}getPropertiesInternal(){return this.values_}hasProperties(){return!!this.values_}notify(t,e){let i;i=`change:${t}`,this.hasListener(i)&&this.dispatchEvent(new l(i,t,e)),i=r.A.PROPERTYCHANGE,this.hasListener(i)&&this.dispatchEvent(new l(i,t,e))}addChangeListener(t,e){this.addEventListener(`change:${t}`,e)}removeChangeListener(t,e){this.removeEventListener(`change:${t}`,e)}set(t,e,i){const n=this.values_||(this.values_={});if(i)n[t]=e;else{const i=n[t];n[t]=e,i!==e&&this.notify(t,i)}}setProperties(t,e){for(const i in t)this.set(i,t[i],e)}applyProperties(t){t.values_&&Object.assign(this.values_||(this.values_={}),t.values_)}unset(t,e){if(this.values_&&t in this.values_){const i=this.values_[t];delete this.values_[t],(0,a.p)(this.values_)&&(this.values_=null),e||this.notify(t,i)}}}const c=h},8450:(t,e,i)=>{"use strict";i.d(e,{A:()=>n});const n={PROPERTYCHANGE:"propertychange"}},1854:(t,e,i)=>{"use strict";i.d(e,{A:()=>a});var n=i(9332),r=i(6837),s=i(9438);class o extends n.A{constructor(){super(),this.on=this.onInternal,this.once=this.onceInternal,this.un=this.unInternal,this.revision_=0}changed(){++this.revision_,this.dispatchEvent(r.A.CHANGE)}getRevision(){return this.revision_}onInternal(t,e){if(Array.isArray(t)){const i=t.length,n=new Array(i);for(let r=0;r{"use strict";i.d(e,{A:()=>h});var n=i(9332),r=i(6837),s=i(1078),o=i(4087),a=i(3474);class l extends n.A{constructor(t,e,i){super(),i=i||{},this.tileCoord=t,this.state=e,this.key="",this.transition_=void 0===i.transition?250:i.transition,this.transitionStarts_={},this.interpolate=!!i.interpolate}changed(){this.dispatchEvent(r.A.CHANGE)}release(){this.state===s.A.ERROR&&this.setState(s.A.EMPTY)}getKey(){return this.key+"/"+this.tileCoord}getTileCoord(){return this.tileCoord}getState(){return this.state}setState(t){if(this.state!==s.A.ERROR&&this.state>t)throw new Error("Tile load sequence violation");this.state=t,this.changed()}load(){(0,o.b0)()}getAlpha(t,e){if(!this.transition_)return 1;let i=this.transitionStarts_[t];if(i){if(-1===i)return 1}else i=e,this.transitionStarts_[t]=i;const n=e-i+1e3/60;return n>=this.transition_?1:(0,a.a6)(n/this.transition_)}inTransition(t){return!!this.transition_&&-1!==this.transitionStarts_[t]}endTransition(t){this.transition_&&(this.transitionStarts_[t]=-1)}}const h=l},6813:(t,e,i)=>{"use strict";i.d(e,{A:()=>h,z:()=>c});var n=i(6837),r=i(588),s=i(3530);const o=1/0,a=class{constructor(t,e){this.priorityFunction_=t,this.keyFunction_=e,this.elements_=[],this.priorities_=[],this.queuedElements_={}}clear(){this.elements_.length=0,this.priorities_.length=0,(0,s.I)(this.queuedElements_)}dequeue(){const t=this.elements_,e=this.priorities_,i=t[0];1==t.length?(t.length=0,e.length=0):(t[0]=t.pop(),e[0]=e.pop(),this.siftUp_(0));const n=this.keyFunction_(i);return delete this.queuedElements_[n],i}enqueue(t){(0,r.v)(!(this.keyFunction_(t)in this.queuedElements_),"Tried to enqueue an `element` that was already added to the queue");const e=this.priorityFunction_(t);return e!=o&&(this.elements_.push(t),this.priorities_.push(e),this.queuedElements_[this.keyFunction_(t)]=!0,this.siftDown_(0,this.elements_.length-1),!0)}getCount(){return this.elements_.length}getLeftChildIndex_(t){return 2*t+1}getRightChildIndex_(t){return 2*t+2}getParentIndex_(t){return t-1>>1}heapify_(){let t;for(t=(this.elements_.length>>1)-1;t>=0;t--)this.siftUp_(t)}isEmpty(){return 0===this.elements_.length}isKeyQueued(t){return t in this.queuedElements_}isQueued(t){return this.isKeyQueued(this.keyFunction_(t))}siftUp_(t){const e=this.elements_,i=this.priorities_,n=e.length,r=e[t],s=i[t],o=t;for(;t>1;){const r=this.getLeftChildIndex_(t),s=this.getRightChildIndex_(t),o=st;){const t=this.getParentIndex_(e);if(!(n[t]>s))break;i[e]=i[t],n[e]=n[t],e=t}i[e]=r,n[e]=s}reprioritize(){const t=this.priorityFunction_,e=this.elements_,i=this.priorities_;let n=0;const r=e.length;let s,a,l;for(a=0;a0;){const t=this.dequeue()[0],e=t.getKey();t.getState()!==l.A.IDLE||e in this.tilesLoadingKeys_||(this.tilesLoadingKeys_[e]=!0,++this.tilesLoading_,++i,t.load())}}};function c(t,e,i,n,r){if(!t||!(i in t.wantedTiles))return o;if(!t.wantedTiles[i][e.getKey()])return o;const s=t.viewState.center,a=n[0]-s[0],l=n[1]-s[1];return 65536*Math.log(r)+Math.sqrt(a*a+l*l)/r}},1110:(t,e,i)=>{"use strict";i.d(e,{A:()=>s,N:()=>r});class n{constructor(t,e,i,n){this.minX=t,this.maxX=e,this.minY=i,this.maxY=n}contains(t){return this.containsXY(t[1],t[2])}containsTileRange(t){return this.minX<=t.minX&&t.maxX<=this.maxX&&this.minY<=t.minY&&t.maxY<=this.maxY}containsXY(t,e){return this.minX<=t&&t<=this.maxX&&this.minY<=e&&e<=this.maxY}equals(t){return this.minX==t.minX&&this.minY==t.minY&&this.maxX==t.maxX&&this.maxY==t.maxY}extend(t){t.minXthis.maxX&&(this.maxX=t.maxX),t.minYthis.maxY&&(this.maxY=t.maxY)}getHeight(){return this.maxY-this.minY+1}getSize(){return[this.getWidth(),this.getHeight()]}getWidth(){return this.maxX-this.minX+1}intersects(t){return this.minX<=t.maxX&&this.maxX>=t.minX&&this.minY<=t.maxY&&this.maxY>=t.minY}}function r(t,e,i,r,s){return void 0!==s?(s.minX=t,s.maxX=e,s.minY=i,s.maxY=r,s):new n(t,e,i,r)}const s=n},1078:(t,e,i)=>{"use strict";i.d(e,{A:()=>n});const n={IDLE:0,LOADING:1,LOADED:2,ERROR:3,EMPTY:4}},1765:(t,e,i)=>{"use strict";i.d(e,{Ay:()=>S});var n=i(4120),r=i(2703);const s={CENTER:"center",RESOLUTION:"resolution",ROTATION:"rotation"};var o=i(7115),a=i(594),l=i(4238),h=i(6933),c=i(588),u=i(1597);function d(t,e,i){return function(n,r,s,o,a){if(!n)return;if(!r&&!e)return n;const l=e?0:s[0]*r,h=e?0:s[1]*r,c=a?a[0]:0,d=a?a[1]:0;let p=t[0]+l/2+c,f=t[2]-l/2+c,g=t[1]+h/2+d,m=t[3]-h/2+d;p>f&&(p=(f+p)/2,f=p),g>m&&(g=(m+g)/2,m=g);let y=(0,u.qE)(n[0],p,f),_=(0,u.qE)(n[1],g,m);if(o&&i&&r){const t=30*r;y+=-t*Math.log(1+Math.max(0,p-n[0])/t)+t*Math.log(1+Math.max(0,n[0]-f)/t),_+=-t*Math.log(1+Math.max(0,g-n[1])/t)+t*Math.log(1+Math.max(0,n[1]-m)/t)}return[y,_]}}function p(t){return t}var f=i(915),g=i(6514);function m(t,e,i,n){const r=(0,f.RG)(e)/i[0],s=(0,f.Oq)(e)/i[1];return n?Math.min(t,Math.max(r,s)):Math.min(t,Math.min(r,s))}function y(t,e,i){let n=Math.min(t,e);return n*=Math.log(1+50*Math.max(0,t/e-1))/50+1,i&&(n=Math.max(n,i),n/=Math.log(1+50*Math.max(0,i/t-1))/50+1),(0,u.qE)(n,i/2,2*e)}function _(t,e,i,n,r){return i=void 0===i||i,function(s,o,a,l){if(void 0!==s){const o=n?m(t,n,a,r):t;return i&&l?y(s,o,e):(0,u.qE)(s,e,o)}}}var v=i(4498),x=i(3474),b=i(1064);class w extends n.A{constructor(t){super(),this.on,this.once,this.un,t=Object.assign({},t),this.hints_=[0,0],this.animations_=[],this.updateAnimationKey_,this.projection_=(0,a.Av)(t.projection,"EPSG:3857"),this.viewportSize_=[100,100],this.targetCenter_=null,this.targetResolution_,this.targetRotation_,this.nextCenter_=null,this.nextResolution_,this.nextRotation_,this.cancelAnchor_=void 0,t.projection&&(0,a.RJ)(),t.center&&(t.center=(0,a.Ad)(t.center,this.projection_)),t.extent&&(t.extent=(0,a.SD)(t.extent,this.projection_)),this.applyOptions_(t)}applyOptions_(t){const e=Object.assign({},t);for(const t in s)delete e[t];this.setProperties(e,!0);const i=function(t){let e,i,n;let r=void 0!==t.minZoom?t.minZoom:0,s=void 0!==t.maxZoom?t.maxZoom:28;const l=void 0!==t.zoomFactor?t.zoomFactor:2,h=void 0!==t.multiWorld&&t.multiWorld,c=void 0===t.smoothResolutionConstraint||t.smoothResolutionConstraint,d=void 0!==t.showFullExtent&&t.showFullExtent,p=(0,a.Av)(t.projection,"EPSG:3857"),v=p.getExtent();let x=t.constrainOnlyCenter,b=t.extent;if(h||b||!p.isGlobal()||(x=!1,b=v),void 0!==t.resolutions){const o=t.resolutions;i=o[r],n=void 0!==o[s]?o[s]:o[o.length-1],e=t.constrainResolution?function(t,e,i,n){return e=void 0===e||e,function(r,s,o,a){if(void 0!==r){const l=t[0],h=t[t.length-1],c=i?m(l,i,o,n):l;if(a)return e?y(r,c,h):(0,u.qE)(r,h,c);const d=Math.min(c,r),p=Math.floor((0,g.FT)(t,d,s));return t[p]>c&&p1&&"function"==typeof arguments[i-1]&&(e=arguments[i-1],--i);let n=0;for(;n0}getInteracting(){return this.hints_[r.A.INTERACTING]>0}cancelAnimations(){let t;this.setHint(r.A.ANIMATING,-this.hints_[r.A.ANIMATING]);for(let e=0,i=this.animations_.length;e=0;--i){const n=this.animations_[i];let s=!0;for(let i=0,r=n.length;i0?o/r.duration:1;a>=1?(r.complete=!0,a=1):s=!1;const l=r.easing(a);if(r.sourceCenter){const t=r.sourceCenter[0],e=r.sourceCenter[1],i=r.targetCenter[0],n=r.targetCenter[1];this.nextCenter_=r.targetCenter;const s=t+l*(i-t),o=e+l*(n-e);this.targetCenter_=[s,o]}if(r.sourceResolution&&r.targetResolution){const t=1===l?r.targetResolution:r.sourceResolution+l*(r.targetResolution-r.sourceResolution);if(r.anchor){const e=this.getViewportSize_(this.getRotation()),i=this.constraints_.resolution(t,0,e,!0);this.targetCenter_=this.calculateCenterZoom(i,r.anchor)}this.nextResolution_=r.targetResolution,this.targetResolution_=t,this.applyTargetState_(!0)}if(void 0!==r.sourceRotation&&void 0!==r.targetRotation){const t=1===l?(0,u.xP)(r.targetRotation+Math.PI,2*Math.PI)-Math.PI:r.sourceRotation+l*(r.targetRotation-r.sourceRotation);if(r.anchor){const e=this.constraints_.rotation(t,!0);this.targetCenter_=this.calculateCenterRotate(e,r.anchor)}this.nextRotation_=r.targetRotation,this.targetRotation_=t}if(this.applyTargetState_(!0),e=!0,!r.complete)break}if(s){this.animations_[i]=null,this.setHint(r.A.ANIMATING,-1),this.nextCenter_=null,this.nextResolution_=NaN,this.nextRotation_=NaN;const t=n[0].callback;t&&A(t,!0)}}this.animations_=this.animations_.filter(Boolean),e&&void 0===this.updateAnimationKey_&&(this.updateAnimationKey_=requestAnimationFrame(this.updateAnimations_.bind(this)))}calculateCenterRotate(t,e){let i;const n=this.getCenterInternal();return void 0!==n&&(i=[n[0]-e[0],n[1]-e[1]],(0,h.e$)(i,t-this.getRotation()),(0,h.WQ)(i,e)),i}calculateCenterZoom(t,e){let i;const n=this.getCenterInternal(),r=this.getResolution();return void 0!==n&&void 0!==r&&(i=[e[0]-t*(e[0]-n[0])/r,e[1]-t*(e[1]-n[1])/r]),i}getViewportSize_(t){const e=this.viewportSize_;if(t){const i=e[0],n=e[1];return[Math.abs(i*Math.cos(t))+Math.abs(n*Math.sin(t)),Math.abs(i*Math.sin(t))+Math.abs(n*Math.cos(t))]}return e}setViewportSize(t){this.viewportSize_=Array.isArray(t)?t.slice():[100,100],this.getAnimating()||this.resolveConstraints(0)}getCenter(){const t=this.getCenterInternal();return t?(0,a.te)(t,this.getProjection()):t}getCenterInternal(){return this.get(s.CENTER)}getConstraints(){return this.constraints_}getConstrainResolution(){return this.get("constrainResolution")}getHints(t){return void 0!==t?(t[0]=this.hints_[0],t[1]=this.hints_[1],t):this.hints_.slice()}calculateExtent(t){const e=this.calculateExtentInternal(t);return(0,a.JR)(e,this.getProjection())}calculateExtentInternal(t){t=t||this.getViewportSizeMinusPadding_();const e=this.getCenterInternal();(0,c.v)(e,"The view center is not defined");const i=this.getResolution();(0,c.v)(void 0!==i,"The view resolution is not defined");const n=this.getRotation();return(0,c.v)(void 0!==n,"The view rotation is not defined"),(0,f.Bg)(e,i,n,t)}getMaxResolution(){return this.maxResolution_}getMinResolution(){return this.minResolution_}getMaxZoom(){return this.getZoomForResolution(this.minResolution_)}setMaxZoom(t){this.applyOptions_(this.getUpdatedOptions_({maxZoom:t}))}getMinZoom(){return this.getZoomForResolution(this.maxResolution_)}setMinZoom(t){this.applyOptions_(this.getUpdatedOptions_({minZoom:t}))}setConstrainResolution(t){this.applyOptions_(this.getUpdatedOptions_({constrainResolution:t}))}getProjection(){return this.projection_}getResolution(){return this.get(s.RESOLUTION)}getResolutions(){return this.resolutions_}getResolutionForExtent(t,e){return this.getResolutionForExtentInternal((0,a.SD)(t,this.getProjection()),e)}getResolutionForExtentInternal(t,e){e=e||this.getViewportSizeMinusPadding_();const i=(0,f.RG)(t)/e[0],n=(0,f.Oq)(t)/e[1];return Math.max(i,n)}getResolutionForValueFunction(t){t=t||2;const e=this.getConstrainedResolution(this.maxResolution_),i=this.minResolution_,n=Math.log(e/i)/Math.log(t);return function(i){return e/Math.pow(t,i*n)}}getRotation(){return this.get(s.ROTATION)}getValueForResolutionFunction(t){const e=Math.log(t||2),i=this.getConstrainedResolution(this.maxResolution_),n=this.minResolution_,r=Math.log(i/n)/e;return function(t){return Math.log(i/t)/e/r}}getViewportSizeMinusPadding_(t){let e=this.getViewportSize_(t);const i=this.padding_;return i&&(e=[e[0]-i[1]-i[3],e[1]-i[0]-i[2]]),e}getState(){const t=this.getProjection(),e=this.getResolution(),i=this.getRotation();let n=this.getCenterInternal();const r=this.padding_;if(r){const t=this.getViewportSizeMinusPadding_();n=C(n,this.getViewportSize_(),[t[0]/2+r[3],t[1]/2+r[0]],e,i)}return{center:n.slice(0),projection:void 0!==t?t:null,resolution:e,nextCenter:this.nextCenter_,nextResolution:this.nextResolution_,nextRotation:this.nextRotation_,rotation:i,zoom:this.getZoom()}}getViewStateAndExtent(){return{viewState:this.getState(),extent:this.calculateExtent()}}getZoom(){let t;const e=this.getResolution();return void 0!==e&&(t=this.getZoomForResolution(e)),t}getZoomForResolution(t){let e,i,n=this.minZoom_||0;if(this.resolutions_){const r=(0,g.FT)(this.resolutions_,t,1);n=r,e=this.resolutions_[r],i=r==this.resolutions_.length-1?2:e/this.resolutions_[r+1]}else e=this.maxResolution_,i=this.zoomFactor_;return n+Math.log(e/t)/Math.log(i)}getResolutionForZoom(t){if(this.resolutions_){if(this.resolutions_.length<=1)return 0;const e=(0,u.qE)(Math.floor(t),0,this.resolutions_.length-2),i=this.resolutions_[e]/this.resolutions_[e+1];return this.resolutions_[e]/Math.pow(i,(0,u.qE)(t-e,0,1))}return this.maxResolution_/Math.pow(this.zoomFactor_,t-this.minZoom_)}fit(t,e){let i;if((0,c.v)(Array.isArray(t)||"function"==typeof t.getSimplifiedGeometry,"Invalid extent or geometry provided as `geometry`"),Array.isArray(t)){(0,c.v)(!(0,f.Im)(t),"Cannot fit empty extent provided as `geometry`");const e=(0,a.SD)(t,this.getProjection());i=(0,b.VY)(e)}else if("Circle"===t.getType()){const e=(0,a.SD)(t.getExtent(),this.getProjection());i=(0,b.VY)(e),i.rotate(this.getRotation(),(0,f.q1)(e))}else{const e=(0,a.Tf)();i=e?t.clone().transform(e,this.getProjection()):t}this.fitInternal(i,e)}rotatedExtentForGeometry(t){const e=this.getRotation(),i=Math.cos(e),n=Math.sin(-e),r=t.getFlatCoordinates(),s=t.getStride();let o=1/0,a=1/0,l=-1/0,h=-1/0;for(let t=0,e=r.length;t{"use strict";i.d(e,{A:()=>n});const n={ANIMATING:0,INTERACTING:1}},6514:(t,e,i)=>{"use strict";function n(t,e,i){let n,s;i=i||r;let o=0,a=t.length,l=!1;for(;o>1),s=+i(t[n],e),s<0?o=n+1:(a=n,l=!s);return l?o:~o}function r(t,e){return t>e?1:t0?r-1:r}return n-1}if(i>0){for(let i=1;i0||i&&0===s)}))}i.d(e,{El:()=>n,FT:()=>s,V_:()=>r,WC:()=>h,X$:()=>a,aI:()=>l,gI:()=>o})},588:(t,e,i)=>{"use strict";function n(t,e){if(!t)throw new Error(e)}i.d(e,{v:()=>n})},3730:(t,e,i)=>{"use strict";i.d(e,{_j:()=>w,oJ:()=>f,sH:()=>b,cD:()=>x,S8:()=>A,eE:()=>v,dI:()=>E,fu:()=>_});const n={name:"rgb",min:[0,0,0],max:[255,255,255],channel:["red","green","blue"],alias:["RGB"]};var r={name:"xyz",min:[0,0,0],channel:["X","Y","Z"],alias:["XYZ","ciexyz","cie1931"],whitepoint:{2:{A:[109.85,100,35.585],C:[98.074,100,118.232],D50:[96.422,100,82.521],D55:[95.682,100,92.149],D65:[95.045592705167,100,108.9057750759878],D75:[94.972,100,122.638],F2:[99.187,100,67.395],F7:[95.044,100,108.755],F11:[100.966,100,64.37],E:[100,100,100]},10:{A:[111.144,100,35.2],C:[97.285,100,116.145],D50:[96.72,100,81.427],D55:[95.799,100,90.926],D65:[94.811,100,107.304],D75:[94.416,100,120.641],F2:[103.28,100,69.026],F7:[95.792,100,107.687],F11:[103.866,100,65.627],E:[100,100,100]}}};r.max=r.whitepoint[2].D65,r.rgb=function(t,e){e=e||r.whitepoint[2].E;var i,n,s,o=t[0]/e[0],a=t[1]/e[1],l=t[2]/e[2];return n=-.96924363628087*o+1.87596750150772*a+.041555057407175*l,s=.055630079696993*o+-.20397695888897*a+1.056971514242878*l,i=(i=3.240969941904521*o+-1.537383177570093*a+-.498610760293*l)>.0031308?1.055*Math.pow(i,1/2.4)-.055:i*=12.92,n=n>.0031308?1.055*Math.pow(n,1/2.4)-.055:n*=12.92,s=s>.0031308?1.055*Math.pow(s,1/2.4)-.055:s*=12.92,[255*(i=Math.min(Math.max(0,i),1)),255*(n=Math.min(Math.max(0,n),1)),255*(s=Math.min(Math.max(0,s),1))]},n.xyz=function(t,e){var i=t[0]/255,n=t[1]/255,s=t[2]/255,o=.21263900587151*(i=i>.04045?Math.pow((i+.055)/1.055,2.4):i/12.92)+.71516867876775*(n=n>.04045?Math.pow((n+.055)/1.055,2.4):n/12.92)+.072192315360733*(s=s>.04045?Math.pow((s+.055)/1.055,2.4):s/12.92),a=.019330818715591*i+.11919477979462*n+.95053215224966*s;return[(.41239079926595*i+.35758433938387*n+.18048078840183*s)*(e=e||r.whitepoint[2].E)[0],o*e[1],a*e[2]]};const s=r,o={name:"luv",min:[0,-134,-140],max:[100,224,122],channel:["lightness","u","v"],alias:["LUV","cieluv","cie1976"],xyz:function(t,e,i){var n,r,o,a,l,h,c,u,d;return o=t[0],a=t[1],l=t[2],0===o?[0,0,0]:(e=e||"D65",i=i||2,n=a/(13*o)+4*(c=s.whitepoint[i][e][0])/(c+15*(u=s.whitepoint[i][e][1])+3*(d=s.whitepoint[i][e][2]))||0,r=l/(13*o)+9*u/(c+15*u+3*d)||0,[9*(h=o>8?u*Math.pow((o+16)/116,3):u*o*.0011070564598794539)*n/(4*r)||0,h,h*(12-3*n-20*r)/(4*r)||0])}};s.luv=function(t,e,i){var n,r,o,a,l,h,c,u,d,p,f;e=e||"D65",i=i||2,p=4*(c=s.whitepoint[i][e][0])/(c+15*(u=s.whitepoint[i][e][1])+3*(d=s.whitepoint[i][e][2])),f=9*u/(c+15*u+3*d),n=4*(a=t[0])/(a+15*(l=t[1])+3*(h=t[2]))||0,r=9*l/(a+15*l+3*h)||0;var g=l/u;return[o=g<=.008856451679035631?903.2962962962961*g:116*Math.pow(g,1/3)-16,13*o*(n-p),13*o*(r-f)]};var a={name:"lchuv",channel:["lightness","chroma","hue"],alias:["LCHuv","cielchuv"],min:[0,0,0],max:[100,100,360],luv:function(t){var e,i=t[0],n=t[1];return e=t[2]/360*2*Math.PI,[i,n*Math.cos(e),n*Math.sin(e)]},xyz:function(t){return o.xyz(a.luv(t))}};const l=a;o.lchuv=function(t){var e=t[0],i=t[1],n=t[2],r=Math.sqrt(i*i+n*n),s=360*Math.atan2(n,i)/2/Math.PI;return s<0&&(s+=360),[e,r,s]},s.lchuv=function(t){return o.lchuv(s.luv(t))};const h={aliceblue:[240,248,255],antiquewhite:[250,235,215],aqua:[0,255,255],aquamarine:[127,255,212],azure:[240,255,255],beige:[245,245,220],bisque:[255,228,196],black:[0,0,0],blanchedalmond:[255,235,205],blue:[0,0,255],blueviolet:[138,43,226],brown:[165,42,42],burlywood:[222,184,135],cadetblue:[95,158,160],chartreuse:[127,255,0],chocolate:[210,105,30],coral:[255,127,80],cornflowerblue:[100,149,237],cornsilk:[255,248,220],crimson:[220,20,60],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgoldenrod:[184,134,11],darkgray:[169,169,169],darkgreen:[0,100,0],darkgrey:[169,169,169],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkseagreen:[143,188,143],darkslateblue:[72,61,139],darkslategray:[47,79,79],darkslategrey:[47,79,79],darkturquoise:[0,206,209],darkviolet:[148,0,211],deeppink:[255,20,147],deepskyblue:[0,191,255],dimgray:[105,105,105],dimgrey:[105,105,105],dodgerblue:[30,144,255],firebrick:[178,34,34],floralwhite:[255,250,240],forestgreen:[34,139,34],fuchsia:[255,0,255],gainsboro:[220,220,220],ghostwhite:[248,248,255],gold:[255,215,0],goldenrod:[218,165,32],gray:[128,128,128],green:[0,128,0],greenyellow:[173,255,47],grey:[128,128,128],honeydew:[240,255,240],hotpink:[255,105,180],indianred:[205,92,92],indigo:[75,0,130],ivory:[255,255,240],khaki:[240,230,140],lavender:[230,230,250],lavenderblush:[255,240,245],lawngreen:[124,252,0],lemonchiffon:[255,250,205],lightblue:[173,216,230],lightcoral:[240,128,128],lightcyan:[224,255,255],lightgoldenrodyellow:[250,250,210],lightgray:[211,211,211],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightsalmon:[255,160,122],lightseagreen:[32,178,170],lightskyblue:[135,206,250],lightslategray:[119,136,153],lightslategrey:[119,136,153],lightsteelblue:[176,196,222],lightyellow:[255,255,224],lime:[0,255,0],limegreen:[50,205,50],linen:[250,240,230],magenta:[255,0,255],maroon:[128,0,0],mediumaquamarine:[102,205,170],mediumblue:[0,0,205],mediumorchid:[186,85,211],mediumpurple:[147,112,219],mediumseagreen:[60,179,113],mediumslateblue:[123,104,238],mediumspringgreen:[0,250,154],mediumturquoise:[72,209,204],mediumvioletred:[199,21,133],midnightblue:[25,25,112],mintcream:[245,255,250],mistyrose:[255,228,225],moccasin:[255,228,181],navajowhite:[255,222,173],navy:[0,0,128],oldlace:[253,245,230],olive:[128,128,0],olivedrab:[107,142,35],orange:[255,165,0],orangered:[255,69,0],orchid:[218,112,214],palegoldenrod:[238,232,170],palegreen:[152,251,152],paleturquoise:[175,238,238],palevioletred:[219,112,147],papayawhip:[255,239,213],peachpuff:[255,218,185],peru:[205,133,63],pink:[255,192,203],plum:[221,160,221],powderblue:[176,224,230],purple:[128,0,128],rebeccapurple:[102,51,153],red:[255,0,0],rosybrown:[188,143,143],royalblue:[65,105,225],saddlebrown:[139,69,19],salmon:[250,128,114],sandybrown:[244,164,96],seagreen:[46,139,87],seashell:[255,245,238],sienna:[160,82,45],silver:[192,192,192],skyblue:[135,206,235],slateblue:[106,90,205],slategray:[112,128,144],slategrey:[112,128,144],snow:[255,250,250],springgreen:[0,255,127],steelblue:[70,130,180],tan:[210,180,140],teal:[0,128,128],thistle:[216,191,216],tomato:[255,99,71],turquoise:[64,224,208],violet:[238,130,238],wheat:[245,222,179],white:[255,255,255],whitesmoke:[245,245,245],yellow:[255,255,0],yellowgreen:[154,205,50]},c=function(t){var e,i,n=[],r=1;if("number"==typeof t)return{space:"rgb",values:[t>>>16,(65280&t)>>>8,255&t],alpha:1};if("number"==typeof t)return{space:"rgb",values:[t>>>16,(65280&t)>>>8,255&t],alpha:1};if(t=String(t).toLowerCase(),h[t])n=h[t].slice(),i="rgb";else if("transparent"===t)r=0,i="rgb",n=[0,0,0];else if("#"===t[0]){var s=t.slice(1),o=s.length;r=1,o<=4?(n=[parseInt(s[0]+s[0],16),parseInt(s[1]+s[1],16),parseInt(s[2]+s[2],16)],4===o&&(r=parseInt(s[3]+s[3],16)/255)):(n=[parseInt(s[0]+s[1],16),parseInt(s[2]+s[3],16),parseInt(s[4]+s[5],16)],8===o&&(r=parseInt(s[6]+s[7],16)/255)),n[0]||(n[0]=0),n[1]||(n[1]=0),n[2]||(n[2]=0),i="rgb"}else if(e=/^((?:rgba?|hs[lvb]a?|hwba?|cmyk?|xy[zy]|gray|lab|lchu?v?|[ly]uv|lms|oklch|oklab|color))\s*\(([^\)]*)\)/.exec(t)){var a=e[1],l="cmyk"===(i=a.replace(/a$/,""))?4:"gray"===i?1:3;n=e[2].trim().split(/\s*[,\/]\s*|\s+/),"color"===i&&(i=n.shift()),r=(n=n.map((function(t,e){if("%"===t[t.length-1])return t=parseFloat(t)/100,3===e?t:"rgb"===i?255*t:"h"===i[0]?100*t:"l"!==i[0]||e?"lab"===i?125*t:"lch"===i?e<2?150*t:360*t:"o"!==i[0]||e?"oklab"===i?.4*t:"oklch"===i?e<2?.4*t:360*t:t:t:100*t;if("h"===i[e]||2===e&&"h"===i[i.length-1]){if(void 0!==u[t])return u[t];if(t.endsWith("deg"))return parseFloat(t);if(t.endsWith("turn"))return 360*parseFloat(t);if(t.endsWith("grad"))return 360*parseFloat(t)/400;if(t.endsWith("rad"))return 180*parseFloat(t)/Math.PI}return"none"===t?0:parseFloat(t)}))).length>l?n.pop():1}else/[0-9](?:\s|\/|,)/.test(t)&&(n=t.match(/([0-9]+)/g).map((function(t){return parseFloat(t)})),i=t.match(/([a-z])/gi)?.join("")?.toLowerCase()||"rgb");return{space:i,values:n,alpha:r}};var u={red:0,orange:60,yellow:120,green:180,blue:240,purple:300};const d={name:"hsl",min:[0,0,0],max:[360,100,100],channel:["hue","saturation","lightness"],alias:["HSL"],rgb:function(t){var e,i,n,r,s,o=t[0]/360,a=t[1]/100,l=t[2]/100,h=0;if(0===a)return[s=255*l,s,s];for(e=2*l-(i=l<.5?l*(1+a):l+a-l*a),r=[0,0,0];h<3;)(n=o+1/3*-(h-1))<0?n++:n>1&&n--,s=6*n<1?e+6*(i-e)*n:2*n<1?i:3*n<2?e+(i-e)*(2/3-n)*6:e,r[h++]=255*s;return r}};n.hsl=function(t){var e,i,n=t[0]/255,r=t[1]/255,s=t[2]/255,o=Math.min(n,r,s),a=Math.max(n,r,s),l=a-o;return a===o?e=0:n===a?e=(r-s)/l:r===a?e=2+(s-n)/l:s===a&&(e=4+(n-r)/l),(e=Math.min(60*e,360))<0&&(e+=360),i=(o+a)/2,[e,100*(a===o?0:i<=.5?l/(a+o):l/(2-a-o)),100*i]};var p=i(1597);function f(t){return"string"==typeof t?t:E(t)}const g=1024,m={};let y=0;function _(t){if(4===t.length)return t;const e=t.slice();return e[3]=1,e}function v(t){const e=s.lchuv(n.xyz(t));return e[3]=t[3],e}function x(t){const e=s.rgb(l.xyz(t));return e[3]=t[3],e}function b(t){if(m.hasOwnProperty(t))return m[t];if(y>=g){let t=0;for(const e in m)0==(3&t++)&&(delete m[e],--y)}const e=function(t){var e;Array.isArray(t)&&t.raw&&(t=String.raw(...arguments)),t instanceof Number&&(t=+t);var i=c(t);if(!i.space)return[];const r="h"===i.space[0]?d.min:n.min,s="h"===i.space[0]?d.max:n.max;return(e=Array(3))[0]=Math.min(Math.max(i.values[0],r[0]),s[0]),e[1]=Math.min(Math.max(i.values[1],r[1]),s[1]),e[2]=Math.min(Math.max(i.values[2],r[2]),s[2]),"h"===i.space[0]&&(e=d.rgb(e)),e.push(Math.min(Math.max(i.alpha,0),1)),e}(t);if(4!==e.length)throw new Error('failed to parse "'+t+'" as color');for(const i of e)if(isNaN(i))throw new Error('failed to parse "'+t+'" as color');return A(e),m[t]=e,++y,e}function w(t){return Array.isArray(t)?t:b(t)}function A(t){return t[0]=(0,p.qE)(t[0]+.5|0,0,255),t[1]=(0,p.qE)(t[1]+.5|0,0,255),t[2]=(0,p.qE)(t[2]+.5|0,0,255),t[3]=(0,p.qE)(t[3],0,1),t}function E(t){let e=t[0];e!=(0|e)&&(e=e+.5|0);let i=t[1];i!=(0|i)&&(i=i+.5|0);let n=t[2];return n!=(0|n)&&(n=n+.5|0),"rgba("+e+","+i+","+n+","+(void 0===t[3]?1:Math.round(1e3*t[3])/1e3)+")"}},7295:(t,e,i)=>{"use strict";i.d(e,{F:()=>l});var n=i(6141),r=i(8711),s=i(7907),o=i(2241),a=i(3730);function l(t){return t?Array.isArray(t)?(0,a.dI)(t):"object"==typeof t&&"src"in t?function(t){if(!t.offset||!t.size)return o.ue.getPattern(t.src,"anonymous",t.color);const e=t.src+":"+t.offset,i=o.ue.getPattern(e,void 0,t.color);if(i)return i;const a=o.ue.get(t.src,"anonymous",null);if(a.getImageState()!==n.A.LOADED)return null;const l=(0,r.Y)(t.size[0],t.size[1]);return l.drawImage(a.getImage(1),t.offset[0],t.offset[1],t.size[0],t.size[1],0,0,t.size[0],t.size[1]),(0,s.J)(l.canvas,e,void 0,n.A.LOADED,t.color,!0),o.ue.getPattern(e,void 0,t.color)}(t):t:null}},4422:(t,e,i)=>{"use strict";i.d(e,{R8:()=>s});const n={info:1,warn:2,error:3,none:4};let r=n.info;function s(...t){r>n.warn||console.warn(...t)}},6933:(t,e,i)=>{"use strict";i.d(e,{Li:()=>l,WQ:()=>r,aI:()=>s,e$:()=>o,hs:()=>a});var n=i(915);function r(t,e){return t[0]+=+e[0],t[1]+=+e[1],t}function s(t,e){let i=!0;for(let n=t.length-1;n>=0;--n)if(t[n]!=e[n]){i=!1;break}return i}function o(t,e){const i=Math.cos(e),n=Math.sin(e),r=t[0]*i-t[1]*n,s=t[1]*i+t[0]*n;return t[0]=r,t[1]=s,t}function a(t,e){return t[0]*=e,t[1]*=e,t}function l(t,e){if(e.canWrapX()){const i=(0,n.RG)(e.getExtent()),r=function(t,e,i){const r=e.getExtent();let s=0;return e.canWrapX()&&(t[0]r[2])&&(i=i||(0,n.RG)(r),s=Math.floor((t[0]-r[0])/i)),s}(t,e,i);r&&(t[0]-=r*i)}return t}},5176:(t,e,i)=>{"use strict";i.d(e,{$N:()=>s,K5:()=>h,Si:()=>n,XI:()=>r,nT:()=>o});const n="ol-hidden",r="ol-unselectable",s="ol-control",o="ol-collapsed",a=new RegExp(["^\\s*(?=(?:(?:[-a-z]+\\s*){0,2}(italic|oblique))?)","(?=(?:(?:[-a-z]+\\s*){0,2}(small-caps))?)","(?=(?:(?:[-a-z]+\\s*){0,2}(bold(?:er)?|lighter|[1-9]00 ))?)","(?:(?:normal|\\1|\\2|\\3)\\s*){0,3}((?:xx?-)?","(?:small|large)|medium|smaller|larger|[\\.\\d]+(?:\\%|in|[cem]m|ex|p[ctx]))","(?:\\s*\\/\\s*(normal|[\\.\\d]+(?:\\%|in|[cem]m|ex|p[ctx])?))","?\\s*([-,\\\"\\'\\sa-z]+?)\\s*$"].join(""),"i"),l=["style","variant","weight","size","lineHeight","family"],h=function(t){const e=t.match(a);if(!e)return null;const i={lineHeight:"normal",size:"1.2em",style:"normal",weight:"normal",variant:"normal"};for(let t=0,n=l.length;t{"use strict";i.d(e,{WM:()=>c,Y:()=>r,Yg:()=>a,fo:()=>l,gS:()=>h,lr:()=>o});var n=i(7771);function r(t,e,i,r){let s;return s=i&&i.length?i.shift():n.Wl?new OffscreenCanvas(t||300,e||300):document.createElement("canvas"),t&&(s.width=t),e&&(s.height=e),s.getContext("2d",r)}let s;function o(){return s||(s=r(1,1)),s}function a(t){const e=t.canvas;e.width=1,e.height=1,t.clearRect(0,0,1,1)}function l(t,e){const i=e.parentNode;i&&i.replaceChild(t,e)}function h(t){for(;t.lastChild;)t.lastChild.remove()}function c(t,e){const i=t.childNodes;for(let n=0;;++n){const r=i[n],s=e[n];if(!r&&!s)break;r!==s&&(r?s?t.insertBefore(s,r):(t.removeChild(r),--n):t.appendChild(s))}}},3474:(t,e,i)=>{"use strict";function n(t){return Math.pow(t,3)}function r(t){return 1-n(1-t)}function s(t){return 3*t*t-2*t*t*t}function o(t){return t}i.d(e,{T9:()=>s,a6:()=>n,sn:()=>o,vT:()=>r})},9438:(t,e,i)=>{"use strict";i.d(e,{JH:()=>o,Jz:()=>s,KT:()=>r});var n=i(3530);function r(t,e,i,n,r){if(r){const r=i;i=function(){t.removeEventListener(e,i),r.apply(n??this,arguments)}}else n&&n!==t&&(i=i.bind(n));const s={target:t,type:e,listener:i};return t.addEventListener(e,i),s}function s(t,e,i,n){return r(t,e,i,n,!0)}function o(t){t&&t.target&&(t.target.removeEventListener(t.type,t.listener),(0,n.I)(t))}},1685:(t,e,i)=>{"use strict";i.d(e,{Ay:()=>n});const n=class{constructor(t){this.propagationStopped,this.defaultPrevented,this.type=t,this.target=null}preventDefault(){this.defaultPrevented=!0}stopPropagation(){this.propagationStopped=!0}}},6837:(t,e,i)=>{"use strict";i.d(e,{A:()=>n});const n={CHANGE:"change",ERROR:"error",BLUR:"blur",CLEAR:"clear",CONTEXTMENU:"contextmenu",CLICK:"click",DBLCLICK:"dblclick",DRAGENTER:"dragenter",DRAGOVER:"dragover",DROP:"drop",FOCUS:"focus",KEYDOWN:"keydown",KEYPRESS:"keypress",LOAD:"load",RESIZE:"resize",TOUCHMOVE:"touchmove",WHEEL:"wheel"}},9332:(t,e,i)=>{"use strict";i.d(e,{A:()=>l});var n=i(25),r=i(1685),s=i(4238),o=i(3530);class a extends n.A{constructor(t){super(),this.eventTarget_=t,this.pendingRemovals_=null,this.dispatching_=null,this.listeners_=null}addEventListener(t,e){if(!t||!e)return;const i=this.listeners_||(this.listeners_={}),n=i[t]||(i[t]=[]);n.includes(e)||n.push(e)}dispatchEvent(t){const e="string"==typeof t,i=e?t:t.type,n=this.listeners_&&this.listeners_[i];if(!n)return;const o=e?new r.Ay(t):t;o.target||(o.target=this.eventTarget_||this);const a=this.dispatching_||(this.dispatching_={}),l=this.pendingRemovals_||(this.pendingRemovals_={});let h;i in a||(a[i]=0,l[i]=0),++a[i];for(let t=0,e=n.length;t0)}removeEventListener(t,e){if(!this.listeners_)return;const i=this.listeners_[t];if(!i)return;const n=i.indexOf(e);-1!==n&&(this.pendingRemovals_&&t in this.pendingRemovals_?(i[n]=s.tV,++this.pendingRemovals_[t]):(i.splice(n,1),0===i.length&&delete this.listeners_[t]))}}const l=a},915:(t,e,i)=>{"use strict";i.d(e,{$C:()=>v,$u:()=>D,Bg:()=>R,HY:()=>F,Im:()=>O,Ld:()=>a,Li:()=>N,Mx:()=>j,N:()=>p,NW:()=>z,Oq:()=>I,Py:()=>M,QJ:()=>G,R:()=>E,R8:()=>x,RG:()=>L,Rj:()=>c,S5:()=>d,Tr:()=>r,UG:()=>A,Vy:()=>m,WU:()=>P,X$:()=>_,Ym:()=>l,_N:()=>k,aI:()=>y,aZ:()=>f,dP:()=>g,k_:()=>C,ms:()=>h,o8:()=>o,q1:()=>S,qF:()=>T,r:()=>s,sB:()=>w,vz:()=>u});var n=i(1580);function r(t){const e=[1/0,1/0,-1/0,-1/0];for(let i=0,n=t.length;is&&(h|=n.A.RIGHT),lo&&(h|=n.A.ABOVE),h===n.A.UNKNOWN&&(h=n.A.INTERSECTING),h}function d(){return[1/0,1/0,-1/0,-1/0]}function p(t,e,i,n,r){return r?(r[0]=t,r[1]=e,r[2]=i,r[3]=n,r):[t,e,i,n]}function f(t){return p(1/0,1/0,-1/0,-1/0,t)}function g(t,e){const i=t[0],n=t[1];return p(i,n,i,n,e)}function m(t,e,i,n,r){return x(f(r),t,e,i,n)}function y(t,e){return t[0]==e[0]&&t[2]==e[2]&&t[1]==e[1]&&t[3]==e[3]}function _(t,e){return e[0]t[2]&&(t[2]=e[2]),e[1]t[3]&&(t[3]=e[3]),t}function v(t,e){e[0]t[2]&&(t[2]=e[0]),e[1]t[3]&&(t[3]=e[1])}function x(t,e,i,n,r){for(;ie[0]?n[0]=t[0]:n[0]=e[0],t[1]>e[1]?n[1]=t[1]:n[1]=e[1],t[2]=e[0]&&t[1]<=e[3]&&t[3]>=e[1]}function O(t){return t[2]=a&&m<=h),r||!(o&n.A.RIGHT)||s&n.A.RIGHT||(y=f-(p-h)*g,r=y>=l&&y<=c),r||!(o&n.A.BELOW)||s&n.A.BELOW||(m=p-(f-l)/g,r=m>=a&&m<=h),r||!(o&n.A.LEFT)||s&n.A.LEFT||(y=f-(p-a)*g,r=y>=l&&y<=c)}return r}function z(t,e,i,n){if(O(t))return f(i);let r=[];if(n>1){const e=t[2]-t[0],i=t[3]-t[1];for(let s=0;s=i[2])){const e=L(i),r=Math.floor((n[0]-i[0])/e)*e;t[0]-=r,t[2]-=r}return t}function G(t,e,i){if(e.canWrapX()){const n=e.getExtent();if(!isFinite(t[0])||!isFinite(t[2]))return[[n[0],t[1],n[2],t[3]]];N(t,e);const r=L(n);if(L(t)>r&&!i)return[[n[0],t[1],n[2],t[3]]];if(t[0]n[2])return[[t[0],t[1],n[2],t[3]],[n[0],t[1],t[2]-r,t[3]]]}return[t]}},1580:(t,e,i)=>{"use strict";i.d(e,{A:()=>n});const n={UNKNOWN:0,INTERSECTING:1,ABOVE:2,RIGHT:4,BELOW:8,LEFT:16}},1142:(t,e,i)=>{"use strict";i.d(e,{m8:()=>s,nF:()=>o});var n=i(4238);let r=!1;function s(t,e,i,n,s,o,a){const l=new XMLHttpRequest;l.open("GET","function"==typeof t?t(i,n,s):t,!0),"arraybuffer"==e.getType()&&(l.responseType="arraybuffer"),l.withCredentials=r,l.onload=function(t){if(!l.status||l.status>=200&&l.status<300){const t=e.getType();try{let n;"text"==t||"json"==t?n=l.responseText:"xml"==t?n=l.responseXML||l.responseText:"arraybuffer"==t&&(n=l.response),n?o(e.readFeatures(n,{extent:i,featureProjection:s}),e.readProjection(n)):a()}catch{a()}}else a()},l.onerror=a,l.send()}function o(t,e){return function(i,r,o,a,l){const h=this;s(t,e,i,r,o,(function(t,e){h.addFeatures(t),void 0!==a&&a(t)}),l||n.tV)}}},303:(t,e,i)=>{"use strict";i.d(e,{te:()=>C,Bs:()=>E,Ay:()=>b,hX:()=>w});var n=i(6717),r=i(4778),s=i(4294),o=i(1217),a=i(1064),l=i(503),h=i(6702),c=i(2871),u=i(6837),d=i(7430),p=i(915),f=i(9438);class g extends d.A{constructor(t){super(),this.geometries_=t,this.changeEventsKeys_=[],this.listenGeometriesChange_()}unlistenGeometriesChange_(){this.changeEventsKeys_.forEach(f.JH),this.changeEventsKeys_.length=0}listenGeometriesChange_(){const t=this.geometries_;for(let e=0,i=t.length;et.clone()))}const y=g;var _=i(4087),v=i(594),x=i(3402);const b=class{constructor(){this.dataProjection=void 0,this.defaultFeatureProjection=void 0,this.featureClass=n.A,this.supportedMediaTypes=null}getReadOptions(t,e){if(e){let i=e.dataProjection?(0,v.Jt)(e.dataProjection):this.readProjection(t);e.extent&&i&&"tile-pixels"===i.getUnits()&&(i=(0,v.Jt)(i),i.setWorldExtent(e.extent)),e={dataProjection:i,featureProjection:e.featureProjection}}return this.adaptOptions(e)}adaptOptions(t){return Object.assign({dataProjection:this.dataProjection,featureProjection:this.defaultFeatureProjection,featureClass:this.featureClass},t)}getType(){return(0,_.b0)()}readFeature(t,e){return(0,_.b0)()}readFeatures(t,e){return(0,_.b0)()}readGeometry(t,e){return(0,_.b0)()}readProjection(t){return(0,_.b0)()}writeFeature(t,e){return(0,_.b0)()}writeFeatures(t,e){return(0,_.b0)()}writeGeometry(t,e){return(0,_.b0)()}};function w(t,e,i){const n=i?(0,v.Jt)(i.featureProjection):null,r=i?(0,v.Jt)(i.dataProjection):null;let s=t;if(n&&r&&!(0,v.tI)(n,r)){e&&(s=t.clone());const i=e?n:r,o=e?r:n;"tile-pixels"===i.getUnits()?s.transform(i,o):s.applyTransform((0,v.RG)(i,o))}if(e&&i&&void 0!==i.decimals){const e=Math.pow(10,i.decimals),n=function(t){for(let i=0,n=t.length;iE({...t,geometry:e}))).flat();const n="MultiPolygon"===i.type?"Polygon":i.type;if("GeometryCollection"===n||"Circle"===n)throw new Error("Unsupported geometry type: "+n);const s=i.layout.length;return w(new r.Ay(n,"Polygon"===n?function(t,e,i){return Array.isArray(e[0])?((0,x.mb)(t,0,e,i)||(t=t.slice(),(0,x.NK)(t,0,e,i)),t):((0,x.PA)(t,0,e,i)||(t=t.slice(),(0,x.ug)(t,0,e,i)),t)}(i.flatCoordinates,i.ends,s):i.flatCoordinates,i.ends?.flat(),s,t.properties||{},t.id).enableSimplifyTransformed(),!1,e)}function C(t,e){if(!t)return null;if(Array.isArray(t)){const i=t.map((t=>C(t,e)));return new y(i)}return w(new(0,A[t.type])(t.flatCoordinates,t.layout,t.ends),!1,e)}},1365:(t,e,i)=>{"use strict";i.d(e,{A:()=>m});var n=i(6717),r=i(303),s=i(4087);class o extends r.Ay{constructor(){super()}getType(){return"json"}readFeature(t,e){return this.readFeatureFromObject(a(t),this.getReadOptions(t,e))}readFeatures(t,e){return this.readFeaturesFromObject(a(t),this.getReadOptions(t,e))}readFeatureFromObject(t,e){return(0,s.b0)()}readFeaturesFromObject(t,e){return(0,s.b0)()}readGeometry(t,e){return this.readGeometryFromObject(a(t),this.getReadOptions(t,e))}readGeometryFromObject(t,e){return(0,s.b0)()}readProjection(t){return this.readProjectionFromObject(a(t))}readProjectionFromObject(t){return(0,s.b0)()}writeFeature(t,e){return JSON.stringify(this.writeFeatureObject(t,e))}writeFeatureObject(t,e){return(0,s.b0)()}writeFeatures(t,e){return JSON.stringify(this.writeFeaturesObject(t,e))}writeFeaturesObject(t,e){return(0,s.b0)()}writeGeometry(t,e){return JSON.stringify(this.writeGeometryObject(t,e))}writeGeometryObject(t,e){return(0,s.b0)()}}function a(t){if("string"==typeof t){return JSON.parse(t)||null}return null!==t?t:null}const l=o;var h=i(4778),c=i(2497),u=i(2096),d=i(594),p=i(3530);function f(t,e){if(!t)return null;let i;switch(t.type){case"Point":i=function(t){const e=t.coordinates;return{type:"Point",flatCoordinates:e,layout:(0,u.p0)(e.length)}}(t);break;case"LineString":i=function(t){const e=t.coordinates,i=e.flat();return{type:"LineString",flatCoordinates:i,ends:[i.length],layout:(0,u.p0)(e[0]?.length||2)}}(t);break;case"Polygon":i=function(t){const e=t.coordinates,i=[],n=e[0]?.[0]?.length;return{type:"Polygon",flatCoordinates:i,ends:(0,c.KG)(i,0,e,n),layout:(0,u.p0)(n)}}(t);break;case"MultiPoint":i=function(t){const e=t.coordinates;return{type:"MultiPoint",flatCoordinates:e.flat(),layout:(0,u.p0)(e[0]?.length||2)}}(t);break;case"MultiLineString":i=function(t){const e=t.coordinates,i=e[0]?.[0]?.length||2,n=[];return{type:"MultiLineString",flatCoordinates:n,ends:(0,c.KG)(n,0,e,i),layout:(0,u.p0)(i)}}(t);break;case"MultiPolygon":i=function(t){const e=t.coordinates,i=[],n=e[0]?.[0]?.[0].length||2;return{type:"MultiPolygon",flatCoordinates:i,ends:(0,c.d6)(i,0,e,n),layout:(0,u.p0)(n)}}(t);break;case"GeometryCollection":i=function(t,e){const i=t.geometries.map((function(t){return f(t)}));return i}(t);break;default:throw new Error("Unsupported GeoJSON type: "+t.type)}return i}function g(t,e){const i=(t=(0,r.hX)(t,!0,e)).getType();let n;switch(i){case"Point":n=function(t,e){return{type:"Point",coordinates:t.getCoordinates()}}(t);break;case"LineString":n=function(t,e){return{type:"LineString",coordinates:t.getCoordinates()}}(t);break;case"Polygon":n=function(t,e){let i;return e&&(i=e.rightHanded),{type:"Polygon",coordinates:t.getCoordinates(i)}}(t,e);break;case"MultiPoint":n=function(t,e){return{type:"MultiPoint",coordinates:t.getCoordinates()}}(t);break;case"MultiLineString":n=function(t,e){return{type:"MultiLineString",coordinates:t.getCoordinates()}}(t);break;case"MultiPolygon":n=function(t,e){let i;return e&&(i=e.rightHanded),{type:"MultiPolygon",coordinates:t.getCoordinates(i)}}(t,e);break;case"GeometryCollection":n=function(t,e){delete(e=Object.assign({},e)).featureProjection;return{type:"GeometryCollection",geometries:t.getGeometriesArray().map((function(t){return g(t,e)}))}}(t,e);break;case"Circle":n={type:"GeometryCollection",geometries:[]};break;default:throw new Error("Unsupported geometry type: "+i)}return n}const m=class extends l{constructor(t){t=t||{},super(),this.dataProjection=(0,d.Jt)(t.dataProjection?t.dataProjection:"EPSG:4326"),t.featureProjection&&(this.defaultFeatureProjection=(0,d.Jt)(t.featureProjection)),t.featureClass&&(this.featureClass=t.featureClass),this.geometryName_=t.geometryName,this.extractGeometryName_=t.extractGeometryName,this.supportedMediaTypes=["application/geo+json","application/vnd.geo+json"]}readFeatureFromObject(t,e){let i=null;i="Feature"===t.type?t:{type:"Feature",geometry:t,properties:null};const s=f(i.geometry);if(this.featureClass===h.Ay)return(0,r.Bs)({geometry:s,id:i.id,properties:i.properties},e);const o=new n.A;return this.geometryName_?o.setGeometryName(this.geometryName_):this.extractGeometryName_&&i.geometry_name&&o.setGeometryName(i.geometry_name),o.setGeometry((0,r.te)(s,e)),"id"in i&&o.setId(i.id),i.properties&&o.setProperties(i.properties,!0),o}readFeaturesFromObject(t,e){let i=null;if("FeatureCollection"===t.type){i=[];const n=t.features;for(let t=0,r=n.length;t{"use strict";i.d(e,{B4:()=>a,W8:()=>s,hq:()=>l,rT:()=>r,tV:()=>o});var n=i(6514);function r(){return!0}function s(){return!1}function o(){}function a(t){let e,i,r;return function(){const s=Array.prototype.slice.call(arguments);return i&&this===r&&(0,n.aI)(s,i)||(r=this,i=s,e=t.apply(this,arguments)),e}}function l(t){return function(){let e;try{e=t()}catch(t){return Promise.reject(t)}return e instanceof Promise?e:Promise.resolve(e)}()}},7430:(t,e,i)=>{"use strict";i.d(e,{A:()=>d});var n=i(4120),r=i(4087),s=i(9703),o=i(915),a=i(594),l=i(4238),h=i(7622);const c=(0,s.vt)();class u extends n.A{constructor(){super(),this.extent_=(0,o.S5)(),this.extentRevision_=-1,this.simplifiedGeometryMaxMinSquaredTolerance=0,this.simplifiedGeometryRevision=0,this.simplifyTransformedInternal=(0,l.B4)(((t,e,i)=>{if(!i)return this.getSimplifiedGeometry(e);const n=this.clone();return n.applyTransform(i),n.getSimplifiedGeometry(e)}))}simplifyTransformed(t,e){return this.simplifyTransformedInternal(this.getRevision(),t,e)}clone(){return(0,r.b0)()}closestPointXY(t,e,i,n){return(0,r.b0)()}containsXY(t,e){const i=this.getClosestPoint([t,e]);return i[0]===t&&i[1]===e}getClosestPoint(t,e){return e=e||[NaN,NaN],this.closestPointXY(t[0],t[1],e,1/0),e}intersectsCoordinate(t){return this.containsXY(t[0],t[1])}computeExtent(t){return(0,r.b0)()}getExtent(t){if(this.extentRevision_!=this.getRevision()){const t=this.computeExtent(this.extent_);(isNaN(t[0])||isNaN(t[1]))&&(0,o.aZ)(t),this.extentRevision_=this.getRevision()}return(0,o.$u)(this.extent_,t)}rotate(t,e){(0,r.b0)()}scale(t,e,i){(0,r.b0)()}simplify(t){return this.getSimplifiedGeometry(t*t)}getSimplifiedGeometry(t){return(0,r.b0)()}getType(){return(0,r.b0)()}applyTransform(t){(0,r.b0)()}intersectsExtent(t){return(0,r.b0)()}translate(t,e){(0,r.b0)()}transform(t,e){const i=(0,a.Jt)(t),n="tile-pixels"==i.getUnits()?function(t,n,r){const l=i.getExtent(),u=i.getWorldExtent(),d=(0,o.Oq)(u)/(0,o.Oq)(l);return(0,s.Zz)(c,u[0],u[3],d,-d,0,0,0),(0,h.Rc)(t,0,t.length,r,c,n),(0,a.RG)(i,e)(t,n,r)}:(0,a.RG)(i,e);return this.applyTransform(n),this}}const d=u},1217:(t,e,i)=>{"use strict";i.d(e,{A:()=>g});var n=i(2096),r=i(3953),s=i(915),o=i(2497),a=i(3671),l=i(6514),h=i(1374),c=i(6361),u=i(9969),d=i(4350),p=i(904);class f extends n.Ay{constructor(t,e){super(),this.flatMidpoint_=null,this.flatMidpointRevision_=-1,this.maxDelta_=-1,this.maxDeltaRevision_=-1,void 0===e||Array.isArray(t[0])?this.setCoordinates(t,e):this.setFlatCoordinates(e,t)}appendCoordinate(t){(0,l.X$)(this.flatCoordinates,t),this.changed()}clone(){const t=new f(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,n){return n<(0,s.Ld)(this.getExtent(),t,e)?n:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt((0,r.MD)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),(0,r.n)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,this.maxDelta_,!1,t,e,i,n))}forEachSegment(t){return(0,h.j)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t)}getCoordinateAtM(t,e){return"XYM"!=this.layout&&"XYZM"!=this.layout?null:(e=void 0!==e&&e,(0,u.gr)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e))}getCoordinates(){return(0,c.n2)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getCoordinateAt(t,e){return(0,u.SH)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e,this.stride)}getLength(){return(0,p.k)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getFlatMidpoint(){return this.flatMidpointRevision_!=this.getRevision()&&(this.flatMidpoint_=this.getCoordinateAt(.5,this.flatMidpoint_??void 0),this.flatMidpointRevision_=this.getRevision()),this.flatMidpoint_}getSimplifiedGeometryInternal(t){const e=[];return e.length=(0,a.P4)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e,0),new f(e,"XY")}getType(){return"LineString"}intersectsExtent(t){return(0,d.gp)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t)}setCoordinates(t,e){this.setLayout(e,t,1),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=(0,o.z2)(this.flatCoordinates,0,t,this.stride),this.changed()}}const g=f},6702:(t,e,i)=>{"use strict";i.d(e,{A:()=>f});var n=i(1217),r=i(2096),s=i(3953),o=i(915),a=i(2497),l=i(3671),h=i(6514),c=i(6361),u=i(9969),d=i(4350);class p extends r.Ay{constructor(t,e,i){if(super(),this.ends_=[],this.maxDelta_=-1,this.maxDeltaRevision_=-1,Array.isArray(t[0]))this.setCoordinates(t,e);else if(void 0!==e&&i)this.setFlatCoordinates(e,t),this.ends_=i;else{const e=t,i=[],n=[];for(let t=0,r=e.length;t{"use strict";i.d(e,{A:()=>u});var n=i(4294),r=i(2096),s=i(915),o=i(2497),a=i(6514),l=i(6361),h=i(1597);class c extends r.Ay{constructor(t,e){super(),e&&!Array.isArray(t[0])?this.setFlatCoordinates(e,t):this.setCoordinates(t,e)}appendPoint(t){(0,a.X$)(this.flatCoordinates,t.getFlatCoordinates()),this.changed()}clone(){const t=new c(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,n){if(n<(0,s.Ld)(this.getExtent(),t,e))return n;const r=this.flatCoordinates,o=this.stride;for(let s=0,a=r.length;s{"use strict";i.d(e,{A:()=>v});var n=i(503),r=i(1064),s=i(2096),o=i(3953),a=i(915),l=i(2497),h=i(6514),c=i(2616),u=i(6361),d=i(4350),p=i(3402),f=i(8609),g=i(4049),m=i(2845),y=i(3671);class _ extends s.Ay{constructor(t,e,i){if(super(),this.endss_=[],this.flatInteriorPointsRevision_=-1,this.flatInteriorPoints_=null,this.maxDelta_=-1,this.maxDeltaRevision_=-1,this.orientedRevision_=-1,this.orientedFlatCoordinates_=null,!i&&!Array.isArray(t[0])){const n=t,r=[],s=[];for(let t=0,e=n.length;t{"use strict";i.d(e,{A:()=>l});var n=i(2096),r=i(915),s=i(2497),o=i(1597);class a extends n.Ay{constructor(t,e){super(),this.setCoordinates(t,e)}clone(){const t=new a(this.flatCoordinates.slice(),this.layout);return t.applyProperties(this),t}closestPointXY(t,e,i,n){const r=this.flatCoordinates,s=(0,o.hG)(t,e,r[0],r[1]);if(s{"use strict";i.d(e,{Ay:()=>v,VY:()=>x});var n=i(2096),r=i(3953),s=i(915),o=i(2497),a=i(3671),l=i(6361),h=i(8609);class c extends n.Ay{constructor(t,e){super(),this.maxDelta_=-1,this.maxDeltaRevision_=-1,void 0===e||Array.isArray(t[0])?this.setCoordinates(t,e):this.setFlatCoordinates(e,t)}clone(){return new c(this.flatCoordinates.slice(),this.layout)}closestPointXY(t,e,i,n){return n<(0,s.Ld)(this.getExtent(),t,e)?n:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt((0,r.MD)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),(0,r.n)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,this.maxDelta_,!0,t,e,i,n))}getArea(){return(0,h.eN)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getCoordinates(){return(0,l.n2)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride)}getSimplifiedGeometryInternal(t){const e=[];return e.length=(0,a.P4)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t,e,0),new c(e,"XY")}getType(){return"LinearRing"}intersectsExtent(t){return!1}setCoordinates(t,e){this.setLayout(e,t,1),this.flatCoordinates||(this.flatCoordinates=[]),this.flatCoordinates.length=(0,o.z2)(this.flatCoordinates,0,t,this.stride),this.changed()}}const u=c;var d=i(4294),p=i(6514),f=i(2616),g=i(4350),m=i(3402),y=i(2845);class _ extends n.Ay{constructor(t,e,i){super(),this.ends_=[],this.flatInteriorPointRevision_=-1,this.flatInteriorPoint_=null,this.maxDelta_=-1,this.maxDeltaRevision_=-1,this.orientedRevision_=-1,this.orientedFlatCoordinates_=null,void 0!==e&&i?(this.setFlatCoordinates(e,t),this.ends_=i):this.setCoordinates(t,e)}appendLinearRing(t){this.flatCoordinates?(0,p.X$)(this.flatCoordinates,t.getFlatCoordinates()):this.flatCoordinates=t.getFlatCoordinates().slice(),this.ends_.push(this.flatCoordinates.length),this.changed()}clone(){const t=new _(this.flatCoordinates.slice(),this.layout,this.ends_.slice());return t.applyProperties(this),t}closestPointXY(t,e,i,n){return n<(0,s.Ld)(this.getExtent(),t,e)?n:(this.maxDeltaRevision_!=this.getRevision()&&(this.maxDelta_=Math.sqrt((0,r.HX)(this.flatCoordinates,0,this.ends_,this.stride,0)),this.maxDeltaRevision_=this.getRevision()),(0,r.oW)(this.flatCoordinates,0,this.ends_,this.stride,this.maxDelta_,!0,t,e,i,n))}containsXY(t,e){return(0,y.zb)(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t,e)}getArea(){return(0,h.PK)(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride)}getCoordinates(t){let e;return void 0!==t?(e=this.getOrientedFlatCoordinates().slice(),(0,m.ug)(e,0,this.ends_,this.stride,t)):e=this.flatCoordinates,(0,l.cD)(e,0,this.ends_,this.stride)}getEnds(){return this.ends_}getFlatInteriorPoint(){if(this.flatInteriorPointRevision_!=this.getRevision()){const t=(0,s.q1)(this.getExtent());this.flatInteriorPoint_=(0,f.J)(this.getOrientedFlatCoordinates(),0,this.ends_,this.stride,t,0),this.flatInteriorPointRevision_=this.getRevision()}return this.flatInteriorPoint_}getInteriorPoint(){return new d.A(this.getFlatInteriorPoint(),"XYM")}getLinearRingCount(){return this.ends_.length}getLinearRing(t){return t<0||this.ends_.length<=t?null:new u(this.flatCoordinates.slice(0===t?0:this.ends_[t-1],this.ends_[t]),this.layout)}getLinearRings(){const t=this.layout,e=this.flatCoordinates,i=this.ends_,n=[];let r=0;for(let s=0,o=i.length;s{"use strict";i.d(e,{Ay:()=>u,p0:()=>l,v7:()=>c});var n=i(7430),r=i(4087),s=i(915),o=i(7622);class a extends n.A{constructor(){super(),this.layout="XY",this.stride=2,this.flatCoordinates}computeExtent(t){return(0,s.Vy)(this.flatCoordinates,0,this.flatCoordinates.length,this.stride,t)}getCoordinates(){return(0,r.b0)()}getFirstCoordinate(){return this.flatCoordinates.slice(0,this.stride)}getFlatCoordinates(){return this.flatCoordinates}getLastCoordinate(){return this.flatCoordinates.slice(this.flatCoordinates.length-this.stride)}getLayout(){return this.layout}getSimplifiedGeometry(t){if(this.simplifiedGeometryRevision!==this.getRevision()&&(this.simplifiedGeometryMaxMinSquaredTolerance=0,this.simplifiedGeometryRevision=this.getRevision()),t<0||0!==this.simplifiedGeometryMaxMinSquaredTolerance&&t<=this.simplifiedGeometryMaxMinSquaredTolerance)return this;const e=this.getSimplifiedGeometryInternal(t);return e.getFlatCoordinates().length{"use strict";function n(t,e,i,n){let r=0;const s=t[i-n],o=t[i-n+1];let a=0,l=0;for(;es,PK:()=>r,eN:()=>n})},4049:(t,e,i)=>{"use strict";i.d(e,{C:()=>r});var n=i(915);function r(t,e,i,r){const s=[];let o=(0,n.S5)();for(let a=0,l=i.length;a{"use strict";i.d(e,{HX:()=>o,MD:()=>s,c:()=>a,n:()=>l,oW:()=>h,te:()=>c});var n=i(1597);function r(t,e,i,r,s,o,a){const l=t[e],h=t[e+1],c=t[i]-l,u=t[i+1]-h;let d;if(0===c&&0===u)d=e;else{const p=((s-l)*c+(o-h)*u)/(c*c+u*u);if(p>1)d=i;else{if(p>0){for(let s=0;ss&&(s=l),o=i,a=r}return s}function o(t,e,i,n,r){for(let o=0,a=i.length;o{"use strict";i.d(e,{Gd:()=>a,a_:()=>s,t7:()=>r,zb:()=>o});var n=i(915);function r(t,e,i,r,o){return!(0,n.sB)(o,(function(n){return!s(t,e,i,r,n[0],n[1])}))}function s(t,e,i,n,r,s){let o=0,a=t[i-n],l=t[i-n+1];for(;es&&(i-a)*(s-l)-(r-a)*(n-l)>0&&o++:n<=s&&(i-a)*(s-l)-(r-a)*(n-l)<0&&o--,a=i,l=n}return 0!==o}function o(t,e,i,n,r,o){if(0===i.length)return!1;if(!s(t,e,i[0],n,r,o))return!1;for(let e=1,a=i.length;e{"use strict";function n(t,e,i,n){for(let n=0,r=i.length;ns,_n:()=>n,d6:()=>o,z2:()=>r})},6361:(t,e,i)=>{"use strict";function n(t,e,i,n,r){r=void 0!==r?r:[];let s=0;for(let o=e;os,cD:()=>r,n2:()=>n})},2616:(t,e,i)=>{"use strict";i.d(e,{J:()=>s,p:()=>o});var n=i(6514),r=i(2845);function s(t,e,i,s,o,a,l){let h,c,u,d,p,f,g;const m=o[a+1],y=[];for(let n=0,r=i.length;nv&&(u=(d+p)/2,(0,r.zb)(t,e,i,s,u,m)&&(_=u,v=n)),d=p}return isNaN(_)&&(_=o[a]),l?(l.push(_,m,v),l):[_,m,v]}function o(t,e,i,n,r){let o=[];for(let a=0,l=i.length;a{"use strict";i.d(e,{L8:()=>a,SH:()=>s,gr:()=>o});var n=i(6514),r=i(1597);function s(t,e,i,s,o,a,l){let h,c;const u=(i-e)/s;if(1===u)h=e;else if(2===u)h=e,c=o;else if(0!==u){let r=t[e],a=t[e+1],l=0;const u=[0];for(let n=e+s;n1?l:2,a=a||new Array(l);for(let e=0;e>1;s{"use strict";i.d(e,{HT:()=>h,Wp:()=>c,fB:()=>a,gp:()=>o,sj:()=>l});var n=i(915),r=i(1374),s=i(2845);function o(t,e,i,s,o){const a=(0,n.R8)((0,n.S5)(),t,e,i,s);return!!(0,n.HY)(o,a)&&(!!(0,n.ms)(o,a)||a[0]>=o[0]&&a[2]<=o[2]||a[1]>=o[1]&&a[3]<=o[3]||(0,r.j)(t,e,i,s,(function(t,e){return(0,n.Mx)(o,t,e)})))}function a(t,e,i,n,r){for(let s=0,a=i.length;s{"use strict";function n(t,e,i,n){let r=t[e],s=t[e+1],o=0;for(let a=e+n;an})},3402:(t,e,i)=>{"use strict";function n(t,e,i,n){for(;e0}function s(t,e,i,n,s){s=void 0!==s&&s;for(let o=0,a=i.length;oh,PA:()=>s,mb:()=>o,ug:()=>a,NK:()=>l})},1374:(t,e,i)=>{"use strict";function n(t,e,i,n,r){let s;for(e+=n;en})},3671:(t,e,i)=>{"use strict";i.d(e,{AL:()=>s,Hg:()=>l,P4:()=>r,n$:()=>o,sx:()=>h});var n=i(1597);function r(t,e,i,r,s,o,a){const l=(i-e)/r;if(l<3){for(;e0;){const i=c.pop(),o=c.pop();let a=0;const l=t[o],d=t[o+1],p=t[i],f=t[i+1];for(let e=o+r;ea&&(u=e,a=s)}a>s&&(h[(u-e)/r]=1,o+r0&&g>p)&&(f<0&&m0&&m>f)?(l=i,h=d):(s[a++]=l,s[a++]=h,c=l,u=h,l=i,h=d)}return s[a++]=l,s[a++]=h,a}function l(t,e,i,n,r,s,o,l){for(let h=0,c=i.length;h{"use strict";function n(t,e,i,n,r,s){s=s||[];let o=0;for(let a=e;an,Tl:()=>o,e$:()=>r,hs:()=>s})},7771:(t,e,i)=>{"use strict";i.d(e,{DT:()=>h,FT:()=>c,Wl:()=>l,_p:()=>r,cr:()=>a,ew:()=>o,j:()=>s});const n="undefined"!=typeof navigator&&void 0!==navigator.userAgent?navigator.userAgent.toLowerCase():"",r=n.includes("firefox"),s=(n.includes("safari")&&!n.includes("chrom")&&(n.includes("version/15.4")||/cpu (os|iphone os) 15_4 like mac os x/.test(n)),n.includes("webkit")&&!n.includes("edge")),o=n.includes("macintosh"),a="undefined"!=typeof devicePixelRatio?devicePixelRatio:1,l="undefined"!=typeof WorkerGlobalScope&&"undefined"!=typeof OffscreenCanvas&&self instanceof WorkerGlobalScope,h="undefined"!=typeof Image&&Image.prototype.decode,c=function(){let t=!1;try{const e=Object.defineProperty({},"passive",{get:function(){t=!0}});window.addEventListener("_",null,e),window.removeEventListener("_",null,e)}catch(t){}return t}()},8620:(t,e,i)=>{"use strict";i.d(e,{A:()=>h});var n=i(4120),r=i(5332),s=i(4087),o=i(588),a=i(1597);class l extends n.A{constructor(t){super(),this.on,this.once,this.un,this.background_=t.background;const e=Object.assign({},t);"object"==typeof t.properties&&(delete e.properties,Object.assign(e,t.properties)),e[r.A.OPACITY]=void 0!==t.opacity?t.opacity:1,(0,o.v)("number"==typeof e[r.A.OPACITY],"Layer opacity must be a number"),e[r.A.VISIBLE]=void 0===t.visible||t.visible,e[r.A.Z_INDEX]=t.zIndex,e[r.A.MAX_RESOLUTION]=void 0!==t.maxResolution?t.maxResolution:1/0,e[r.A.MIN_RESOLUTION]=void 0!==t.minResolution?t.minResolution:0,e[r.A.MIN_ZOOM]=void 0!==t.minZoom?t.minZoom:-1/0,e[r.A.MAX_ZOOM]=void 0!==t.maxZoom?t.maxZoom:1/0,this.className_=void 0!==e.className?e.className:"ol-layer",delete e.className,this.setProperties(e),this.state_=null}getBackground(){return this.background_}getClassName(){return this.className_}getLayerState(t){const e=this.state_||{layer:this,managed:void 0===t||t},i=this.getZIndex();return e.opacity=(0,a.qE)(Math.round(100*this.getOpacity())/100,0,1),e.visible=this.getVisible(),e.extent=this.getExtent(),e.zIndex=void 0!==i||e.managed?i:1/0,e.maxResolution=this.getMaxResolution(),e.minResolution=Math.max(this.getMinResolution(),0),e.minZoom=this.getMinZoom(),e.maxZoom=this.getMaxZoom(),this.state_=e,e}getLayersArray(t){return(0,s.b0)()}getLayerStatesArray(t){return(0,s.b0)()}getExtent(){return this.get(r.A.EXTENT)}getMaxResolution(){return this.get(r.A.MAX_RESOLUTION)}getMinResolution(){return this.get(r.A.MIN_RESOLUTION)}getMinZoom(){return this.get(r.A.MIN_ZOOM)}getMaxZoom(){return this.get(r.A.MAX_ZOOM)}getOpacity(){return this.get(r.A.OPACITY)}getSourceState(){return(0,s.b0)()}getVisible(){return this.get(r.A.VISIBLE)}getZIndex(){return this.get(r.A.Z_INDEX)}setBackground(t){this.background_=t,this.changed()}setExtent(t){this.set(r.A.EXTENT,t)}setMaxResolution(t){this.set(r.A.MAX_RESOLUTION,t)}setMinResolution(t){this.set(r.A.MIN_RESOLUTION,t)}setMaxZoom(t){this.set(r.A.MAX_ZOOM,t)}setMinZoom(t){this.set(r.A.MIN_ZOOM,t)}setOpacity(t){(0,o.v)("number"==typeof t,"Layer opacity must be a number"),this.set(r.A.OPACITY,t)}setVisible(t){this.set(r.A.VISIBLE,t)}setZIndex(t){this.set(r.A.Z_INDEX,t)}disposeInternal(){this.state_&&(this.state_.layer=null,this.state_=null),super.disposeInternal()}}const h=l},7600:(t,e,i)=>{"use strict";i.d(e,{A:()=>_t});var n=i(764),r=i(48),s=i(9276),o=i(7733),a=i(3628),l=i(9700),h=i(6936),c=i(953),u=i(1426),d=i(6514),p=i(3730),f=i(6782);let g=0;const m=1<",GreaterThanOrEqualTo:">=",LessThan:"<",LessThanOrEqualTo:"<=",Multiply:"*",Divide:"/",Add:"+",Subtract:"-",Clamp:"clamp",Mod:"%",Pow:"^",Abs:"abs",Floor:"floor",Ceil:"ceil",Round:"round",Sin:"sin",Cos:"cos",Atan:"atan",Sqrt:"sqrt",Match:"match",Between:"between",Interpolate:"interpolate",Coalesce:"coalesce",Case:"case",In:"in",Number:"number",String:"string",Array:"array",Color:"color",Id:"id",Band:"band",Palette:"palette",ToString:"to-string"},L={[P.Get]:N(O(1,1/0),(function(t,e,i){const n=t.length-1,r=new Array(n);for(let e=0;ee)throw new Error(`expected ${e===1/0?`${t} or more`:`${t} to ${e}`} arguments for ${s}, got ${o}`)}}function D(t,e,i){const n=t.length-1,r=new Array(n);for(let s=0;s{for(let e=0;e{for(let e=0;e{const n=t.args;let r=e.properties[i];for(let t=1,e=n.length;tt.variables[i];default:throw new Error(`Unsupported accessor operator ${t.operator}`)}}(t);case P.Id:return t=>t.featureId;case P.GeometryType:return t=>t.geometryType;case P.Concat:{const i=t.args.map((t=>W(t,e)));return t=>"".concat(...i.map((e=>e(t).toString())))}case P.Resolution:return t=>t.resolution;case P.Any:case P.All:case P.Between:case P.In:case P.Not:return function(t,e){const i=t.operator,n=t.args.length,r=new Array(n);for(let i=0;i{for(let e=0;e{for(let e=0;e{const e=r[0](t),i=r[1](t),n=r[2](t);return e>=i&&e<=n};case P.In:return t=>{const e=r[0](t);for(let i=1;i!r[0](t);default:throw new Error(`Unsupported logical operator ${i}`)}}(t,e);case P.Equal:case P.NotEqual:case P.LessThan:case P.LessThanOrEqualTo:case P.GreaterThan:case P.GreaterThanOrEqualTo:return function(t,e){const i=t.operator,n=W(t.args[0],e),r=W(t.args[1],e);switch(i){case P.Equal:return t=>n(t)===r(t);case P.NotEqual:return t=>n(t)!==r(t);case P.LessThan:return t=>n(t)n(t)<=r(t);case P.GreaterThan:return t=>n(t)>r(t);case P.GreaterThanOrEqualTo:return t=>n(t)>=r(t);default:throw new Error(`Unsupported comparison operator ${i}`)}}(t,e);case P.Multiply:case P.Divide:case P.Add:case P.Subtract:case P.Clamp:case P.Mod:case P.Pow:case P.Abs:case P.Floor:case P.Ceil:case P.Round:case P.Sin:case P.Cos:case P.Atan:case P.Sqrt:return function(t,e){const i=t.operator,n=t.args.length,r=new Array(n);for(let i=0;i{let e=1;for(let i=0;ir[0](t)/r[1](t);case P.Add:return t=>{let e=0;for(let i=0;ir[0](t)-r[1](t);case P.Clamp:return t=>{const e=r[0](t),i=r[1](t);if(en?n:e};case P.Mod:return t=>r[0](t)%r[1](t);case P.Pow:return t=>Math.pow(r[0](t),r[1](t));case P.Abs:return t=>Math.abs(r[0](t));case P.Floor:return t=>Math.floor(r[0](t));case P.Ceil:return t=>Math.ceil(r[0](t));case P.Round:return t=>Math.round(r[0](t));case P.Sin:return t=>Math.sin(r[0](t));case P.Cos:return t=>Math.cos(r[0](t));case P.Atan:return 2===n?t=>Math.atan2(r[0](t),r[1](t)):t=>Math.atan(r[0](t));case P.Sqrt:return t=>Math.sqrt(r[0](t));default:throw new Error(`Unsupported numeric operator ${i}`)}}(t,e);case P.Case:return function(t,e){const i=t.args.length,n=new Array(i);for(let r=0;r{for(let e=0;e{const e=n[0](t);for(let r=1;r{const e=n[0](t),r=n[1](t);let s,o;for(let a=2;a=r)return 2===a?l:h?X(e,r,s,o,i,l):Y(e,r,s,o,i,l);s=i,o=l}return o}}(t,e);case P.ToString:return function(t,e){const i=t.operator,n=t.args.length,r=new Array(n);for(let i=0;i{const i=r[0](e);return t.args[0].type===v?(0,p.dI)(i):i.toString()};throw new Error(`Unsupported convert operator ${i}`)}(t,e);default:throw new Error(`Unsupported operator ${i}`)}}function Y(t,e,i,n,r,s){const o=r-i;if(0===o)return n;const a=e-i;return n+(1===t?a/o:(Math.pow(t,a)-1)/(Math.pow(t,o)-1))*(s-n)}function X(t,e,i,n,r,s){if(0==r-i)return n;const o=(0,p.eE)(n),a=(0,p.eE)(s);let l=a[2]-o[2];l>180?l-=360:l<-180&&(l+=360);const h=[Y(t,e,i,o[0],r,a[0]),Y(t,e,i,o[1],r,a[1]),o[2]+Y(t,e,i,0,r,l),Y(t,e,i,n[3],r,s[3])];return(0,p.S8)((0,p.cD)(h))}var V=i(3530);function K(t){return!0}function U(t){const e=k(),i=function(t,e){const i=t.length,n=new Array(i);for(let r=0;rnull;n=et(t,e+"fill-color",i)}if(!n)return null;const r=new a.A;return function(t){const e=n(t);return"none"===e?null:(r.setColor(e),r)}}function $(t,e,i){const n=J(t,e+"stroke-width",i),r=et(t,e+"stroke-color",i);if(!n&&!r)return null;const s=Q(t,e+"stroke-line-cap",i),o=Q(t,e+"stroke-line-join",i),a=it(t,e+"stroke-line-dash",i),l=J(t,e+"stroke-line-dash-offset",i),h=J(t,e+"stroke-miter-limit",i),u=new c.A;return function(t){if(r){const e=r(t);if("none"===e)return null;u.setColor(e)}if(n&&u.setWidth(n(t)),s){const e=s(t);if("butt"!==e&&"round"!==e&&"square"!==e)throw new Error("Expected butt, round, or square line cap");u.setLineCap(e)}if(o){const e=o(t);if("bevel"!==e&&"round"!==e&&"miter"!==e)throw new Error("Expected bevel, round, or miter line join");u.setLineJoin(e)}return a&&u.setLineDash(a(t)),l&&u.setLineDashOffset(l(t)),h&&u.setMiterLimit(h(t)),u}}function J(t,e,i){if(!(e in t))return;const n=q(t[e],y,i);return function(t){return pt(n(t),e)}}function Q(t,e,i){if(!(e in t))return null;const n=q(t[e],_,i);return function(t){return dt(n(t),e)}}function tt(t,e,i){if(!(e in t))return null;const n=q(t[e],m,i);return function(t){const i=n(t);if("boolean"!=typeof i)throw new Error(`Expected a boolean for ${e}`);return i}}function et(t,e,i){if(!(e in t))return null;const n=q(t[e],v,i);return function(t){return ft(n(t),e)}}function it(t,e,i){if(!(e in t))return null;const n=q(t[e],x,i);return function(t){return ut(n(t),e)}}function nt(t,e,i){if(!(e in t))return null;const n=q(t[e],x,i);return function(t){const i=ut(n(t),e);if(2!==i.length)throw new Error(`Expected two numbers for ${e}`);return i}}function rt(t,e,i){if(!(e in t))return null;const n=q(t[e],x,i);return function(t){return gt(n(t),e)}}function st(t,e,i){if(!(e in t))return null;const n=q(t[e],x|y,i);return function(t){return i=n(t),r=e,"number"==typeof i?i:gt(i,r);var i,r}}function ot(t,e){const i=t[e];if(void 0!==i){if("number"!=typeof i)throw new Error(`Expected a number for ${e}`);return i}}function at(t,e){const i=t[e];if(void 0!==i){if("number"==typeof i)return(0,f.xq)(i);if(!Array.isArray(i))throw new Error(`Expected a number or size array for ${e}`);if(2!==i.length||"number"!=typeof i[0]||"number"!=typeof i[1])throw new Error(`Expected a number or size array for ${e}`);return i}}function lt(t,e){const i=t[e];if(void 0!==i){if("bottom-left"!==i&&"bottom-right"!==i&&"top-left"!==i&&"top-right"!==i)throw new Error(`Expected bottom-left, bottom-right, top-left, or top-right for ${e}`);return i}}function ht(t,e){const i=t[e];if(void 0!==i){if("pixels"!==i&&"fraction"!==i)throw new Error(`Expected pixels or fraction for ${e}`);return i}}function ct(t,e){const i=t[e];if(void 0!==i){if("string"!=typeof i)throw new Error(`Expected a string for ${e}`);if("declutter"!==i&&"obstacle"!==i&&"none"!==i)throw new Error(`Expected declutter, obstacle, or none for ${e}`);return i}}function ut(t,e){if(!Array.isArray(t))throw new Error(`Expected an array for ${e}`);const i=t.length;for(let n=0;n4)throw new Error(`Expected a color with 3 or 4 values for ${e}`);return i}function gt(t,e){const i=ut(t,e);if(2!==i.length)throw new Error(`Expected an array of two numbers for ${e}`);return i}const mt="renderOrder";class yt extends n.A{constructor(t){t=t||{};const e=Object.assign({},t);delete e.style,delete e.renderBuffer,delete e.updateWhileAnimating,delete e.updateWhileInteracting,super(e),this.declutter_=t.declutter?String(t.declutter):void 0,this.renderBuffer_=void 0!==t.renderBuffer?t.renderBuffer:100,this.style_=null,this.styleFunction_=void 0,this.setStyle(t.style),this.updateWhileAnimating_=void 0!==t.updateWhileAnimating&&t.updateWhileAnimating,this.updateWhileInteracting_=void 0!==t.updateWhileInteracting&&t.updateWhileInteracting}getDeclutter(){return this.declutter_}getFeatures(t){return super.getFeatures(t)}getRenderBuffer(){return this.renderBuffer_}getRenderOrder(){return this.get(mt)}getStyle(){return this.style_}getStyleFunction(){return this.styleFunction_}getUpdateWhileAnimating(){return this.updateWhileAnimating_}getUpdateWhileInteracting(){return this.updateWhileInteracting_}renderDeclutter(t,e){const i=this.getDeclutter();i in t.declutter==0&&(t.declutter[i]=new r.A(9)),this.getRenderer().renderDeclutter(t,e)}setRenderOrder(t){this.set(mt,t)}setStyle(t){this.style_=void 0===t?s.d1:t;const e=function(t){if(void 0===t)return s.d1;if(!t)return null;if("function"==typeof t)return t;if(t instanceof s.Ay)return t;if(!Array.isArray(t))return B([t]);if(0===t.length)return[];const e=t.length,i=t[0];if(i instanceof s.Ay){const i=new Array(e);for(let n=0;n{"use strict";i.d(e,{A:()=>y,i:()=>f});var n=i(8620),r=i(71),s=i(2135),o=i(1685),a=i(6837),l=i(8450),h=i(588),c=i(3530),u=i(915),d=i(4087),p=i(9438);class f extends o.Ay{constructor(t,e){super(t),this.layer=e}}const g="layers";class m extends n.A{constructor(t){t=t||{};const e=Object.assign({},t);delete e.layers;let i=t.layers;super(e),this.on,this.once,this.un,this.layersListenerKeys_=[],this.listenerKeys_={},this.addChangeListener(g,this.handleLayersChanged_),i?Array.isArray(i)?i=new r.A(i.slice(),{unique:!0}):(0,h.v)("function"==typeof i.getArray,"Expected `layers` to be an array or a `Collection`"):i=new r.A(void 0,{unique:!0}),this.setLayers(i)}handleLayerChange_(){this.changed()}handleLayersChanged_(){this.layersListenerKeys_.forEach(p.JH),this.layersListenerKeys_.length=0;const t=this.getLayers();this.layersListenerKeys_.push((0,p.KT)(t,s.A.ADD,this.handleLayersAdd_,this),(0,p.KT)(t,s.A.REMOVE,this.handleLayersRemove_,this));for(const t in this.listenerKeys_)this.listenerKeys_[t].forEach(p.JH);(0,c.I)(this.listenerKeys_);const e=t.getArray();for(let t=0,i=e.length;t{"use strict";i.d(e,{A:()=>p,l:()=>d});var n=i(8620),r=i(6837),s=i(5332),o=i(3984),a=i(1765),l=i(588),h=i(915),c=i(9438);class u extends n.A{constructor(t){const e=Object.assign({},t);delete e.source,super(e),this.on,this.once,this.un,this.mapPrecomposeKey_=null,this.mapRenderKey_=null,this.sourceChangeKey_=null,this.renderer_=null,this.sourceReady_=!1,this.rendered=!1,t.render&&(this.render=t.render),t.map&&this.setMap(t.map),this.addChangeListener(s.A.SOURCE,this.handleSourcePropertyChange_);const i=t.source?t.source:null;this.setSource(i)}getLayersArray(t){return(t=t||[]).push(this),t}getLayerStatesArray(t){return(t=t||[]).push(this.getLayerState()),t}getSource(){return this.get(s.A.SOURCE)||null}getRenderSource(){return this.getSource()}getSourceState(){const t=this.getSource();return t?t.getState():"undefined"}handleSourceChange_(){this.changed(),this.sourceReady_||"ready"!==this.getSource().getState()||(this.sourceReady_=!0,this.dispatchEvent("sourceready"))}handleSourcePropertyChange_(){this.sourceChangeKey_&&((0,c.JH)(this.sourceChangeKey_),this.sourceChangeKey_=null),this.sourceReady_=!1;const t=this.getSource();t&&(this.sourceChangeKey_=(0,c.KT)(t,r.A.CHANGE,this.handleSourceChange_,this),"ready"===t.getState()&&(this.sourceReady_=!0,setTimeout((()=>{this.dispatchEvent("sourceready")}),0))),this.changed()}getFeatures(t){return this.renderer_?this.renderer_.getFeatures(t):Promise.resolve([])}getData(t){return this.renderer_&&this.rendered?this.renderer_.getData(t):null}isVisible(t){let e;const i=this.getMapInternal();let n;!t&&i&&(t=i.getView()),e=t instanceof a.Ay?{viewState:t.getState(),extent:t.calculateExtent()}:t,!e.layerStatesArray&&i&&(e.layerStatesArray=i.getLayerGroup().getLayerStatesArray()),n=e.layerStatesArray?e.layerStatesArray.find((t=>t.layer===this)):this.getLayerState();const r=this.getExtent();return d(n,e.viewState)&&(!r||(0,h.HY)(r,e.extent))}getAttributions(t){if(!this.isVisible(t))return[];const e=this.getSource()?.getAttributions();if(!e)return[];let i=e(t instanceof a.Ay?t.getViewStateAndExtent():t);return Array.isArray(i)||(i=[i]),i}render(t,e){const i=this.getRenderer();return i.prepareFrame(t)?(this.rendered=!0,i.renderFrame(t,e)):null}unrender(){this.rendered=!1}getDeclutter(){}renderDeclutter(t,e){}renderDeferred(t){const e=this.getRenderer();e&&e.renderDeferred(t)}setMapInternal(t){t||this.unrender(),this.set(s.A.MAP,t)}getMapInternal(){return this.get(s.A.MAP)}setMap(t){this.mapPrecomposeKey_&&((0,c.JH)(this.mapPrecomposeKey_),this.mapPrecomposeKey_=null),t||this.changed(),this.mapRenderKey_&&((0,c.JH)(this.mapRenderKey_),this.mapRenderKey_=null),t&&(this.mapPrecomposeKey_=(0,c.KT)(t,o.A.PRECOMPOSE,(t=>{const e=t.frameState.layerStatesArray,i=this.getLayerState(!1);(0,l.v)(!e.some((function(t){return t.layer===i.layer})),"A layer can only be added to the map once. Use either `layer.setMap()` or `map.addLayer()`, not both."),e.push(i)})),this.mapRenderKey_=(0,c.KT)(this,r.A.CHANGE,t.render,t),this.changed())}setSource(t){this.set(s.A.SOURCE,t)}getRenderer(){return this.renderer_||(this.renderer_=this.createRenderer()),this.renderer_}hasRenderer(){return!!this.renderer_}createRenderer(){return null}disposeInternal(){this.renderer_&&(this.renderer_.dispose(),delete this.renderer_),this.setSource(null),super.disposeInternal()}}function d(t,e){if(!t.visible)return!1;const i=e.resolution;if(i=t.maxResolution)return!1;const n=e.zoom;return n>t.minZoom&&n<=t.maxZoom}const p=u},5332:(t,e,i)=>{"use strict";i.d(e,{A:()=>n});const n={OPACITY:"opacity",VISIBLE:"visible",EXTENT:"extent",Z_INDEX:"zIndex",MAX_RESOLUTION:"maxResolution",MIN_RESOLUTION:"minResolution",MAX_ZOOM:"maxZoom",MIN_ZOOM:"minZoom",SOURCE:"source",MAP:"map"}},5360:(t,e,i)=>{"use strict";i.d(e,{A:()=>n});const n={PRELOAD:"preload",USE_INTERIM_TILES_ON_ERROR:"useInterimTilesOnError"}},2757:(t,e,i)=>{"use strict";i.d(e,{A:()=>x});var n=i(7600),r=i(136),s=i(1623),o=i(7343),a=i(3984),l=i(2703),h=i(7727),c=i(915),u=i(8711),d=i(3608),p=i(6514),f=i(594),g=i(4087),m=i(6933);class y extends s.A{constructor(t){super(t),this.boundHandleStyleImageChange_=this.handleStyleImageChange_.bind(this),this.animatingOrInteracting_,this.hitDetectionImageData_=null,this.clipped_=!1,this.renderedFeatures_=null,this.renderedRevision_=-1,this.renderedResolution_=NaN,this.renderedExtent_=(0,c.S5)(),this.wrappedRenderedExtent_=(0,c.S5)(),this.renderedRotation_,this.renderedCenter_=null,this.renderedProjection_=null,this.renderedPixelRatio_=1,this.renderedRenderOrder_=null,this.renderedFrameDeclutter_,this.replayGroup_=null,this.replayGroupChanged=!0,this.clipping=!0,this.targetContext_=null,this.opacity_=1}renderWorlds(t,e,i){const n=e.extent,r=e.viewState,s=r.center,a=r.resolution,h=r.projection,u=r.rotation,d=h.getExtent(),p=this.getLayer().getSource(),f=this.getLayer().getDeclutter(),g=e.pixelRatio,m=e.viewHints,y=!(m[l.A.ANIMATING]||m[l.A.INTERACTING]),_=this.context,v=Math.round((0,c.RG)(n)/a*g),x=Math.round((0,c.Oq)(n)/a*g),b=p.getWrapX()&&h.canWrapX(),w=b?(0,c.RG)(d):null,A=b?Math.ceil((n[2]-d[2])/w)+1:1;let E=b?Math.floor((n[0]-d[0])/w):0;do{let n=this.getRenderTransform(s,a,0,g,v,x,E*w);e.declutter&&(n=n.slice(0)),t.execute(_,[_.canvas.width,_.canvas.height],n,u,y,void 0===i?o.y2:i?o.$i:o.x$,i?f&&e.declutter[f]:void 0)}while(++E{if(this.frameState&&!this.hitDetectionImageData_&&!this.animatingOrInteracting_){const t=this.frameState.size.slice(),e=this.renderedCenter_,i=this.renderedResolution_,n=this.renderedRotation_,r=this.renderedProjection_,s=this.wrappedRenderedExtent_,o=this.getLayer(),a=[],l=t[0]*h.tF,u=t[1]*h.tF;a.push(this.getRenderTransform(e,i,n,h.tF,l,u,0).slice());const p=o.getSource(),g=r.getExtent();if(p.getWrapX()&&r.canWrapX()&&!(0,c.ms)(g,s)){let t=s[0];const r=(0,c.RG)(g);let o,d=0;for(;tg[2];)++d,o=r*d,a.push(this.getRenderTransform(e,i,n,h.tF,l,u,o).slice()),t-=r}const m=(0,f.Tf)();this.hitDetectionImageData_=(0,h._7)(t,a,this.renderedFeatures_,o.getStyleFunction(),s,i,n,(0,d.j)(i,this.renderedPixelRatio_),m?r:null)}e((0,h.F8)(t,this.renderedFeatures_,this.hitDetectionImageData_))}))}forEachFeatureAtCoordinate(t,e,i,n,r){if(!this.replayGroup_)return;const s=e.viewState.resolution,o=e.viewState.rotation,a=this.getLayer(),l={},h=function(t,e,i){const s=(0,g.v6)(t),o=l[s];if(o){if(!0!==o&&ic=n.forEachFeatureAtCoordinate(t,s,o,i,h,d&&e.declutter[d]?e.declutter[d].all().map((t=>t.value)):null))),c}handleFontsChanged(){const t=this.getLayer();t.getVisible()&&this.replayGroup_&&t.changed()}handleStyleImageChange_(t){this.renderIfReadyAndVisible()}prepareFrame(t){const e=this.getLayer(),i=e.getSource();if(!i)return!1;const n=t.viewHints[l.A.ANIMATING],s=t.viewHints[l.A.INTERACTING],a=e.getUpdateWhileAnimating(),h=e.getUpdateWhileInteracting();if(this.ready&&!a&&n||!h&&s)return this.animatingOrInteracting_=!0,!0;this.animatingOrInteracting_=!1;const u=t.extent,g=t.viewState,y=g.projection,_=g.resolution,v=t.pixelRatio,x=e.getRevision(),b=e.getRenderBuffer();let w=e.getRenderOrder();void 0===w&&(w=d.Eo);const A=g.center.slice(),E=(0,c.r)(u,b*_),C=E.slice(),S=[E.slice()],T=y.getExtent();if(i.getWrapX()&&y.canWrapX()&&!(0,c.ms)(T,t.extent)){const t=(0,c.RG)(T),e=Math.max((0,c.RG)(E)/2,t);E[0]=T[0]-e,E[2]=T[2]+e,(0,m.Li)(A,y);const i=(0,c.Li)(S[0],y);i[0]T[0]&&i[2]>T[2]&&S.push([i[0]-t,i[1],i[2]-t,i[3]])}if(this.ready&&this.renderedResolution_==_&&this.renderedRevision_==x&&this.renderedRenderOrder_==w&&this.renderedFrameDeclutter_===!!t.declutter&&(0,c.ms)(this.wrappedRenderedExtent_,E))return(0,p.aI)(this.renderedExtent_,C)||(this.hitDetectionImageData_=null,this.renderedExtent_=C),this.renderedCenter_=A,this.replayGroupChanged=!1,!0;this.replayGroup_=null;const R=new r.A((0,d.gY)(_,v),E,_,v),I=(0,f.Tf)();let k;if(I){for(let t=0,e=S.length;t{let n;const r=t.getStyleFunction()||e.getStyleFunction();if(r&&(n=r(t,_)),n){const e=this.renderFeature(t,M,n,R,k,this.getLayer().getDeclutter(),i);P=P&&!e}},F=(0,f.JR)(E,y),O=i.getFeaturesInExtent(F);w&&O.sort(w);for(let t=0,e=O.length;t{"use strict";i.d(e,{A:()=>C});var n=i(7600),r=i(136),s=i(7343),o=i(441),a=i(1078),l=i(2703),h=i(808),c=i(7727),u=i(9703),d=i(6514),p=i(915),f=i(3608),g=i(4087),m=i(6782),y=i(6933);const _={image:["Polygon","Circle","LineString","Image","Text"],hybrid:["Polygon","LineString"],vector:[]},v={hybrid:["Image","Text","Default"],vector:["Polygon","Circle","LineString","Image","Text","Default"]};class x extends o.A{constructor(t,e){super(t,e),this.boundHandleStyleImageChange_=this.handleStyleImageChange_.bind(this),this.renderedLayerRevision_,this.renderedPixelToCoordinateTransform_=null,this.renderedRotation_,this.renderedOpacity_=1,this.tmpTransform_=(0,u.vt)(),this.tileClipContexts_=null}drawTile(t,e,i,n,r,s,o,a){this.updateExecutorGroup_(t,e.pixelRatio,e.viewState.projection),this.tileImageNeedsRender_(t)&&this.renderTileImage_(t,e),super.drawTile(t,e,i,n,r,s,o,a)}getTile(t,e,i,n){const r=this.getOrCreateTile(t,e,i,n);if(!r)return null;const s=n.viewState.resolution,o=n.viewHints;return!(!o[l.A.ANIMATING]&&!o[l.A.INTERACTING])&&r.wantedResolution||(r.wantedResolution=s),r}prepareFrame(t){const e=this.getLayer().getRevision();return this.renderedLayerRevision_!==e&&(this.renderedLayerRevision_=e,this.renderedTiles.length=0),super.prepareFrame(t)}updateExecutorGroup_(t,e,i){const n=this.getLayer(),o=n.getRevision(),l=n.getRenderOrder()||null,h=t.wantedResolution,c=t.getReplayState(n);if(!c.dirty&&c.renderedResolution===h&&c.renderedRevision==o&&c.renderedRenderOrder==l)return;const u=n.getSource(),d=!!n.getDeclutter(),m=u.getTileGrid(),y=u.getTileGridForProjection(i).getTileCoordExtent(t.wrappedTileCoord),_=u.getSourceTiles(e,i,t),v=(0,g.v6)(n);delete t.hitDetectionImageData[v],t.executorGroups[v]=[],c.dirty=!1;for(let i=0,o=_.length;i{const r=_?e.declutter[_].all().map((t=>t.value)):null;for(let e=0,a=n.length;e{const n=this.getLayer(),r=(0,g.v6)(n),s=n.getSource(),o=this.renderedProjection,l=o.getExtent(),h=this.renderedResolution,d=s.getTileGridForProjection(o),f=(0,u.Bb)(this.renderedPixelToCoordinateTransform_,t.slice()),_=d.getTileCoordForCoordAndResolution(f,h);let v;for(let t=0,e=this.renderedTiles.length;t0)return void e([]);const x=d.getTileCoordExtent(v.wrappedTileCoord),b=(0,p.Py)(x),w=[(f[0]-b[0])/h,(b[1]-f[1])/h],A=v.getSourceTiles().reduce((function(t,e){return t.concat(e.getFeatures())}),[]);let E=v.hitDetectionImageData[r];if(!E){const t=(0,m.xq)(d.getTileSize(d.getZForResolution(h,s.zDirection))),e=this.renderedRotation_,i=[this.getRenderTransform(d.getTileCoordCenter(v.wrappedTileCoord),h,0,c.tF,t[0]*c.tF,t[1]*c.tF,0)];E=(0,c._7)(t,i,A,n.getStyleFunction(),d.getTileCoordExtent(v.wrappedTileCoord),v.getReplayState(n).renderedResolution,e),v.hitDetectionImageData[r]=E}e((0,c.F8)(w,A,E))}))}getFeaturesInExtent(t){const e=[],i=this.getTileCache();if(0===i.getCount())return e;const n=this.getLayer().getSource().tileGrid,r=n.getZForResolution(this.renderedResolution);return i.forEach((i=>{if(i.tileCoord[0]!==r||i.getState()!==a.A.LOADED)return;const s=i.getSourceTiles();for(let i=0,r=s.length;i=0;--e)n[e].execute(this.context,[this.context.canvas.width,this.context.canvas.height],this.getTileRenderTransform(i,t),t.viewState.rotation,o,s.$i,r?t.declutter[r]:void 0)}i.globalAlpha=n}renderDeferredInternal(t){const e=this.renderedTiles.reduce(((t,e,i)=>(e.executorGroups[(0,g.v6)(this.getLayer())].forEach((e=>t.push({executorGroup:e,index:i}))),t)),[]),i=e.map((({executorGroup:t})=>t.getDeferredZIndexContexts())),n={};for(let t=0,i=e.length;t{i.forEach(((i,n)=>{i[t]&&(i[t].forEach((t=>{const{executorGroup:i,index:r}=e[n],s=i.getRenderedContext(),o=s.globalAlpha;s.globalAlpha=this.renderedOpacity_;const a=this.tileClipContexts_[r];a&&a.draw(s),t.draw(s),a&&s.restore(),s.globalAlpha=o,t.clear()})),i[t].length=0)}))}))}getTileRenderTransform(t,e){const i=e.pixelRatio,n=e.viewState,r=n.center,s=n.resolution,o=n.rotation,a=e.size,l=Math.round(a[0]*i),h=Math.round(a[1]*i),c=this.getLayer().getSource().getTileGridForProjection(e.viewState.projection),d=t.tileCoord,p=c.getTileCoordExtent(t.wrappedTileCoord),f=c.getTileCoordExtent(d,this.tempExtent)[0]-p[0];return(0,u.lw)((0,u.hs)(this.inversePixelTransform.slice(),1/i,1/i),this.getRenderTransform(r,s,o,i,l,h,f))}postRender(t,e){const i=e.viewHints,n=!(i[l.A.ANIMATING]||i[l.A.INTERACTING]);this.renderedPixelToCoordinateTransform_=e.pixelToCoordinateTransform.slice(),this.renderedRotation_=e.viewState.rotation,this.renderedOpacity_=e.layerStatesArray[e.layerIndex].opacity;const r=this.getLayer(),o=r.getRenderMode(),a=t.globalAlpha;t.globalAlpha=this.renderedOpacity_;const c=r.getDeclutter(),u=c?v[o].filter((t=>!s.$i.includes(t))):v[o],d=e.viewState,f=d.rotation,m=r.getSource(),y=m.getTileGridForProjection(d.projection).getZForResolution(d.resolution,m.zDirection),_=this.renderedTiles,x=[],b=[],w=[];let A=!0;for(let i=_.length-1;i>=0;--i){const s=_[i];A=A&&!s.getReplayState(r).dirty;const o=s.executorGroups[(0,g.v6)(r)].filter((t=>t.hasExecutors(u)));if(0===o.length)continue;const a=this.getTileRenderTransform(s,e),l=s.tileCoord[0];let d=!1;const m=o[0].getClipCoords(a);let v,E=t;if(m){v=new h.A,E=v.getContext();for(let t=0,e=x.length;t{"use strict";function n(t,e){return[[-1/0,-1/0,1/0,1/0]]}function r(t,e){return[t]}i.d(e,{Q7:()=>n,Qk:()=>r}),i(594)},1597:(t,e,i)=>{"use strict";function n(t,e,i){return Math.min(Math.max(t,e),i)}function r(t,e,i,n,r,o){const a=r-i,l=o-n;if(0!==a||0!==l){const s=((t-i)*a+(e-n)*l)/(a*a+l*l);s>1?(i=r,n=o):s>0&&(i+=a*s,n+=l*s)}return s(t,e,i,n)}function s(t,e,i,n){const r=i-t,s=n-e;return r*r+s*s}function o(t){const e=t.length;for(let i=0;ir&&(r=e,n=s)}if(0===r)return null;const s=t[n];t[n]=t[i],t[i]=s;for(let n=i+1;n=0;n--){i[n]=t[n][e]/t[n][n];for(let r=n-1;r>=0;r--)t[r][e]-=t[r][n]*i[n]}return i}function a(t){return t*Math.PI/180}function l(t,e){const i=t%e;return i*e<0?i+e:i}function h(t,e,i){return t+i*(e-t)}function c(t,e){const i=Math.pow(10,e);return Math.round(t*i)/i}function u(t,e){return Math.floor(c(t,e))}function d(t,e){return Math.ceil(c(t,e))}i.d(e,{Cc:()=>h,KU:()=>o,Mg:()=>c,Q1:()=>r,RI:()=>u,eh:()=>a,hG:()=>s,mk:()=>d,qE:()=>n,xP:()=>l})},3530:(t,e,i)=>{"use strict";function n(t){for(const e in t)delete t[e]}function r(t){let e;for(e in t)return!1;return!e}i.d(e,{I:()=>n,p:()=>r})},594:(t,e,i)=>{"use strict";i.d(e,{Ig:()=>g.I,Av:()=>L,RJ:()=>S,tI:()=>O,Rb:()=>F,Ad:()=>Y,SD:()=>V,Jt:()=>k,hO:()=>M,RG:()=>j,FO:()=>D,Tf:()=>q,te:()=>W,JR:()=>X,vN:()=>K,pd:()=>z});var n=i(5286);const r=6378137,s=Math.PI*r,o=[-s,-s,s,s],a=[-180,-85,180,85],l=r*Math.log(Math.tan(Math.PI/2));class h extends n.A{constructor(t){super({code:t,units:"m",extent:o,global:!0,worldExtent:a,getPointResolution:function(t,e){return t/Math.cosh(e[1]/r)}})}}const c=[new h("EPSG:3857"),new h("EPSG:102100"),new h("EPSG:102113"),new h("EPSG:900913"),new h("http://www.opengis.net/def/crs/EPSG/0/3857"),new h("http://www.opengis.net/gml/srs/epsg.xml#3857")];const u=[-180,-90,180,90],d=6378137*Math.PI/180;class p extends n.A{constructor(t,e){super({code:t,units:"degrees",extent:u,axisOrientation:e,global:!0,metersPerUnit:d,worldExtent:u})}}const f=[new p("CRS:84"),new p("EPSG:4326","neu"),new p("urn:ogc:def:crs:OGC:1.3:CRS84"),new p("urn:ogc:def:crs:OGC:2:84"),new p("http://www.opengis.net/def/crs/OGC/1.3/CRS84"),new p("http://www.opengis.net/gml/srs/epsg.xml#4326","neu"),new p("http://www.opengis.net/def/crs/EPSG/0/4326","neu")];var g=i(8100);let m={},y={};function _(t,e,i){const n=t.getCode(),r=e.getCode();n in y||(y[n]={}),y[n][r]=i}var v=i(915),x=i(6933),b=i(1597);const w=6371008.8;function A(t,e,i){i=i||w;const n=(0,b.eh)(t[1]),r=(0,b.eh)(e[1]),s=(r-n)/2,o=(0,b.eh)(e[0]-t[0])/2,a=Math.sin(s)*Math.sin(s)+Math.sin(o)*Math.sin(o)*Math.cos(n)*Math.cos(r);return 2*i*Math.atan2(Math.sqrt(a),Math.sqrt(1-a))}var E=i(4422);let C=!0;function S(t){C=!(void 0===t||t)}function T(t,e){if(void 0!==e)for(let i=0,n=t.length;i=-180&&t[0]<=180&&t[1]>=-90&&t[1]<=90&&(C=!1,(0,E.R8)("Call useGeographic() from ol/proj once to work with [longitude, latitude] coordinates.")),t)}function X(t,e){return G?N(t,e,G):t}function V(t,e){return G?N(t,G,e):t}function K(t,e){if(!G)return t;const i=k(e).getMetersPerUnit(),n=G.getMetersPerUnit();return i&&n?t*i/n:t}var U,B,Z;P(c),P(f),U=c,B=function(t,e,i){const n=t.length;i=i>1?i:2,void 0===e&&(e=i>2?t.slice():new Array(n));for(let o=0;ol?i=l:i<-l&&(i=-l),e[o+1]=i}return e},Z=function(t,e,i){const n=t.length;i=i>1?i:2,void 0===e&&(e=i>2?t.slice():new Array(n));for(let o=0;o{"use strict";i.d(e,{A:()=>r});var n=i(8100);const r=class{constructor(t){this.code_=t.code,this.units_=t.units,this.extent_=void 0!==t.extent?t.extent:null,this.worldExtent_=void 0!==t.worldExtent?t.worldExtent:null,this.axisOrientation_=void 0!==t.axisOrientation?t.axisOrientation:"enu",this.global_=void 0!==t.global&&t.global,this.canWrapX_=!(!this.global_||!this.extent_),this.getPointResolutionFunc_=t.getPointResolution,this.defaultTileGrid_=null,this.metersPerUnit_=t.metersPerUnit}canWrapX(){return this.canWrapX_}getCode(){return this.code_}getExtent(){return this.extent_}getUnits(){return this.units_}getMetersPerUnit(){return this.metersPerUnit_||n.I[this.units_]}getWorldExtent(){return this.worldExtent_}getAxisOrientation(){return this.axisOrientation_}isGlobal(){return this.global_}setGlobal(t){this.global_=t,this.canWrapX_=!(!t||!this.extent_)}getDefaultTileGrid(){return this.defaultTileGrid_}setDefaultTileGrid(t){this.defaultTileGrid_=t}setExtent(t){this.extent_=t,this.canWrapX_=!(!this.global_||!t)}setWorldExtent(t){this.worldExtent_=t}setGetPointResolution(t){this.getPointResolutionFunc_=t}getPointResolutionFunc(){return this.getPointResolutionFunc_}}},8100:(t,e,i)=>{"use strict";i.d(e,{I:()=>n});const n={radians:6370997/(2*Math.PI),degrees:2*Math.PI*6370997/360,ft:.3048,m:1,"us-ft":1200/3937}},9960:(t,e,i)=>{"use strict";i.d(e,{A:()=>s});var n=i(1685);class r extends n.Ay{constructor(t,e,i,n){super(t),this.inversePixelTransform=e,this.frameState=i,this.context=n}}const s=r},3984:(t,e,i)=>{"use strict";i.d(e,{A:()=>n});const n={PRERENDER:"prerender",POSTRENDER:"postrender",PRECOMPOSE:"precompose",POSTCOMPOSE:"postcompose",RENDERCOMPLETE:"rendercomplete"}},4778:(t,e,i)=>{"use strict";i.d(e,{Ay:()=>m});var n=i(9703),r=i(915),s=i(3671),o=i(6514),a=i(2616),l=i(594),h=i(3402),c=i(9969),u=i(4049),d=i(4238),p=i(7622);const f=(0,n.vt)();class g{constructor(t,e,i,n,r,s){this.styleFunction,this.extent_,this.id_=s,this.type_=t,this.flatCoordinates_=e,this.flatInteriorPoints_=null,this.flatMidpoints_=null,this.ends_=i||null,this.properties_=r,this.squaredTolerance_,this.stride_=n,this.simplifiedGeometry_}get(t){return this.properties_[t]}getExtent(){return this.extent_||(this.extent_="Point"===this.type_?(0,r.dP)(this.flatCoordinates_):(0,r.Vy)(this.flatCoordinates_,0,this.flatCoordinates_.length,2)),this.extent_}getFlatInteriorPoint(){if(!this.flatInteriorPoints_){const t=(0,r.q1)(this.getExtent());this.flatInteriorPoints_=(0,a.J)(this.flatCoordinates_,0,this.ends_,2,t,0)}return this.flatInteriorPoints_}getFlatInteriorPoints(){if(!this.flatInteriorPoints_){const t=(0,h.yJ)(this.flatCoordinates_,this.ends_),e=(0,u.C)(this.flatCoordinates_,0,t,2);this.flatInteriorPoints_=(0,a.p)(this.flatCoordinates_,0,t,2,e)}return this.flatInteriorPoints_}getFlatMidpoint(){return this.flatMidpoints_||(this.flatMidpoints_=(0,c.SH)(this.flatCoordinates_,0,this.flatCoordinates_.length,2,.5)),this.flatMidpoints_}getFlatMidpoints(){if(!this.flatMidpoints_){this.flatMidpoints_=[];const t=this.flatCoordinates_;let e=0;const i=this.ends_;for(let n=0,r=i.length;n{if(t===this.squaredTolerance_)return this.simplifiedGeometry_;this.simplifiedGeometry_=this.clone(),e&&this.simplifiedGeometry_.applyTransform(e);const i=this.simplifiedGeometry_.getFlatCoordinates();let n;switch(this.type_){case"LineString":i.length=(0,s.P4)(i,0,this.simplifiedGeometry_.flatCoordinates_.length,this.simplifiedGeometry_.stride_,t,i,0),n=[i.length];break;case"MultiLineString":n=[],i.length=(0,s.AL)(i,0,this.simplifiedGeometry_.ends_,this.simplifiedGeometry_.stride_,t,i,0,n);break;case"Polygon":n=[],i.length=(0,s.Hg)(i,0,this.simplifiedGeometry_.ends_,this.simplifiedGeometry_.stride_,Math.sqrt(t),i,0,n)}return n&&(this.simplifiedGeometry_=new g(this.type_,i,n,2,this.properties_,this.id_)),this.squaredTolerance_=t,this.simplifiedGeometry_})),this}}g.prototype.getFlatCoordinates=g.prototype.getOrientedFlatCoordinates;const m=g},2826:(t,e,i)=>{"use strict";i.d(e,{A:()=>n});const n=class{drawCustom(t,e,i,n,r){}drawGeometry(t){}setStyle(t){}drawCircle(t,e,i){}drawFeature(t,e,i){}drawGeometryCollection(t,e,i){}drawLineString(t,e,i){}drawMultiLineString(t,e,i){}drawMultiPoint(t,e,i){}drawMultiPolygon(t,e,i){}drawPoint(t,e,i){}drawPolygon(t,e,i){}drawText(t,e,i){}setFillStrokeStyle(t,e){}setImageStyle(t,e){}setTextStyle(t,e){}}},8774:(t,e,i)=>{"use strict";i.d(e,{Jw:()=>k,M8:()=>y,MY:()=>m,NT:()=>g,Oq:()=>u,TA:()=>R,Tq:()=>_,ZV:()=>l,_K:()=>p,_m:()=>c,aq:()=>v,eL:()=>f,fZ:()=>E,jT:()=>I,qY:()=>h,vk:()=>d,yY:()=>x});var n=i(4120),r=i(7771),s=i(3530),o=i(8711),a=i(5176);const l="10px sans-serif",h="#000",c="round",u=[],d=0,p="round",f=10,g="#000",m="center",y="middle",_=[0,0,0,0],v=1,x=new n.A;let b,w=null;const A={},E=function(){const t="32px ",e=["monospace","serif"],i=e.length,n="wmytzilWMYTZIL@#/&?$%10";let r,o;function l(r,s,a){let l=!0;for(let h=0;hMath.max(e,T(t,i))),0);return i[e]=n,n}function I(t,e){const i=[],n=[],r=[];let s=0,o=0,a=0,l=0;for(let h=0,c=e.length;h<=c;h+=2){const u=e[h];if("\n"===u||h===c){s=Math.max(s,o),r.push(o),o=0,a+=l,l=0;continue}const d=e[h+1]||t.font,p=T(d,u);i.push(p),o+=p;const f=C(d);n.push(f),l=Math.max(l,f)}return{width:s,height:a,widths:i,heights:n,lineWidths:r}}function k(t,e,i,n,r,s,o,a,l,h,c){t.save(),1!==i&&(void 0===t.globalAlpha?t.globalAlpha=t=>t.globalAlpha*=i:t.globalAlpha*=i),e&&t.transform.apply(t,e),n.contextInstructions?(t.translate(l,h),t.scale(c[0],c[1]),function(t,e){const i=t.contextInstructions;for(let t=0,n=i.length;t{"use strict";i.d(e,{A:()=>d});var n=i(6429),r=i(1580),s=i(2826),o=i(7295),a=i(915),l=i(8774),h=i(6514),c=i(6361);class u extends s.A{constructor(t,e,i,n){super(),this.tolerance=t,this.maxExtent=e,this.pixelRatio=n,this.maxLineWidth=0,this.resolution=i,this.beginGeometryInstruction1_=null,this.beginGeometryInstruction2_=null,this.bufferedMaxExtent_=null,this.instructions=[],this.coordinates=[],this.tmpCoordinate_=[],this.hitDetectionInstructions=[],this.state={}}applyPixelRatio(t){const e=this.pixelRatio;return 1==e?t:t.map((function(t){return t*e}))}appendFlatPointCoordinates(t,e){const i=this.getBufferedMaxExtent(),n=this.tmpCoordinate_,r=this.coordinates;let s=r.length;for(let o=0,l=t.length;ol&&(this.instructions.push([n.Ay.CUSTOM,l,u,t,i,c.n2,s]),this.hitDetectionInstructions.push([n.Ay.CUSTOM,l,u,t,r||i,c.n2,s]));break;case"Point":h=t.getFlatCoordinates(),this.coordinates.push(h[0],h[1]),u=this.coordinates.length,this.instructions.push([n.Ay.CUSTOM,l,u,t,i,void 0,s]),this.hitDetectionInstructions.push([n.Ay.CUSTOM,l,u,t,r||i,void 0,s])}this.endGeometry(e)}beginGeometry(t,e,i){this.beginGeometryInstruction1_=[n.Ay.BEGIN_GEOMETRY,e,0,t,i],this.instructions.push(this.beginGeometryInstruction1_),this.beginGeometryInstruction2_=[n.Ay.BEGIN_GEOMETRY,e,0,t,i],this.hitDetectionInstructions.push(this.beginGeometryInstruction2_)}finish(){return{instructions:this.instructions,hitDetectionInstructions:this.hitDetectionInstructions,coordinates:this.coordinates}}reverseHitDetectionInstructions(){const t=this.hitDetectionInstructions;let e;t.reverse();const i=t.length;let r,s,o=-1;for(e=0;ethis.maxLineWidth&&(this.maxLineWidth=i.lineWidth,this.bufferedMaxExtent_=null)}else i.strokeStyle=void 0,i.lineCap=void 0,i.lineDash=null,i.lineDashOffset=void 0,i.lineJoin=void 0,i.lineWidth=void 0,i.miterLimit=void 0}createFill(t){const e=t.fillStyle,i=[n.Ay.SET_FILL_STYLE,e];return"string"!=typeof e&&i.push(t.fillPatternScale),i}applyStroke(t){this.instructions.push(this.createStroke(t))}createStroke(t){return[n.Ay.SET_STROKE_STYLE,t.strokeStyle,t.lineWidth*this.pixelRatio,t.lineCap,t.lineJoin,t.miterLimit,this.applyPixelRatio(t.lineDash),t.lineDashOffset*this.pixelRatio]}updateFillStyle(t,e){const i=t.fillStyle;"string"==typeof i&&t.currentFillStyle==i||(void 0!==i&&this.instructions.push(e.call(this,t)),t.currentFillStyle=i)}updateStrokeStyle(t,e){const i=t.strokeStyle,n=t.lineCap,r=t.lineDash,s=t.lineDashOffset,o=t.lineJoin,a=t.lineWidth,l=t.miterLimit;(t.currentStrokeStyle!=i||t.currentLineCap!=n||r!=t.currentLineDash&&!(0,h.aI)(t.currentLineDash,r)||t.currentLineDashOffset!=s||t.currentLineJoin!=o||t.currentLineWidth!=a||t.currentMiterLimit!=l)&&(void 0!==i&&e.call(this,t),t.currentStrokeStyle=i,t.currentLineCap=n,t.currentLineDash=r,t.currentLineDashOffset=s,t.currentLineJoin=o,t.currentLineWidth=a,t.currentMiterLimit=l)}endGeometry(t){this.beginGeometryInstruction1_[2]=this.instructions.length,this.beginGeometryInstruction1_=null,this.beginGeometryInstruction2_[2]=this.hitDetectionInstructions.length,this.beginGeometryInstruction2_=null;const e=[n.Ay.END_GEOMETRY,t];this.instructions.push(e),this.hitDetectionInstructions.push(e)}getBufferedMaxExtent(){if(!this.bufferedMaxExtent_&&(this.bufferedMaxExtent_=(0,a.o8)(this.maxExtent),this.maxLineWidth>0)){const t=this.resolution*(this.maxLineWidth+1)/2;(0,a.r)(this.bufferedMaxExtent_,t,this.bufferedMaxExtent_)}return this.bufferedMaxExtent_}}const d=u},136:(t,e,i)=>{"use strict";i.d(e,{A:()=>m});var n=i(8130),r=i(6429),s=i(915);class o extends n.A{constructor(t,e,i,n){super(t,e,i,n),this.hitDetectionImage_=null,this.image_=null,this.imagePixelRatio_=void 0,this.anchorX_=void 0,this.anchorY_=void 0,this.height_=void 0,this.opacity_=void 0,this.originX_=void 0,this.originY_=void 0,this.rotateWithView_=void 0,this.rotation_=void 0,this.scale_=void 0,this.width_=void 0,this.declutterMode_=void 0,this.declutterImageWithText_=void 0}drawPoint(t,e,i){if(!this.image_||this.maxExtent&&!(0,s.Ym)(this.maxExtent,t.getFlatCoordinates()))return;this.beginGeometry(t,e,i);const n=t.getFlatCoordinates(),o=t.getStride(),a=this.coordinates.length,l=this.appendFlatPointCoordinates(n,o);this.instructions.push([r.Ay.DRAW_IMAGE,a,l,this.image_,this.anchorX_*this.imagePixelRatio_,this.anchorY_*this.imagePixelRatio_,Math.ceil(this.height_*this.imagePixelRatio_),this.opacity_,this.originX_*this.imagePixelRatio_,this.originY_*this.imagePixelRatio_,this.rotateWithView_,this.rotation_,[this.scale_[0]*this.pixelRatio/this.imagePixelRatio_,this.scale_[1]*this.pixelRatio/this.imagePixelRatio_],Math.ceil(this.width_*this.imagePixelRatio_),this.declutterMode_,this.declutterImageWithText_]),this.hitDetectionInstructions.push([r.Ay.DRAW_IMAGE,a,l,this.hitDetectionImage_,this.anchorX_,this.anchorY_,this.height_,1,this.originX_,this.originY_,this.rotateWithView_,this.rotation_,this.scale_,this.width_,this.declutterMode_,this.declutterImageWithText_]),this.endGeometry(e)}drawMultiPoint(t,e,i){if(!this.image_)return;this.beginGeometry(t,e,i);const n=t.getFlatCoordinates(),o=[];for(let e=0,i=n.length;e{"use strict";i.d(e,{y2:()=>S,$i:()=>T,x$:()=>R,Ay:()=>k});var n=i(6429),r=i(808),s=i(3624),o=i(9703),a=i(915),l=i(8774),h=i(1597),c=i(7622);function u(t,e,i,n,r,s,o,a,l,u,d,p){let f=t[e],g=t[e+1],m=0,y=0,_=0,v=0;function x(){m=f,y=g,f=t[e+=n],g=t[e+1],v+=_,_=Math.sqrt((f-m)*(f-m)+(g-y)*(g-y))}do{x()}while(et[2]}else I=w>T;const k=Math.PI,M=[],P=E+n===e;let L;if(_=0,v=C,f=t[e=E],g=t[e+1],P){x(),L=Math.atan2(g-y,f-m),I&&(L+=L>0?-k:k);const t=(T+w)/2,e=(R+A)/2;return M[0]=[t,e,(S-s)/2,L,r],M}for(let t=0,c=(r=r.replace(/\n/g," ")).length;t0?-k:k),void 0!==L){let t=p-L;if(t+=t>k?-2*k:t<-k?2*k:0,Math.abs(t)>o)return null}L=p;const w=t;let A=0;for(;t0&&t.push("\n",""),t.push(e,""),t}const A=class{constructor(t,e,i,n,s){this.overlaps=i,this.pixelRatio=e,this.resolution=t,this.alignAndScaleFill_,this.instructions=n.instructions,this.coordinates=n.coordinates,this.coordinateCache_={},this.renderedTransform_=(0,o.vt)(),this.hitDetectionInstructions=n.hitDetectionInstructions,this.pixelCoordinates_=null,this.viewRotation_=0,this.fillStates=n.fillStates||{},this.strokeStates=n.strokeStates||{},this.textStates=n.textStates||{},this.widths_={},this.labels_={},this.zIndexContext_=s?new r.A:null}getZIndexContext(){return this.zIndexContext_}createLabel(t,e,i,n){const r=t+e+i+n;if(this.labels_[r])return this.labels_[r];const o=n?this.strokeStates[n]:null,a=i?this.fillStates[i]:null,h=this.textStates[e],c=this.pixelRatio,u=[h.scale[0]*c,h.scale[1]*c],d=h.justify?s.E[h.justify]:b(Array.isArray(t)?t[0]:t,h.textAlign||l.MY),p=n&&o.lineWidth?o.lineWidth:0,f=Array.isArray(t)?t:String(t).split("\n").reduce(w,[]),{width:g,height:m,widths:y,heights:_,lineWidths:v}=(0,l.jT)(h,f),x=g+p,A=[],E=(x+2)*u[0],C=(m+p)*u[1],S={width:E<0?Math.floor(E):Math.ceil(E),height:C<0?Math.floor(C):Math.ceil(C),contextInstructions:A};1==u[0]&&1==u[1]||A.push("scale",u),n&&(A.push("strokeStyle",o.strokeStyle),A.push("lineWidth",p),A.push("lineCap",o.lineCap),A.push("lineJoin",o.lineJoin),A.push("miterLimit",o.miterLimit),A.push("setLineDash",[o.lineDash]),A.push("lineDashOffset",o.lineDashOffset)),i&&A.push("fillStyle",a.fillStyle),A.push("textBaseline","middle"),A.push("textAlign","center");const T=.5-d;let R=d*x+T*p;const I=[],k=[];let M,P=0,L=0,F=0,O=0;for(let t=0,e=f.length;tt?t-c:r,S=s+u>e?e-u:s,T=x[3]+C*p[0]+x[1],R=x[0]+S*p[1]+x[2],I=A-x[3],k=E-x[0];let M;return(b||0!==d)&&(g[0]=I,_[0]=I,g[1]=k,m[1]=k,m[0]=I+T,y[0]=m[0],y[1]=k+R,_[1]=y[1]),0!==d?(M=(0,o.Zz)((0,o.vt)(),i,n,1,1,d,-i,-n),(0,o.Bb)(M,g),(0,o.Bb)(M,m),(0,o.Bb)(M,y),(0,o.Bb)(M,_),(0,a.N)(Math.min(g[0],m[0],y[0],_[0]),Math.min(g[1],m[1],y[1],_[1]),Math.max(g[0],m[0],y[0],_[0]),Math.max(g[1],m[1],y[1],_[1]),f)):(0,a.N)(Math.min(I,I+T),Math.min(k,k+R),Math.max(I,I+T),Math.max(k,k+R),f),v&&(A=Math.round(A),E=Math.round(E)),{drawImageX:A,drawImageY:E,drawImageW:C,drawImageH:S,originX:c,originY:u,declutterBox:{minX:f[0],minY:f[1],maxX:f[2],maxY:f[3],value:w},canvasTransform:M,scale:p}}replayImageOrLabel_(t,e,i,n,r,s,o){const a=!(!s&&!o),h=n.declutterBox,c=o?o[2]*n.scale[0]/2:0;return h.minX-c<=e[0]&&h.maxX+c>=0&&h.minY-c<=e[1]&&h.maxY+c>=0&&(a&&this.replayTextBackground_(t,g,m,y,_,s,o),(0,l.Jw)(t,n.canvasTransform,r,i,n.originX,n.originY,n.drawImageW,n.drawImageH,n.drawImageX,n.drawImageY,n.scale)),!0}fill_(t){const e=this.alignAndScaleFill_;if(e){const i=(0,o.Bb)(this.renderedTransform_,[0,0]),n=512*this.pixelRatio;t.save(),t.translate(i[0]%n,i[1]%n),1!==e&&t.scale(e,e),t.rotate(this.viewRotation_)}t.fill(),e&&t.restore()}setStrokeStyle_(t,e){t.strokeStyle=e[1],t.lineWidth=e[2],t.lineCap=e[3],t.lineJoin=e[4],t.miterLimit=e[5],t.lineDashOffset=e[7],t.setLineDash(e[6])}drawLabelWithPointPlacement_(t,e,i,n){const r=this.textStates[e],o=this.createLabel(t,e,n,i),a=this.strokeStates[i],h=this.pixelRatio,c=b(Array.isArray(t)?t[0]:t,r.textAlign||l.MY),u=s.E[r.textBaseline||l.M8],d=a&&a.lineWidth?a.lineWidth:0;return{label:o,anchorX:c*(o.width/h-2*r.scale[0])+2*(.5-c)*d,anchorY:u*o.height/h+2*(.5-u)*d}}execute_(t,e,i,r,s,h,f,g){const m=this.zIndexContext_;let y;this.pixelCoordinates_&&(0,d.aI)(i,this.renderedTransform_)?y=this.pixelCoordinates_:(this.pixelCoordinates_||(this.pixelCoordinates_=[]),y=(0,c.Rc)(this.coordinates,0,this.coordinates.length,2,i,this.pixelCoordinates_),(0,o.k3)(this.renderedTransform_,i));let _=0;const x=r.length;let w,A,E,C,S,T,R,I,k,M,P,L,F,O=0,D=0,j=0,z=null,N=null;const G=this.coordinateCache_,q=this.viewRotation_,W=Math.round(1e12*Math.atan2(-i[1],i[0]))/1e12,Y={context:t,pixelRatio:this.pixelRatio,resolution:this.resolution,rotation:q},X=this.instructions!=r||this.overlaps?0:200;let V,K,U,B;for(;_X&&(this.fill_(t),D=0),j>X&&(t.stroke(),j=0),D||j||(t.beginPath(),S=NaN,T=NaN),++_;break;case n.Ay.CIRCLE:O=i[1];const r=y[O],o=y[O+1],c=y[O+2]-r,d=y[O+3]-o,x=Math.sqrt(c*c+d*d);t.moveTo(r+x,o),t.arc(r,o,x,0,2*Math.PI,!0),++_;break;case n.Ay.CLOSE_PATH:t.closePath(),++_;break;case n.Ay.CUSTOM:O=i[1],w=i[2];const Z=i[3],H=i[4],$=i[5];Y.geometry=Z,Y.feature=V,_ in G||(G[_]=[]);const J=G[_];$?$(y,O,w,2,J):(J[0]=y[O],J[1]=y[O+1],J.length=2),m&&(m.zIndex=i[6]),H(J,Y),++_;break;case n.Ay.DRAW_IMAGE:O=i[1],w=i[2],k=i[3],A=i[4],E=i[5];let Q=i[6];const tt=i[7],et=i[8],it=i[9],nt=i[10];let rt=i[11];const st=i[12];let ot=i[13];C=i[14]||"declutter";const at=i[15];if(!k&&i.length>=20){M=i[19],P=i[20],L=i[21],F=i[22];const t=this.drawLabelWithPointPlacement_(M,P,L,F);k=t.label,i[3]=k;const e=i[23];A=(t.anchorX-e)*this.pixelRatio,i[4]=A;const n=i[24];E=(t.anchorY-n)*this.pixelRatio,i[5]=E,Q=k.height,i[6]=Q,ot=k.width,i[13]=ot}let lt,ht,ct,ut;i.length>25&&(lt=i[25]),i.length>17?(ht=i[16],ct=i[17],ut=i[18]):(ht=l.Tq,ct=!1,ut=!1),nt&&W?rt+=q:nt||W||(rt-=q);let dt=0;for(;O!T.includes(t))),I={},k=class{constructor(t,e,i,n,r,s,a){this.maxExtent_=t,this.overlaps_=n,this.pixelRatio_=i,this.resolution_=e,this.renderBuffer_=s,this.executorsByZIndex_={},this.hitDetectionContext_=null,this.hitDetectionTransform_=(0,o.vt)(),this.renderedContext_=null,this.deferredZIndexContexts_={},this.createExecutors_(r,a)}clip(t,e){const i=this.getClipCoords(e);t.beginPath(),t.moveTo(i[0],i[1]),t.lineTo(i[2],i[3]),t.lineTo(i[4],i[5]),t.lineTo(i[6],i[7]),t.clip()}createExecutors_(t,e){for(const i in t){let n=this.executorsByZIndex_[i];void 0===n&&(n={},this.executorsByZIndex_[i]=n);const r=t[i];for(const t in r){const i=r[t];n[t]=new A(this.resolution_,this.pixelRatio_,this.overlaps_,i,e)}}}hasExecutors(t){for(const e in this.executorsByZIndex_){const i=this.executorsByZIndex_[e];for(let e=0,n=t.length;ei)break;let a=n[o];a||(a=[],n[o]=a),a.push(4*((t+r)*e+(t+s))+3),r>0&&a.push(4*((t-r)*e+(t+s))+3),s>0&&(a.push(4*((t+r)*e+(t-s))+3),r>0&&a.push(4*((t-r)*e+(t-s))+3))}const r=[];for(let t=0,e=n.length;t0){if(!s||"none"===i||"Image"!==g&&"Text"!==g||s.includes(t)){const i=(f[a]-3)/4,s=n-i%l,o=n-(i/l|0),h=r(t,e,s*s+o*o);if(h)return h}u.clearRect(0,0,l,l);break}}const y=Object.keys(this.executorsByZIndex_).map(Number);let _,v,x,b,w;for(y.sort(d.V_),_=y.length-1;_>=0;--_){const t=y[_].toString();for(x=this.executorsByZIndex_[t],v=S.length-1;v>=0;--v)if(g=S[v],b=x[g],void 0!==b&&(w=b.executeHitDetection(u,h,i,m,p),w))return w}}getClipCoords(t){const e=this.maxExtent_;if(!e)return null;const i=e[0],n=e[1],r=e[2],s=e[3],o=[i,n,i,s,r,s,r,n];return(0,c.Rc)(o,0,8,2,t,o),o}isEmpty(){return(0,C.p)(this.executorsByZIndex_)}execute(t,e,i,n,r,s,o){const a=Object.keys(this.executorsByZIndex_).map(Number);a.sort(d.V_),s=s||S;const l=S.length;let h,c,u,p,f;for(o&&a.reverse(),h=0,c=a.length;hd.execute(t,e,i,n,r,o))):d.execute(p,e,i,n,r,o),f&&p.restore(),s){s.offset();const t=a[h]*l+u;this.deferredZIndexContexts_[t]||(this.deferredZIndexContexts_[t]=[]),this.deferredZIndexContexts_[t].push(s)}}}}this.renderedContext_=t}getDeferredZIndexContexts(){return this.deferredZIndexContexts_}getRenderedContext(){return this.renderedContext_}renderDeferred(){const t=this.deferredZIndexContexts_,e=Object.keys(t).map(Number).sort(d.V_);for(let i=0,n=e.length;i{t.draw(this.renderedContext_),t.clear()})),t[e[i]].length=0}}},6429:(t,e,i)=>{"use strict";i.d(e,{Ay:()=>l,I5:()=>r,VD:()=>s,kx:()=>a,th:()=>o});const n={BEGIN_GEOMETRY:0,BEGIN_PATH:1,CIRCLE:2,CLOSE_PATH:3,CUSTOM:4,DRAW_CHARS:5,DRAW_IMAGE:6,END_GEOMETRY:7,FILL:8,MOVE_TO_LINE_TO:9,SET_FILL_STYLE:10,SET_STROKE_STYLE:11,STROKE:12},r=[n.FILL],s=[n.STROKE],o=[n.BEGIN_PATH],a=[n.CLOSE_PATH],l=n},3624:(t,e,i)=>{"use strict";i.d(e,{E:()=>d,A:()=>f});var n=i(8130),r=i(6429),s=i(7295),o=i(8774),a=i(4087),l=i(915),h=i(1597);function c(t,e,i,n,r){const s=[];let o=i,a=0,l=e.slice(i,2);for(;a=t){const e=(t-a+d)/d,p=(0,h.Cc)(i,c,e),f=(0,h.Cc)(n,u,e);l.push(p,f),s.push(l),l=[p,f],a==t&&(o+=r),a=0}else if(a0&&s.push(l),s}function u(t,e,i,n,r){let s,o,a,l,h,c,u,d,p,f,g=i,m=i,y=0,_=0,v=i;for(o=i;ot&&(_>y&&(y=_,g=v,m=o),_=0,v=o-r)),a=l,u=p,d=f),h=i,c=n}return _+=l,_>y?[v,o]:[g,m]}const d={left:0,center:.5,right:1,top:0,middle:.5,hanging:.2,alphabetic:.8,ideographic:.8,bottom:1};class p extends n.A{constructor(t,e,i,n){super(t,e,i,n),this.labels_=null,this.text_="",this.textOffsetX_=0,this.textOffsetY_=0,this.textRotateWithView_=void 0,this.textRotation_=0,this.textFillState_=null,this.fillStates={},this.fillStates[o.qY]={fillStyle:o.qY},this.textStrokeState_=null,this.strokeStates={},this.textState_={},this.textStates={},this.textKey_="",this.fillKey_="",this.strokeKey_="",this.declutterMode_=void 0,this.declutterImageWithText_=void 0}finish(){const t=super.finish();return t.textStates=this.textStates,t.fillStates=this.fillStates,t.strokeStates=this.strokeStates,t}drawText(t,e,i){const n=this.textFillState_,s=this.textStrokeState_,a=this.textState_;if(""===this.text_||!a||!n&&!s)return;const h=this.coordinates;let d=h.length;const p=t.getType();let f=null,g=t.getStride();if("line"!==a.placement||"LineString"!=p&&"MultiLineString"!=p&&"Polygon"!=p&&"MultiPolygon"!=p){let n=a.overflow?null:[];switch(p){case"Point":case"MultiPoint":f=t.getFlatCoordinates();break;case"LineString":f=t.getFlatMidpoint();break;case"Circle":f=t.getCenter();break;case"MultiLineString":f=t.getFlatMidpoints(),g=2;break;case"Polygon":f=t.getFlatInteriorPoint(),a.overflow||n.push(f[2]/this.resolution),g=3;break;case"MultiPolygon":const e=t.getFlatInteriorPoints();f=[];for(let t=0,i=e.length;t{const n=h[2*(t+i)]===f[i*g]&&h[2*(t+i)+1]===f[i*g+1];return n||--t,n}))}this.saveTextStates_(),(a.backgroundFill||a.backgroundStroke)&&(this.setFillStrokeStyle(a.backgroundFill,a.backgroundStroke),a.backgroundFill&&this.updateFillStyle(this.state,this.createFill),a.backgroundStroke&&(this.updateStrokeStyle(this.state,this.applyStroke),this.hitDetectionInstructions.push(this.createStroke(this.state)))),this.beginGeometry(t,e,i);let l=a.padding;if(l!=o.Tq&&(a.scale[0]<0||a.scale[1]<0)){let t=a.padding[0],e=a.padding[1],i=a.padding[2],n=a.padding[3];a.scale[0]<0&&(e=-e,n=-n),a.scale[1]<0&&(t=-t,i=-i),l=[t,e,i,n]}const c=this.pixelRatio;this.instructions.push([r.Ay.DRAW_IMAGE,d,s,null,NaN,NaN,NaN,1,0,0,this.textRotateWithView_,this.textRotation_,[1,1],NaN,this.declutterMode_,this.declutterImageWithText_,l==o.Tq?o.Tq:l.map((function(t){return t*c})),!!a.backgroundFill,!!a.backgroundStroke,this.text_,this.textKey_,this.strokeKey_,this.fillKey_,this.textOffsetX_,this.textOffsetY_,n]);const u=1/c,m=this.state.fillStyle;a.backgroundFill&&(this.state.fillStyle=o.qY,this.hitDetectionInstructions.push(this.createFill(this.state))),this.hitDetectionInstructions.push([r.Ay.DRAW_IMAGE,d,s,null,NaN,NaN,NaN,1,0,0,this.textRotateWithView_,this.textRotation_,[u,u],NaN,this.declutterMode_,this.declutterImageWithText_,l,!!a.backgroundFill,!!a.backgroundStroke,this.text_,this.textKey_,this.strokeKey_,this.fillKey_?o.qY:this.fillKey_,this.textOffsetX_,this.textOffsetY_,n]),a.backgroundFill&&(this.state.fillStyle=m,this.hitDetectionInstructions.push(this.createFill(this.state))),this.endGeometry(e)}else{if(!(0,l.HY)(this.maxExtent,t.getExtent()))return;let n;if(f=t.getFlatCoordinates(),"LineString"==p)n=[f.length];else if("MultiLineString"==p)n=t.getEnds();else if("Polygon"==p)n=t.getEnds().slice(0,1);else if("MultiPolygon"==p){const e=t.getEndss();n=[];for(let t=0,i=e.length;t{"use strict";i.d(e,{A:()=>r});var n=i(8711);const r=class{constructor(){this.instructions_=[],this.zIndex=0,this.offset_=0,this.context_=new Proxy((0,n.lr)(),{get:(t,e)=>{if("function"==typeof(0,n.lr)()[e])return this.instructions_[this.zIndex+this.offset_]||(this.instructions_[this.zIndex+this.offset_]=[]),this.instructions_[this.zIndex+this.offset_].push(e),this.pushMethodArgs_},set:(t,e,i)=>(this.instructions_[this.zIndex+this.offset_]||(this.instructions_[this.zIndex+this.offset_]=[]),this.instructions_[this.zIndex+this.offset_].push(e,i),!0)})}pushMethodArgs_=(...t)=>(this.instructions_[this.zIndex+this.offset_].push(t),this);pushFunction(t){this.instructions_[this.zIndex+this.offset_].push(t)}getContext(){return this.context_}draw(t){this.instructions_.forEach((e=>{for(let i=0,n=e.length;i{"use strict";i.d(e,{tF:()=>y,_7:()=>_,F8:()=>v});var n=i(2826),r=i(7295),s=i(9703),o=i(8774),a=i(6514),l=i(915),h=i(1597),c=i(7622),u=i(2096);class d extends n.A{constructor(t,e,i,n,r,o,a){super(),this.context_=t,this.pixelRatio_=e,this.extent_=i,this.transform_=n,this.transformRotation_=n?(0,h.Mg)(Math.atan2(n[1],n[0]),10):0,this.viewRotation_=r,this.squaredTolerance_=o,this.userTransform_=a,this.contextFillState_=null,this.contextStrokeState_=null,this.contextTextState_=null,this.fillState_=null,this.strokeState_=null,this.image_=null,this.imageAnchorX_=0,this.imageAnchorY_=0,this.imageHeight_=0,this.imageOpacity_=0,this.imageOriginX_=0,this.imageOriginY_=0,this.imageRotateWithView_=!1,this.imageRotation_=0,this.imageScale_=[0,0],this.imageWidth_=0,this.text_="",this.textOffsetX_=0,this.textOffsetY_=0,this.textRotateWithView_=!1,this.textRotation_=0,this.textScale_=[0,0],this.textFillState_=null,this.textStrokeState_=null,this.textState_=null,this.pixelCoordinates_=[],this.tmpLocalTransform_=(0,s.vt)()}drawImages_(t,e,i,n){if(!this.image_)return;const r=(0,c.Rc)(t,e,i,n,this.transform_,this.pixelCoordinates_),o=this.context_,a=this.tmpLocalTransform_,l=o.globalAlpha;1!=this.imageOpacity_&&(o.globalAlpha=l*this.imageOpacity_);let h=this.imageRotation_;0===this.transformRotation_&&(h-=this.viewRotation_),this.imageRotateWithView_&&(h+=this.viewRotation_);for(let t=0,e=r.length;tt*this.pixelRatio_)),lineDashOffset:(s||o.vk)*this.pixelRatio_,lineJoin:void 0!==a?a:o._K,lineWidth:(void 0!==l?l:o.aq)*this.pixelRatio_,miterLimit:void 0!==h?h:o.eL,strokeStyle:(0,r.F)(t||o.NT)}}else this.strokeState_=null}setImageStyle(t){let e;if(!t||!(e=t.getSize()))return void(this.image_=null);const i=t.getPixelRatio(this.pixelRatio_),n=t.getAnchor(),r=t.getOrigin();this.image_=t.getImage(this.pixelRatio_),this.imageAnchorX_=n[0]*i,this.imageAnchorY_=n[1]*i,this.imageHeight_=e[1]*i,this.imageOpacity_=t.getOpacity(),this.imageOriginX_=r[0],this.imageOriginY_=r[1],this.imageRotateWithView_=t.getRotateWithView(),this.imageRotation_=t.getRotation();const s=t.getScaleArray();this.imageScale_=[s[0]*this.pixelRatio_/i,s[1]*this.pixelRatio_/i],this.imageWidth_=e[0]*i}setTextStyle(t){if(t){const e=t.getFill();if(e){const t=e.getColor();this.textFillState_={fillStyle:(0,r.F)(t||o.qY)}}else this.textFillState_=null;const i=t.getStroke();if(i){const t=i.getColor(),e=i.getLineCap(),n=i.getLineDash(),s=i.getLineDashOffset(),a=i.getLineJoin(),l=i.getWidth(),h=i.getMiterLimit();this.textStrokeState_={lineCap:void 0!==e?e:o._m,lineDash:n||o.Oq,lineDashOffset:s||o.vk,lineJoin:void 0!==a?a:o._K,lineWidth:void 0!==l?l:o.aq,miterLimit:void 0!==h?h:o.eL,strokeStyle:(0,r.F)(t||o.NT)}}else this.textStrokeState_=null;const n=t.getFont(),s=t.getOffsetX(),a=t.getOffsetY(),l=t.getRotateWithView(),h=t.getRotation(),c=t.getScaleArray(),u=t.getText(),d=t.getTextAlign(),p=t.getTextBaseline();this.textState_={font:void 0!==n?n:o.ZV,textAlign:void 0!==d?d:o.MY,textBaseline:void 0!==p?p:o.M8},this.text_=void 0!==u?Array.isArray(u)?u.reduce(((t,e,i)=>t+(i%2?" ":e)),""):u:"",this.textOffsetX_=void 0!==s?this.pixelRatio_*s:0,this.textOffsetY_=void 0!==a?this.pixelRatio_*a:0,this.textRotateWithView_=void 0!==l&&l,this.textRotation_=void 0!==h?h:0,this.textScale_=[this.pixelRatio_*c[0],this.pixelRatio_*c[1]]}else this.text_=""}}const p=d;var f=i(9700),g=i(8711),m=i(594);const y=.5;function _(t,e,i,n,r,s,o,h,c){const u=c?(0,m.JR)(r,c):r,d=t[0]*y,_=t[1]*y,v=(0,g.Y)(d,_);v.imageSmoothingEnabled=!1;const x=v.canvas,b=new p(v,y,r,null,o,h,c?(0,m.FO)((0,m.Tf)(),c):null),w=i.length,A=Math.floor(16777215/w),E={};for(let t=1;t<=w;++t){const e=i[t-1],r=e.getStyleFunction()||n;if(!r)continue;let o=r(e,s);if(!o)continue;Array.isArray(o)||(o=[o]);const a=(t*A).toString(16).padStart(7,"#00000");for(let t=0,i=o.length;t{"use strict";i.d(e,{B:()=>y,A:()=>v});var n=i(6837),r=i(6141),s=i(1854),o=i(4087);class a extends s.A{constructor(t){super(),this.ready=!0,this.boundHandleImageChange_=this.handleImageChange_.bind(this),this.layer_=t,this.staleKeys_=new Array,this.maxStaleKeys=5}getStaleKeys(){return this.staleKeys_}prependStaleKey(t){this.staleKeys_.unshift(t),this.staleKeys_.length>this.maxStaleKeys&&(this.staleKeys_.length=this.maxStaleKeys)}getFeatures(t){return(0,o.b0)()}getData(t){return null}prepareFrame(t){return(0,o.b0)()}renderFrame(t,e){return(0,o.b0)()}forEachFeatureAtCoordinate(t,e,i,n,r){}getLayer(){return this.layer_}handleFontsChanged(){}handleImageChange_(t){const e=t.target;e.getState()!==r.A.LOADED&&e.getState()!==r.A.ERROR||this.renderIfReadyAndVisible()}loadImage(t){let e=t.getState();return e!=r.A.LOADED&&e!=r.A.ERROR&&t.addEventListener(n.A.CHANGE,this.boundHandleImageChange_),e==r.A.IDLE&&(t.load(),e=t.getState()),e==r.A.LOADED}renderIfReadyAndVisible(){const t=this.getLayer();t&&t.getVisible()&&"ready"===t.getSourceState()&&t.changed()}renderDeferred(t){}disposeInternal(){delete this.layer_,super.disposeInternal()}}const l=a;var h=i(9960),c=i(3984),u=i(808),d=i(9703),p=i(3730),f=i(8711),g=i(6514),m=i(915);const y=[];let _=null;const v=class extends l{constructor(t){super(t),this.container=null,this.renderedResolution,this.tempTransform=(0,d.vt)(),this.pixelTransform=(0,d.vt)(),this.inversePixelTransform=(0,d.vt)(),this.context=null,this.deferredContext_=null,this.containerReused=!1,this.frameState=null}getImageData(t,e,i){let n;_||(_=(0,f.Y)(1,1,void 0,{willReadFrequently:!0})),_.clearRect(0,0,1,1);try{_.drawImage(t,e,i,1,1,0,0,1,1),n=_.getImageData(0,0,1,1).data}catch(t){return _=null,null}return n}getBackground(t){let e=this.getLayer().getBackground();return"function"==typeof e&&(e=e(t.viewState.resolution)),e||void 0}useContainer(t,e,i){const n=this.getLayer().getClassName();let r,s;if(t&&t.className===n&&(!i||t&&t.style.backgroundColor&&(0,g.aI)((0,p._j)(t.style.backgroundColor),(0,p._j)(i)))){const e=t.firstElementChild;e instanceof HTMLCanvasElement&&(s=e.getContext("2d"))}if(s&&s.canvas.style.transform===e?(this.container=t,this.context=s,this.containerReused=!0):this.containerReused?(this.container=null,this.context=null,this.containerReused=!1):this.container&&(this.container.style.backgroundColor=null),!this.container){r=document.createElement("div"),r.className=n;let t=r.style;t.position="absolute",t.width="100%",t.height="100%",s=(0,f.Y)();const e=s.canvas;r.appendChild(e),t=e.style,t.position="absolute",t.left="0",t.transformOrigin="top left",this.container=r,this.context=s}this.containerReused||!i||this.container.style.backgroundColor||(this.container.style.backgroundColor=i)}clipUnrotated(t,e,i){const n=(0,m.Py)(i),r=(0,m.WU)(i),s=(0,m.k_)(i),o=(0,m.R)(i);(0,d.Bb)(e.coordinateToPixelTransform,n),(0,d.Bb)(e.coordinateToPixelTransform,r),(0,d.Bb)(e.coordinateToPixelTransform,s),(0,d.Bb)(e.coordinateToPixelTransform,o);const a=this.inversePixelTransform;(0,d.Bb)(a,n),(0,d.Bb)(a,r),(0,d.Bb)(a,s),(0,d.Bb)(a,o),t.save(),t.beginPath(),t.moveTo(Math.round(n[0]),Math.round(n[1])),t.lineTo(Math.round(r[0]),Math.round(r[1])),t.lineTo(Math.round(s[0]),Math.round(s[1])),t.lineTo(Math.round(o[0]),Math.round(o[1])),t.clip()}prepareContainer(t,e){const i=t.extent,n=t.viewState.resolution,r=t.viewState.rotation,s=t.pixelRatio,o=Math.round((0,m.RG)(i)/n*s),a=Math.round((0,m.Oq)(i)/n*s);(0,d.Zz)(this.pixelTransform,t.size[0]/2,t.size[1]/2,1/s,1/s,r,-o/2,-a/2),(0,d.T9)(this.inversePixelTransform,this.pixelTransform);const l=(0,d.dI)(this.pixelTransform);if(this.useContainer(e,l,this.getBackground(t)),!this.containerReused){const t=this.context.canvas;t.width!=o||t.height!=a?(t.width=o,t.height=a):this.context.clearRect(0,0,o,a),l!==t.style.transform&&(t.style.transform=l)}}dispatchRenderEvent_(t,e,i){const n=this.getLayer();if(n.hasListener(t)){const r=new h.A(t,this.inversePixelTransform,i,e);n.dispatchEvent(r)}}preRender(t,e){this.frameState=e,e.declutter||this.dispatchRenderEvent_(c.A.PRERENDER,t,e)}postRender(t,e){e.declutter||this.dispatchRenderEvent_(c.A.POSTRENDER,t,e)}renderDeferredInternal(t){}getRenderContext(t){return t.declutter&&!this.deferredContext_&&(this.deferredContext_=new u.A),t.declutter?this.deferredContext_.getContext():this.context}renderDeferred(t){t.declutter&&(this.dispatchRenderEvent_(c.A.PRERENDER,this.context,t),t.declutter&&this.deferredContext_&&(this.deferredContext_.draw(this.context),this.deferredContext_.clear()),this.renderDeferredInternal(t),this.dispatchRenderEvent_(c.A.POSTRENDER,this.context,t))}getRenderTransform(t,e,i,n,r,s,o){const a=r/2,l=s/2,h=n/e,c=-h,u=-t[0]+o,p=-t[1];return(0,d.Zz)(this.tempTransform,a,l,h,c,-i,u,p)}disposeInternal(){delete this.frameState,super.disposeInternal()}}},441:(t,e,i)=>{"use strict";i.d(e,{A:()=>D});var n=i(1623),r=i(8143),s=i(1078),o=i(8711);function a(t){return t instanceof Image||t instanceof HTMLCanvasElement||t instanceof HTMLVideoElement||t instanceof ImageBitmap?t:null}const l=new Error("disposed");let h=null;const c=[256,256];class u extends r.A{constructor(t){const e=s.A.IDLE;super(t.tileCoord,e,{transition:t.transition,interpolate:t.interpolate}),this.loader_=t.loader,this.data_=null,this.error_=null,this.size_=t.size||null,this.controller_=t.controller||null}getSize(){if(this.size_)return this.size_;const t=a(this.data_);return t?[t.width,t.height]:c}getData(){return this.data_}getError(){return this.error_}load(){if(this.state!==s.A.IDLE&&this.state!==s.A.ERROR)return;this.state=s.A.LOADING,this.changed();const t=this;this.loader_().then((function(e){t.data_=e,t.state=s.A.LOADED,t.changed()})).catch((function(e){t.error_=e,t.state=s.A.ERROR,t.changed()}))}disposeInternal(){this.controller_&&(this.controller_.abort(l),this.controller_=null),super.disposeInternal()}}const d=u;var p=i(190),f=i(4969),g=i(3101),m=i(6837),y=i(2913),_=i(3513),v=i(1597),x=i(915),b=i(9438);const w=class extends d{constructor(t){super({tileCoord:t.tileCoord,loader:()=>Promise.resolve(new Uint8ClampedArray(4)),interpolate:t.interpolate,transition:t.transition}),this.pixelRatio_=t.pixelRatio,this.gutter_=t.gutter,this.reprojData_=null,this.reprojError_=null,this.reprojSize_=void 0,this.sourceTileGrid_=t.sourceTileGrid,this.targetTileGrid_=t.targetTileGrid,this.wrappedTileCoord_=t.wrappedTileCoord||t.tileCoord,this.sourceTiles_=[],this.sourcesListenerKeys_=null,this.sourceZ_=0;const e=t.sourceProj,i=e.getExtent(),n=t.sourceTileGrid.getExtent();this.clipExtent_=e.canWrapX()?n?(0,x._N)(i,n):i:n;const r=this.targetTileGrid_.getTileCoordExtent(this.wrappedTileCoord_),o=this.targetTileGrid_.getExtent();let a=this.sourceTileGrid_.getExtent();const l=o?(0,x._N)(r,o):r;if(0===(0,x.UG)(l))return void(this.state=s.A.EMPTY);i&&(a=a?(0,x._N)(a,i):i);const h=this.targetTileGrid_.getResolution(this.wrappedTileCoord_[0]),c=t.targetProj,u=(0,_.aY)(e,c,l,h);if(!isFinite(u)||u<=0)return void(this.state=s.A.EMPTY);const d=void 0!==t.errorThreshold?t.errorThreshold:g.l;if(this.triangulation_=new y.A(e,c,l,a,u*d,h),0===this.triangulation_.getTriangles().length)return void(this.state=s.A.EMPTY);this.sourceZ_=this.sourceTileGrid_.getZForResolution(u);let p=this.triangulation_.calculateSourceExtent();if(a&&(e.canWrapX()?(p[1]=(0,v.qE)(p[1],a[1],a[3]),p[3]=(0,v.qE)(p[3],a[1],a[3])):p=(0,x._N)(p,a)),(0,x.UG)(p)){let n=0,r=0;e.canWrapX()&&(n=(0,x.RG)(i),r=Math.floor((p[0]-i[0])/n)),(0,x.QJ)(p.slice(),e,!0).forEach((e=>{const i=this.sourceTileGrid_.getTileRangeForExtentAndZ(e,this.sourceZ_),s=t.getTileFunction;for(let t=i.minX;t<=i.maxX;t++)for(let e=i.minY;e<=i.maxY;e++){const i=s(this.sourceZ_,t,e,this.pixelRatio_);if(i){const t=r*n;this.sourceTiles_.push({tile:i,offset:t})}}++r})),0===this.sourceTiles_.length&&(this.state=s.A.EMPTY)}else this.state=s.A.EMPTY}getSize(){return this.reprojSize_}getData(){return this.reprojData_}getError(){return this.reprojError_}reproject_(){const t=[];let e=!1;if(this.sourceTiles_.forEach((i=>{const n=i.tile;if(!n||n.getState()!==s.A.LOADED)return;const r=n.getSize(),l=this.gutter_;let c;const u=(d=n.getData())instanceof Uint8Array||d instanceof Uint8ClampedArray||d instanceof Float32Array||d instanceof DataView?d:null;var d;u?c=u:(e=!0,c=function(t){h||(h=(0,o.Y)(t.width,t.height,void 0,{willReadFrequently:!0}));const e=h.canvas,i=t.width;e.width!==i&&(e.width=i);const n=t.height;return e.height!==n&&(e.height=n),h.clearRect(0,0,i,n),h.drawImage(t,0,0),h.getImageData(0,0,i,n).data}(a(n.getData())));const p=[r[0]+2*l,r[1]+2*l],f=c instanceof Float32Array,g=p[0]*p[1],m=f?Float32Array:Uint8ClampedArray,y=new m(c.buffer),_=m.BYTES_PER_ELEMENT,v=_*y.length/g,x=y.byteLength/p[1],b=Math.floor(x/_/p[0]),w=g*b;let A=y;if(y.length!==w){A=new m(w);let t=0,e=0;const i=p[0]*b;for(let n=0;n=0;--e){const i=[];for(let n=0,r=t.length;n{const i=e.getState();if(i!==s.A.IDLE&&i!==s.A.LOADING)return;t++;const n=(0,b.KT)(e,m.A.CHANGE,(()=>{const i=e.getState();i!=s.A.LOADED&&i!=s.A.ERROR&&i!=s.A.EMPTY||((0,b.JH)(n),t--,0===t&&(this.unlistenSources_(),this.reproject_()))}));this.sourcesListenerKeys_.push(n)})),0===t?setTimeout(this.reproject_.bind(this),0):this.sourceTiles_.forEach((function({tile:t}){t.getState()==s.A.IDLE&&t.load()}))}unlistenSources_(){this.sourcesListenerKeys_.forEach(b.JH),this.sourcesListenerKeys_=null}};var A=i(7404),E=i(1110),C=i(9703),S=i(6514),T=i(186),R=i(594),I=i(4087),k=i(6782);function M(t,e,i,n){return`${t},${(0,T.dp)(e,i,n)}`}function P(t,e,i){if(!(i in t))return t[i]=new Set([e]),!0;const n=t[i],r=n.has(e);return r||n.add(e),!r}function L(t,e,i){const n=t[i];return!!n&&n.delete(e)}function F(t,e){const i=t.layerStatesArray[t.layerIndex];i.extent&&(e=(0,x._N)(e,(0,R.SD)(i.extent,t.viewState.projection)));const n=i.layer.getRenderSource();if(!n.getWrapX()){const i=n.getTileGridForProjection(t.viewState.projection).getExtent();i&&(e=(0,x._N)(e,i))}return e}class O extends n.A{constructor(t,e){super(t),e=e||{},this.extentChanged=!0,this.renderComplete=!1,this.renderedExtent_=null,this.renderedPixelRatio,this.renderedProjection=null,this.renderedRevision,this.renderedTiles=[],this.renderedSourceKey_,this.renderedSourceRevision_,this.tempExtent=(0,x.S5)(),this.tempTileRange_=new E.A(0,0,0,0),this.tempTileCoord_=(0,T.N)(0,0,0);const i=void 0!==e.cacheSize?e.cacheSize:512;this.tileCache_=new f.A(i),this.maxStaleKeys=.5*i}getTileCache(){return this.tileCache_}getOrCreateTile(t,e,i,n){const r=this.tileCache_,s=this.getLayer().getSource(),o=M(s.getKey(),t,e,i);let a;if(r.containsKey(o))a=r.get(o);else{if(a=s.getTile(t,e,i,n.pixelRatio,n.viewState.projection),!a)return null;r.set(o,a)}return a}getTile(t,e,i,n){return this.getOrCreateTile(t,e,i,n)||null}getData(t){const e=this.frameState;if(!e)return null;const i=this.getLayer(),n=(0,C.Bb)(e.pixelToCoordinateTransform,t.slice()),r=i.getExtent();if(r&&!(0,x.Ym)(r,n))return null;const o=e.viewState,l=i.getRenderSource(),h=l.getTileGridForProjection(o.projection),c=l.getTilePixelRatio(e.pixelRatio);for(let t=h.getZForResolution(o.resolution);t>=h.getMinZoom();--t){const i=h.getTileCoordForCoordAndZ(n,t),r=this.getTile(t,i[1],i[2],e);if(!r||r.getState()!==s.A.LOADED)continue;const u=h.getOrigin(t),f=(0,k.xq)(h.getTileSize(t)),g=h.getResolution(t);let m;if(r instanceof p.A)m=r.getImage();else{if(!(r instanceof d))continue;if(m=a(r.getData()),!m)continue}const y=Math.floor(c*((n[0]-u[0])/g-i[1]*f[0])),_=Math.floor(c*((u[1]-n[1])/g-i[2]*f[1])),v=Math.round(c*l.getGutterForProjection(o.projection));return this.getImageData(m,y+v,_+v)}return null}prepareFrame(t){const e=this.getLayer().getSource();if(!e)return!1;const i=this.getLayer().getSource().getRevision();return this.renderedRevision_?this.renderedRevision_!==i&&(this.renderedRevision_=i,this.renderedSourceKey_===e.getKey()&&this.tileCache_.clear()):this.renderedRevision_=i,!0}enqueueTiles(t,e,i,n,r){const o=t.viewState,a=this.getLayer(),l=a.getRenderSource(),h=l.getTileGridForProjection(o.projection),c=(0,I.v6)(l);c in t.wantedTiles||(t.wantedTiles[c]={});const u=t.wantedTiles[c],d=a.getMapInternal(),p=Math.max(i-r,h.getMinZoom(),h.getZForResolution(Math.min(a.getMaxResolution(),d?d.getView().getResolutionForZoom(Math.max(a.getMinZoom(),0)):h.getResolution(0)),l.zDirection));for(let r=i;r>=p;--r){const i=h.getTileRangeForExtentAndZ(e,r,this.tempTileRange_),o=h.getResolution(r);for(let e=i.minX;e<=i.maxX;++e)for(let a=i.minY;a<=i.maxY;++a){const i=this.getTile(r,e,a,t);if(!i)continue;if(!P(n,i,r))continue;const l=i.getKey();if(u[l]=!0,i.getState()===s.A.IDLE&&!t.tileQueue.isKeyQueued(l)){const n=(0,T.N)(r,e,a,this.tempTileCoord_);t.tileQueue.enqueue([i,c,h.getTileCoordCenter(n),o])}}}}findStaleTile_(t,e){const i=this.tileCache_,n=t[0],r=t[1],o=t[2],a=this.getStaleKeys();for(let t=0;t0&&setTimeout((()=>{this.enqueueTiles(t,O,p-1,M,P-1)}),0);const D=(0,I.v6)(this),j=t.time;for(const e of M[p]){const i=e.getState();if((e instanceof A.A||e instanceof w)&&i===s.A.EMPTY)continue;const n=e.tileCoord;if(i===s.A.LOADED&&1===e.getAlpha(D,j)){e.endTransition(D);continue}if(this.renderComplete=!1,this.findStaleTile_(n,M)){L(M,e,p),t.animate=!0;continue}if(this.findAltTiles_(d,n,p+1,M))continue;const r=d.getMinZoom();for(let t=p-1;t>=r&&!this.findAltTiles_(d,n,t,M);--t);}const z=f/o*l/y,N=this.getRenderContext(t);(0,C.Zz)(this.tempTransform,_/2,v/2,z,z,0,-_/2,-v/2),i.extent&&this.clipUnrotated(N,t,b),c.getInterpolate()||(N.imageSmoothingEnabled=!1),this.preRender(N,t),this.renderedTiles.length=0;const G=Object.keys(M).map(Number);let q;G.sort(S.V_);const W=[],Y=[];for(let e=G.length-1;e>=0;--e){const i=G[e],n=c.getTilePixelSize(i,l,r),o=d.getResolution(i)/f,a=n[0]*o*z,h=n[1]*o*z,u=d.getTileCoordForCoordAndZ((0,x.Py)(k),i),p=d.getTileCoordExtent(u),g=(0,C.Bb)(this.tempTransform,[y*(p[0]-k[0])/f,y*(k[3]-p[3])/f]),m=y*c.getGutterForProjection(r);for(const e of M[i]){if(e.getState()!==s.A.LOADED)continue;const n=e.tileCoord,r=u[1]-n[1],o=Math.round(g[0]-(r-1)*a),l=u[2]-n[2],d=Math.round(g[1]-(l-1)*h),p=Math.round(g[0]-r*a),f=Math.round(g[1]-l*h),y=o-p,_=d-f,v=1===G.length;let b=!1;q=[p,f,p+y,f,p+y,f+_,p,f+_];for(let t=0,e=W.length;t{const i=(0,I.v6)(c),n=e.wantedTiles[i],r=n?Object.keys(n).length:0;this.updateCacheSize(r),this.tileCache_.expireCache()})),this.container}updateCacheSize(t){this.tileCache_.highWaterMark=Math.max(this.tileCache_.highWaterMark,2*t)}drawTile(t,e,i,n,r,s,o,l){let h;if(t instanceof d){if(h=a(t.getData()),!h)throw new Error("Rendering array data is not yet supported")}else h=this.getTileImage(t);if(!h)return;const c=this.getRenderContext(e),u=(0,I.v6)(this),p=e.layerStatesArray[e.layerIndex],f=p.opacity*(l?t.getAlpha(u,e.time):1),g=f!==c.globalAlpha;g&&(c.save(),c.globalAlpha=f),c.drawImage(h,o,o,h.width-2*o,h.height-2*o,i,n,r,s),g&&c.restore(),f!==p.opacity?e.animate=!0:l&&t.endTransition(u)}getImage(){const t=this.context;return t?t.canvas:null}getTileImage(t){return t.getImage()}updateUsedTiles(t,e,i){const n=(0,I.v6)(e);n in t||(t[n]={}),t[n][i.getKey()]=!0}}const D=O},3608:(t,e,i)=>{"use strict";i.d(e,{Eo:()=>a,gY:()=>h,j:()=>l,nl:()=>c});var n=i(6141),r=i(4087);const s=.5,o={Point:function(t,e,i,r,s,o){const a=i.getImage(),l=i.getText(),h=l&&l.getText(),c=o&&a&&h?{}:void 0;if(a){if(a.getImageState()!=n.A.LOADED)return;const o=t.getBuilder(i.getZIndex(),"Image");o.setImageStyle(a,c),o.drawPoint(e,r,s)}if(h){const n=t.getBuilder(i.getZIndex(),"Text");n.setTextStyle(l,c),n.drawText(e,r,s)}},LineString:function(t,e,i,n,r){const s=i.getStroke();if(s){const o=t.getBuilder(i.getZIndex(),"LineString");o.setFillStrokeStyle(null,s),o.drawLineString(e,n,r)}const o=i.getText();if(o&&o.getText()){const s=t.getBuilder(i.getZIndex(),"Text");s.setTextStyle(o),s.drawText(e,n,r)}},Polygon:function(t,e,i,n,r){const s=i.getFill(),o=i.getStroke();if(s||o){const a=t.getBuilder(i.getZIndex(),"Polygon");a.setFillStrokeStyle(s,o),a.drawPolygon(e,n,r)}const a=i.getText();if(a&&a.getText()){const s=t.getBuilder(i.getZIndex(),"Text");s.setTextStyle(a),s.drawText(e,n,r)}},MultiPoint:function(t,e,i,r,s,o){const a=i.getImage(),l=a&&0!==a.getOpacity(),h=i.getText(),c=h&&h.getText(),u=o&&l&&c?{}:void 0;if(l){if(a.getImageState()!=n.A.LOADED)return;const o=t.getBuilder(i.getZIndex(),"Image");o.setImageStyle(a,u),o.drawMultiPoint(e,r,s)}if(c){const n=t.getBuilder(i.getZIndex(),"Text");n.setTextStyle(h,u),n.drawText(e,r,s)}},MultiLineString:function(t,e,i,n,r){const s=i.getStroke();if(s){const o=t.getBuilder(i.getZIndex(),"LineString");o.setFillStrokeStyle(null,s),o.drawMultiLineString(e,n,r)}const o=i.getText();if(o&&o.getText()){const s=t.getBuilder(i.getZIndex(),"Text");s.setTextStyle(o),s.drawText(e,n,r)}},MultiPolygon:function(t,e,i,n,r){const s=i.getFill(),o=i.getStroke();if(o||s){const a=t.getBuilder(i.getZIndex(),"Polygon");a.setFillStrokeStyle(s,o),a.drawMultiPolygon(e,n,r)}const a=i.getText();if(a&&a.getText()){const s=t.getBuilder(i.getZIndex(),"Text");s.setTextStyle(a),s.drawText(e,n,r)}},GeometryCollection:function(t,e,i,n,r,s){const a=e.getGeometriesArray();let l,h;for(l=0,h=a.length;l0;return f&&Promise.all(c).then((()=>s(null))),function(t,e,i,n,r,s,a){const l=i.getGeometryFunction()(e);if(!l)return;const h=l.simplifyTransformed(n,r);i.getRenderer()?u(t,h,i,e,a):(0,o[h.getType()])(t,h,i,e,a,s)}(t,e,i,r,a,l,h),f}function u(t,e,i,n,r){if("GeometryCollection"!=e.getType())t.getBuilder(i.getZIndex(),"Default").drawCustom(e,n,i.getRenderer(),i.getHitDetectionRenderer(),r);else{const s=e.getGeometries();for(let e=0,o=s.length;e{"use strict";i.d(e,{BV:()=>l,KQ:()=>u,XX:()=>p,aY:()=>d});var n=i(915),r=i(8711),s=i(594),o=i(1597);let a;const l=[];function h(t,e,i,n,r){t.beginPath(),t.moveTo(0,0),t.lineTo(e,i),t.lineTo(n,r),t.closePath(),t.save(),t.clip(),t.fillRect(0,0,Math.max(e,n)+1,Math.max(i,r)),t.restore()}function c(t,e){return Math.abs(t[4*e]-210)>2||Math.abs(t[4*e+3]-191.25)>2}function u(t,e,i,r){const o=(0,s.pd)(i,e,t);let a=(0,s.hO)(e,r,i);const l=e.getMetersPerUnit();void 0!==l&&(a*=l);const h=t.getMetersPerUnit();void 0!==h&&(a/=h);const c=t.getExtent();if(!c||(0,n.Ym)(c,o)){const e=(0,s.hO)(t,a,o)/a;isFinite(e)&&e>0&&(a/=e)}return a}function d(t,e,i,r){const s=(0,n.q1)(i);let o=u(t,e,s,r);return(!isFinite(o)||o<=0)&&(0,n.sB)(i,(function(i){return o=u(t,e,i,r),isFinite(o)&&o>0})),o}function p(t,e,i,s,u,d,p,f,g,m,y,_,v,x){const b=(0,r.Y)(Math.round(i*t),Math.round(i*e),l);if(_||(b.imageSmoothingEnabled=!1),0===g.length)return b.canvas;function w(t){return Math.round(t*i)/i}b.scale(i,i),b.globalCompositeOperation="lighter";const A=(0,n.S5)();let E;g.forEach((function(t,e,i){(0,n.X$)(A,t.extent)}));const C=i/s,S=(_?1:1+Math.pow(2,-24))/C;if(!v||1!==g.length||0!==m){if(E=(0,r.Y)(Math.round((0,n.RG)(A)*C),Math.round((0,n.Oq)(A)*C),l),_||(E.imageSmoothingEnabled=!1),u&&x){const t=(u[0]-A[0])*C,e=-(u[3]-A[3])*C,i=(0,n.RG)(u)*C,r=(0,n.Oq)(u)*C;E.rect(t,e,i,r),E.clip()}g.forEach((function(t,e,i){if(t.image.width>0&&t.image.height>0){if(t.clipExtent){E.save();const e=(t.clipExtent[0]-A[0])*C,i=-(t.clipExtent[3]-A[3])*C,r=(0,n.RG)(t.clipExtent)*C,s=(0,n.Oq)(t.clipExtent)*C;E.rect(_?e:Math.round(e),_?i:Math.round(i),_?r:Math.round(e+r)-Math.round(e),_?s:Math.round(i+s)-Math.round(i)),E.clip()}const e=(t.extent[0]-A[0])*C,i=-(t.extent[3]-A[3])*C,r=(0,n.RG)(t.extent)*C,s=(0,n.Oq)(t.extent)*C;E.drawImage(t.image,m,m,t.image.width-2*m,t.image.height-2*m,_?e:Math.round(e),_?i:Math.round(i),_?r:Math.round(e+r)-Math.round(e),_?s:Math.round(i+s)-Math.round(i)),t.clipExtent&&E.restore()}}))}const T=(0,n.Py)(p);return f.getTriangles().forEach((function(t,e,i){const s=t.source,u=t.target;let p=s[0][0],f=s[0][1],m=s[1][0],y=s[1][1],v=s[2][0],x=s[2][1];const C=w((u[0][0]-T[0])/d),R=w(-(u[0][1]-T[1])/d),I=w((u[1][0]-T[0])/d),k=w(-(u[1][1]-T[1])/d),M=w((u[2][0]-T[0])/d),P=w(-(u[2][1]-T[1])/d),L=p,F=f;p=0,f=0,m-=L,y-=F,v-=L,x-=F;const O=[[m,y,0,0,I-C],[v,x,0,0,M-C],[0,0,m,y,k-R],[0,0,v,x,P-R]],D=(0,o.KU)(O);if(!D)return;if(b.save(),b.beginPath(),function(){if(void 0===a){const t=(0,r.Y)(6,6,l);t.globalCompositeOperation="lighter",t.fillStyle="rgba(210, 0, 0, 0.75)",h(t,4,5,4,0),h(t,4,5,0,5);const e=t.getImageData(0,0,3,3).data;a=c(e,0)||c(e,4)||c(e,8),(0,r.Yg)(t),l.push(t.canvas)}return a}()||!_){b.moveTo(I,k);const t=4,e=C-I,i=R-k;for(let n=0;n{"use strict";i.d(e,{A:()=>f});var n=i(3101),r=i(6837),s=i(8143),o=i(1078),a=i(2913),l=i(3513),h=i(1597),c=i(915),u=i(9438),d=i(8711);class p extends s.A{constructor(t,e,i,r,s,u,d,p,f,g,m,y){super(s,o.A.IDLE,y),this.renderEdges_=void 0!==m&&m,this.pixelRatio_=d,this.gutter_=p,this.canvas_=null,this.sourceTileGrid_=e,this.targetTileGrid_=r,this.wrappedTileCoord_=u||s,this.sourceTiles_=[],this.sourcesListenerKeys_=null,this.sourceZ_=0,this.clipExtent_=t.canWrapX()?t.getExtent():void 0;const _=r.getTileCoordExtent(this.wrappedTileCoord_),v=this.targetTileGrid_.getExtent();let x=this.sourceTileGrid_.getExtent();const b=v?(0,c._N)(_,v):_;if(0===(0,c.UG)(b))return void(this.state=o.A.EMPTY);const w=t.getExtent();w&&(x=x?(0,c._N)(x,w):w);const A=r.getResolution(this.wrappedTileCoord_[0]),E=(0,l.aY)(t,i,b,A);if(!isFinite(E)||E<=0)return void(this.state=o.A.EMPTY);const C=void 0!==g?g:n.l;if(this.triangulation_=new a.A(t,i,b,x,E*C,A),0===this.triangulation_.getTriangles().length)return void(this.state=o.A.EMPTY);this.sourceZ_=e.getZForResolution(E);let S=this.triangulation_.calculateSourceExtent();if(x&&(t.canWrapX()?(S[1]=(0,h.qE)(S[1],x[1],x[3]),S[3]=(0,h.qE)(S[3],x[1],x[3])):S=(0,c._N)(S,x)),(0,c.UG)(S)){let i=0,n=0;t.canWrapX()&&(i=(0,c.RG)(w),n=Math.floor((S[0]-w[0])/i)),(0,c.QJ)(S.slice(),t,!0).forEach((t=>{const r=e.getTileRangeForExtentAndZ(t,this.sourceZ_);for(let t=r.minX;t<=r.maxX;t++)for(let e=r.minY;e<=r.maxY;e++){const r=f(this.sourceZ_,t,e,d);if(r){const t=n*i;this.sourceTiles_.push({tile:r,offset:t})}}++n})),0===this.sourceTiles_.length&&(this.state=o.A.EMPTY)}else this.state=o.A.EMPTY}getImage(){return this.canvas_}reproject_(){const t=[];if(this.sourceTiles_.forEach((e=>{const i=e.tile;if(i&&i.getState()==o.A.LOADED){const n=this.sourceTileGrid_.getTileCoordExtent(i.tileCoord);n[0]+=e.offset,n[2]+=e.offset;const r=this.clipExtent_?.slice();r&&(r[0]+=e.offset,r[2]+=e.offset),t.push({extent:n,clipExtent:r,image:i.getImage()})}})),this.sourceTiles_.length=0,0===t.length)this.state=o.A.ERROR;else{const e=this.wrappedTileCoord_[0],i=this.targetTileGrid_.getTileSize(e),n="number"==typeof i?i:i[0],r="number"==typeof i?i:i[1],s=this.targetTileGrid_.getResolution(e),a=this.sourceTileGrid_.getResolution(this.sourceZ_),h=this.targetTileGrid_.getTileCoordExtent(this.wrappedTileCoord_);this.canvas_=(0,l.XX)(n,r,this.pixelRatio_,a,this.sourceTileGrid_.getExtent(),s,h,this.triangulation_,t,this.gutter_,this.renderEdges_,this.interpolate),this.state=o.A.LOADED}this.changed()}load(){if(this.state==o.A.IDLE){this.state=o.A.LOADING,this.changed();let t=0;this.sourcesListenerKeys_=[],this.sourceTiles_.forEach((({tile:e})=>{const i=e.getState();if(i==o.A.IDLE||i==o.A.LOADING){t++;const i=(0,u.KT)(e,r.A.CHANGE,(n=>{const r=e.getState();r!=o.A.LOADED&&r!=o.A.ERROR&&r!=o.A.EMPTY||((0,u.JH)(i),t--,0===t&&(this.unlistenSources_(),this.reproject_()))}));this.sourcesListenerKeys_.push(i)}})),0===t?setTimeout(this.reproject_.bind(this),0):this.sourceTiles_.forEach((function({tile:t},e,i){t.getState()==o.A.IDLE&&t.load()}))}}unlistenSources_(){this.sourcesListenerKeys_.forEach(u.JH),this.sourcesListenerKeys_=null}release(){this.canvas_&&((0,d.Yg)(this.canvas_.getContext("2d")),l.BV.push(this.canvas_),this.canvas_=null),super.release()}}const f=p},2913:(t,e,i)=>{"use strict";i.d(e,{A:()=>o});var n=i(915),r=i(594),s=i(1597);const o=class{constructor(t,e,i,s,o,a){this.sourceProj_=t,this.targetProj_=e;let l={};const h=(0,r.RG)(this.targetProj_,this.sourceProj_);this.transformInv_=function(t){const e=t[0]+"/"+t[1];return l[e]||(l[e]=h(t)),l[e]},this.maxSourceExtent_=s,this.errorThresholdSquared_=o*o,this.triangles_=[],this.wrapsXInSource_=!1,this.canWrapXInSource_=this.sourceProj_.canWrapX()&&!!s&&!!this.sourceProj_.getExtent()&&(0,n.RG)(s)>=(0,n.RG)(this.sourceProj_.getExtent()),this.sourceWorldWidth_=this.sourceProj_.getExtent()?(0,n.RG)(this.sourceProj_.getExtent()):null,this.targetWorldWidth_=this.targetProj_.getExtent()?(0,n.RG)(this.targetProj_.getExtent()):null;const c=(0,n.Py)(i),u=(0,n.WU)(i),d=(0,n.k_)(i),p=(0,n.R)(i),f=this.transformInv_(c),g=this.transformInv_(u),m=this.transformInv_(d),y=this.transformInv_(p),_=10+(a?Math.max(0,Math.ceil(Math.log2((0,n.UG)(i)/(a*a*256*256)))):0);if(this.addQuad_(c,u,d,p,f,g,m,y,_),this.wrapsXInSource_){let t=1/0;this.triangles_.forEach((function(e,i,n){t=Math.min(t,e.source[0][0],e.source[1][0],e.source[2][0])})),this.triangles_.forEach((e=>{if(Math.max(e.source[0][0],e.source[1][0],e.source[2][0])-t>this.sourceWorldWidth_/2){const i=[[e.source[0][0],e.source[0][1]],[e.source[1][0],e.source[1][1]],[e.source[2][0],e.source[2][1]]];i[0][0]-t>this.sourceWorldWidth_/2&&(i[0][0]-=this.sourceWorldWidth_),i[1][0]-t>this.sourceWorldWidth_/2&&(i[1][0]-=this.sourceWorldWidth_),i[2][0]-t>this.sourceWorldWidth_/2&&(i[2][0]-=this.sourceWorldWidth_);const n=Math.min(i[0][0],i[1][0],i[2][0]);Math.max(i[0][0],i[1][0],i[2][0])-n.5&&d<1;let g=!1;if(c>0){if(this.targetProj_.isGlobal()&&this.targetWorldWidth_){const s=(0,n.Tr)([t,e,i,r]);g=(0,n.RG)(s)/this.targetWorldWidth_>.25||g}!f&&this.sourceProj_.isGlobal()&&d&&(g=d>.25||g)}if(!g&&this.maxSourceExtent_&&isFinite(u[0])&&isFinite(u[1])&&isFinite(u[2])&&isFinite(u[3])&&!(0,n.HY)(u,this.maxSourceExtent_))return;let m=0;if(!(g||isFinite(o[0])&&isFinite(o[1])&&isFinite(a[0])&&isFinite(a[1])&&isFinite(l[0])&&isFinite(l[1])&&isFinite(h[0])&&isFinite(h[1])))if(c>0)g=!0;else if(m=(isFinite(o[0])&&isFinite(o[1])?0:8)+(isFinite(a[0])&&isFinite(a[1])?0:4)+(isFinite(l[0])&&isFinite(l[1])?0:2)+(isFinite(h[0])&&isFinite(h[1])?0:1),1!=m&&2!=m&&4!=m&&8!=m)return;if(c>0){if(!g){const e=[(t[0]+i[0])/2,(t[1]+i[1])/2],n=this.transformInv_(e);let r;r=f?((0,s.xP)(o[0],p)+(0,s.xP)(l[0],p))/2-(0,s.xP)(n[0],p):(o[0]+l[0])/2-n[0];const a=(o[1]+l[1])/2-n[1];g=r*r+a*a>this.errorThresholdSquared_}if(g){if(Math.abs(t[0]-i[0])<=Math.abs(t[1]-i[1])){const n=[(e[0]+i[0])/2,(e[1]+i[1])/2],s=this.transformInv_(n),u=[(r[0]+t[0])/2,(r[1]+t[1])/2],d=this.transformInv_(u);this.addQuad_(t,e,n,u,o,a,s,d,c-1),this.addQuad_(u,n,i,r,d,s,l,h,c-1)}else{const n=[(t[0]+e[0])/2,(t[1]+e[1])/2],s=this.transformInv_(n),u=[(i[0]+r[0])/2,(i[1]+r[1])/2],d=this.transformInv_(u);this.addQuad_(t,n,u,r,o,s,d,h,c-1),this.addQuad_(n,e,i,u,s,a,l,d,c-1)}return}}if(f){if(!this.canWrapXInSource_)return;this.wrapsXInSource_=!0}0==(11&m)&&this.addTriangle_(t,i,r,o,l,h),0==(14&m)&&this.addTriangle_(t,i,e,o,l,a),m&&(0==(13&m)&&this.addTriangle_(e,r,t,a,h,o),0==(7&m)&&this.addTriangle_(e,r,i,a,h,l))}calculateSourceExtent(){const t=(0,n.S5)();return this.triangles_.forEach((function(e,i,r){const s=e.source;(0,n.$C)(t,s[0]),(0,n.$C)(t,s[1]),(0,n.$C)(t,s[2])})),t}getTriangles(){return this.triangles_}}},3101:(t,e,i)=>{"use strict";i.d(e,{l:()=>n});const n=.5},4498:(t,e,i)=>{"use strict";i.d(e,{a$:()=>o,b8:()=>r,cq:()=>a,dv:()=>s});var n=i(1597);function r(t){if(void 0!==t)return 0}function s(t){if(void 0!==t)return t}function o(t){const e=2*Math.PI/t;return function(t,i){return i?t:void 0!==t?t=Math.floor(t/e+.5)*e:void 0}}function a(t){const e=void 0===t?(0,n.eh)(5):t;return function(t,i){return i||void 0===t?t:Math.abs(t)<=e?0:t}}},6782:(t,e,i)=>{"use strict";function n(t){return t[0]>0&&t[1]>0}function r(t,e,i){return void 0===i&&(i=[0,0]),i[0]=t[0]*e+.5|0,i[1]=t[1]*e+.5|0,i}function s(t,e){return Array.isArray(t)?t:(void 0===e?e=[t,t]:(e[0]=t,e[1]=t),e)}i.d(e,{Ie:()=>n,hs:()=>r,xq:()=>s})},6444:(t,e,i)=>{"use strict";i.d(e,{A:()=>a});var n=i(4120),r=i(594);class s extends n.A{constructor(t){super(),this.projection=(0,r.Jt)(t.projection),this.attributions_=o(t.attributions),this.attributionsCollapsible_=t.attributionsCollapsible??!0,this.loading=!1,this.state_=void 0!==t.state?t.state:"ready",this.wrapX_=void 0!==t.wrapX&&t.wrapX,this.interpolate_=!!t.interpolate,this.viewResolver=null,this.viewRejector=null;const e=this;this.viewPromise_=new Promise((function(t,i){e.viewResolver=t,e.viewRejector=i}))}getAttributions(){return this.attributions_}getAttributionsCollapsible(){return this.attributionsCollapsible_}getProjection(){return this.projection}getResolutions(t){return null}getView(){return this.viewPromise_}getState(){return this.state_}getWrapX(){return this.wrapX_}getInterpolate(){return this.interpolate_}refresh(){this.changed()}setAttributions(t){this.attributions_=o(t),this.changed()}setState(t){this.state_=t,this.changed()}}function o(t){return t?"function"==typeof t?t:(Array.isArray(t)||(t=[t]),e=>t):null}const a=s},8738:(t,e,i)=>{"use strict";i.d(e,{A:()=>C});var n=i(71),r=i(2135),s=i(1685),o=i(6837),a=i(8450),l=i(48),h=i(915),c=i(4087),u=i(3530);const d=class{constructor(t){this.rbush_=new l.A(t),this.items_={}}insert(t,e){const i={minX:t[0],minY:t[1],maxX:t[2],maxY:t[3],value:e};this.rbush_.insert(i),this.items_[(0,c.v6)(e)]=i}load(t,e){const i=new Array(e.length);for(let n=0,r=e.length;n{e||(e=!0,this.addFeature(t.element),e=!1)})),t.addEventListener(r.A.REMOVE,(t=>{e||(e=!0,this.removeFeature(t.element),e=!1)})),this.featuresCollection_=t}clear(t){if(t){for(const t in this.featureChangeKeys_)this.featureChangeKeys_[t].forEach(b.JH);this.featuresCollection_||(this.featureChangeKeys_={},this.idIndex_={},this.uidIndex_={})}else if(this.featuresRtree_){const t=t=>{this.removeFeatureInternal(t)};this.featuresRtree_.forEach(t);for(const t in this.nullGeometryFeatures_)this.removeFeatureInternal(this.nullGeometryFeatures_[t])}this.featuresCollection_&&this.featuresCollection_.clear(),this.featuresRtree_&&this.featuresRtree_.clear(),this.nullGeometryFeatures_={};const e=new A("clear");this.dispatchEvent(e),this.changed()}forEachFeature(t){if(this.featuresRtree_)return this.featuresRtree_.forEach(t);this.featuresCollection_&&this.featuresCollection_.forEach(t)}forEachFeatureAtCoordinateDirect(t,e){const i=[t[0],t[1],t[0],t[1]];return this.forEachFeatureInExtent(i,(function(i){const n=i.getGeometry();if(n instanceof p.Ay||n.intersectsCoordinate(t))return e(i)}))}forEachFeatureInExtent(t,e){if(this.featuresRtree_)return this.featuresRtree_.forEachInExtent(t,e);this.featuresCollection_&&this.featuresCollection_.forEach(e)}forEachFeatureIntersectingExtent(t,e){return this.forEachFeatureInExtent(t,(function(i){const n=i.getGeometry();if(n instanceof p.Ay||n.intersectsExtent(t)){const t=e(i);if(t)return t}}))}getFeaturesCollection(){return this.featuresCollection_}getFeatures(){let t;return this.featuresCollection_?t=this.featuresCollection_.getArray().slice(0):this.featuresRtree_&&(t=this.featuresRtree_.getAll(),(0,u.p)(this.nullGeometryFeatures_)||(0,x.X$)(t,Object.values(this.nullGeometryFeatures_))),t}getFeaturesAtCoordinate(t){const e=[];return this.forEachFeatureAtCoordinateDirect(t,(function(t){e.push(t)})),e}getFeaturesInExtent(t,e){if(this.featuresRtree_){if(!(e&&e.canWrapX()&&this.getWrapX()))return this.featuresRtree_.getInExtent(t);const i=(0,h.QJ)(t,e);return[].concat(...i.map((t=>this.featuresRtree_.getInExtent(t))))}return this.featuresCollection_?this.featuresCollection_.getArray().slice(0):[]}getClosestFeatureToCoordinate(t,e){const i=t[0],n=t[1];let r=null;const s=[NaN,NaN];let o=1/0;const a=[-1/0,-1/0,1/0,1/0];return e=e||y.rT,this.featuresRtree_.forEachInExtent(a,(function(t){if(e(t)){const e=t.getGeometry(),l=o;if(o=e instanceof p.Ay?0:e.closestPointXY(i,n,s,o),o{--this.loadingExtentsCount_,this.dispatchEvent(new A("featuresloadend",void 0,t))}),(()=>{--this.loadingExtentsCount_,this.dispatchEvent(new A("featuresloaderror"))})),n.insert(s,{extent:s.slice()}))}this.loading=!(this.loader_.length<4)&&this.loadingExtentsCount_>0}refresh(){this.clear(!0),this.loadedExtentsRtree_.clear(),super.refresh()}removeLoadedExtent(t){const e=this.loadedExtentsRtree_;let i;e.forEachInExtent(t,(function(e){if((0,h.aI)(e.extent,t))return i=e,!0})),i&&e.remove(i)}removeFeatures(t){let e=!1;for(let i=0,n=t.length;i{"use strict";i.d(e,{A:()=>r});var n=i(588);const r=class{constructor(t){this.highWaterMark=void 0!==t?t:2048,this.count_=0,this.entries_={},this.oldest_=null,this.newest_=null}canExpireCache(){return this.highWaterMark>0&&this.getCount()>this.highWaterMark}expireCache(t){for(;this.canExpireCache();)this.pop()}clear(){this.count_=0,this.entries_={},this.oldest_=null,this.newest_=null}containsKey(t){return this.entries_.hasOwnProperty(t)}forEach(t){let e=this.oldest_;for(;e;)t(e.value_,e.key_,this),e=e.newer}get(t,e){const i=this.entries_[t];return(0,n.v)(void 0!==i,"Tried to get a value for a key that does not exist in the cache"),i===this.newest_||(i===this.oldest_?(this.oldest_=this.oldest_.newer,this.oldest_.older=null):(i.newer.older=i.older,i.older.newer=i.newer),i.newer=null,i.older=this.newest_,this.newest_.newer=i,this.newest_=i),i.value_}remove(t){const e=this.entries_[t];return(0,n.v)(void 0!==e,"Tried to get a value for a key that does not exist in the cache"),e===this.newest_?(this.newest_=e.older,this.newest_&&(this.newest_.newer=null)):e===this.oldest_?(this.oldest_=e.newer,this.oldest_&&(this.oldest_.older=null)):(e.newer.older=e.older,e.older.newer=e.newer),delete this.entries_[t],--this.count_,e.value_}getCount(){return this.count_}getKeys(){const t=new Array(this.count_);let e,i=0;for(e=this.newest_;e;e=e.older)t[i++]=e.key_;return t}getValues(){const t=new Array(this.count_);let e,i=0;for(e=this.newest_;e;e=e.older)t[i++]=e.value_;return t}peekLast(){return this.oldest_.value_}peekLastKey(){return this.oldest_.key_}peekFirstKey(){return this.newest_.key_}peek(t){return this.entries_[t]?.value_}pop(){const t=this.oldest_;return delete this.entries_[t.key_],t.newer&&(t.newer.older=null),this.oldest_=t.newer,this.oldest_||(this.newest_=null),--this.count_,t.value_}replace(t,e){this.get(t),this.entries_[t].value_=e}set(t,e){(0,n.v)(!(t in this.entries_),"Tried to set a value for a key that is used already");const i={key_:t,newer:null,older:this.newest_,value_:e};this.newest_?this.newest_.newer=i:this.oldest_=i,this.newest_=i,this.entries_[t]=i,++this.count_}setSize(t){this.highWaterMark=t}}},7733:(t,e,i)=>{"use strict";i.d(e,{A:()=>s});var n=i(6936);class r extends n.A{constructor(t){super({points:1/0,fill:(t=t||{radius:5}).fill,radius:t.radius,stroke:t.stroke,scale:void 0!==t.scale?t.scale:1,rotation:void 0!==t.rotation?t.rotation:0,rotateWithView:void 0!==t.rotateWithView&&t.rotateWithView,displacement:void 0!==t.displacement?t.displacement:[0,0],declutterMode:t.declutterMode})}clone(){const t=this.getScale(),e=new r({fill:this.getFill()?this.getFill().clone():void 0,stroke:this.getStroke()?this.getStroke().clone():void 0,radius:this.getRadius(),scale:Array.isArray(t)?t.slice():t,rotation:this.getRotation(),rotateWithView:this.getRotateWithView(),displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()});return e.setOpacity(this.getOpacity()),e}setRadius(t){this.radius=t,this.render()}}const s=r},3628:(t,e,i)=>{"use strict";i.d(e,{A:()=>o});var n=i(6141),r=i(7907);class s{constructor(t){t=t||{},this.patternImage_=null,this.color_=null,void 0!==t.color&&this.setColor(t.color)}clone(){const t=this.getColor();return new s({color:Array.isArray(t)?t.slice():t||void 0})}getColor(){return this.color_}setColor(t){if(null!==t&&"object"==typeof t&&"src"in t){const e=(0,r.J)(null,t.src,"anonymous",void 0,t.offset?null:t.color?t.color:null,!(t.offset&&t.size));e.ready().then((()=>{this.patternImage_=null})),e.getImageState()===n.A.IDLE&&e.load(),e.getImageState()===n.A.LOADING&&(this.patternImage_=e)}this.color_=t}loading(){return!!this.patternImage_}ready(){return this.patternImage_?this.patternImage_.ready():Promise.resolve()}}const o=s},9700:(t,e,i)=>{"use strict";i.d(e,{A:()=>d});var n=i(6837),r=i(6141),s=i(940),o=i(3730),a=i(588),l=i(7907),h=i(4087);function c(t,e,i,n){return void 0!==i&&void 0!==n?[i/t,n/e]:void 0!==i?i/t:void 0!==n?n/e:1}class u extends s.A{constructor(t){const e=void 0!==(t=t||{}).opacity?t.opacity:1,i=void 0!==t.rotation?t.rotation:0,n=void 0!==t.scale?t.scale:1,s=void 0!==t.rotateWithView&&t.rotateWithView;super({opacity:e,rotation:i,scale:n,displacement:void 0!==t.displacement?t.displacement:[0,0],rotateWithView:s,declutterMode:t.declutterMode}),this.anchor_=void 0!==t.anchor?t.anchor:[.5,.5],this.normalizedAnchor_=null,this.anchorOrigin_=void 0!==t.anchorOrigin?t.anchorOrigin:"top-left",this.anchorXUnits_=void 0!==t.anchorXUnits?t.anchorXUnits:"fraction",this.anchorYUnits_=void 0!==t.anchorYUnits?t.anchorYUnits:"fraction",this.crossOrigin_=void 0!==t.crossOrigin?t.crossOrigin:null;const u=void 0!==t.img?t.img:null;let d,p=t.src;if((0,a.v)(!(void 0!==p&&u),"`image` and `src` cannot be provided at the same time"),void 0!==p&&0!==p.length||!u||(p=u.src||(0,h.v6)(u)),(0,a.v)(void 0!==p&&p.length>0,"A defined and non-empty `src` or `image` must be provided"),(0,a.v)(!((void 0!==t.width||void 0!==t.height)&&void 0!==t.scale),"`width` or `height` cannot be provided together with `scale`"),void 0!==t.src?d=r.A.IDLE:void 0!==u&&(d="complete"in u?u.complete?u.src?r.A.LOADED:r.A.IDLE:r.A.LOADING:r.A.LOADED),this.color_=void 0!==t.color?(0,o._j)(t.color):null,this.iconImage_=(0,l.J)(u,p,this.crossOrigin_,d,this.color_),this.offset_=void 0!==t.offset?t.offset:[0,0],this.offsetOrigin_=void 0!==t.offsetOrigin?t.offsetOrigin:"top-left",this.origin_=null,this.size_=void 0!==t.size?t.size:null,this.initialOptions_,void 0!==t.width||void 0!==t.height){let e,i;if(t.size)[e,i]=t.size;else{const n=this.getImage(1);if(n.width&&n.height)e=n.width,i=n.height;else if(n instanceof HTMLImageElement){this.initialOptions_=t;const e=()=>{if(this.unlistenImageChange(e),!this.initialOptions_)return;const i=this.iconImage_.getSize();this.setScale(c(i[0],i[1],t.width,t.height))};return void this.listenImageChange(e)}}void 0!==e&&this.setScale(c(e,i,t.width,t.height))}}clone(){let t,e,i;return this.initialOptions_?(e=this.initialOptions_.width,i=this.initialOptions_.height):(t=this.getScale(),t=Array.isArray(t)?t.slice():t),new u({anchor:this.anchor_.slice(),anchorOrigin:this.anchorOrigin_,anchorXUnits:this.anchorXUnits_,anchorYUnits:this.anchorYUnits_,color:this.color_&&this.color_.slice?this.color_.slice():this.color_||void 0,crossOrigin:this.crossOrigin_,offset:this.offset_.slice(),offsetOrigin:this.offsetOrigin_,opacity:this.getOpacity(),rotateWithView:this.getRotateWithView(),rotation:this.getRotation(),scale:t,width:e,height:i,size:null!==this.size_?this.size_.slice():void 0,src:this.getSrc(),displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()})}getAnchor(){let t=this.normalizedAnchor_;if(!t){t=this.anchor_;const e=this.getSize();if("fraction"==this.anchorXUnits_||"fraction"==this.anchorYUnits_){if(!e)return null;t=this.anchor_.slice(),"fraction"==this.anchorXUnits_&&(t[0]*=e[0]),"fraction"==this.anchorYUnits_&&(t[1]*=e[1])}if("top-left"!=this.anchorOrigin_){if(!e)return null;t===this.anchor_&&(t=this.anchor_.slice()),"top-right"!=this.anchorOrigin_&&"bottom-right"!=this.anchorOrigin_||(t[0]=-t[0]+e[0]),"bottom-left"!=this.anchorOrigin_&&"bottom-right"!=this.anchorOrigin_||(t[1]=-t[1]+e[1])}this.normalizedAnchor_=t}const e=this.getDisplacement(),i=this.getScaleArray();return[t[0]-e[0]/i[0],t[1]+e[1]/i[1]]}setAnchor(t){this.anchor_=t,this.normalizedAnchor_=null}getColor(){return this.color_}getImage(t){return this.iconImage_.getImage(t)}getPixelRatio(t){return this.iconImage_.getPixelRatio(t)}getImageSize(){return this.iconImage_.getSize()}getImageState(){return this.iconImage_.getImageState()}getHitDetectionImage(){return this.iconImage_.getHitDetectionImage()}getOrigin(){if(this.origin_)return this.origin_;let t=this.offset_;if("top-left"!=this.offsetOrigin_){const e=this.getSize(),i=this.iconImage_.getSize();if(!e||!i)return null;t=t.slice(),"top-right"!=this.offsetOrigin_&&"bottom-right"!=this.offsetOrigin_||(t[0]=i[0]-e[0]-t[0]),"bottom-left"!=this.offsetOrigin_&&"bottom-right"!=this.offsetOrigin_||(t[1]=i[1]-e[1]-t[1])}return this.origin_=t,this.origin_}getSrc(){return this.iconImage_.getSrc()}getSize(){return this.size_?this.size_:this.iconImage_.getSize()}getWidth(){const t=this.getScaleArray();return this.size_?this.size_[0]*t[0]:this.iconImage_.getImageState()==r.A.LOADED?this.iconImage_.getSize()[0]*t[0]:void 0}getHeight(){const t=this.getScaleArray();return this.size_?this.size_[1]*t[1]:this.iconImage_.getImageState()==r.A.LOADED?this.iconImage_.getSize()[1]*t[1]:void 0}setScale(t){delete this.initialOptions_,super.setScale(t)}listenImageChange(t){this.iconImage_.addEventListener(n.A.CHANGE,t)}load(){this.iconImage_.load()}unlistenImageChange(t){this.iconImage_.removeEventListener(n.A.CHANGE,t)}ready(){return this.iconImage_.ready()}}const d=u},7907:(t,e,i)=>{"use strict";i.d(e,{J:()=>d});var n=i(9332),r=i(6837),s=i(6141),o=i(3730),a=i(8711),l=i(3938),h=i(2241);let c=null;class u extends n.A{constructor(t,e,i,n,r){super(),this.hitDetectionImage_=null,this.image_=t,this.crossOrigin_=i,this.canvas_={},this.color_=r,this.imageState_=void 0===n?s.A.IDLE:n,this.size_=t&&t.width&&t.height?[t.width,t.height]:null,this.src_=e,this.tainted_,this.ready_=null}initializeImage_(){this.image_=new Image,null!==this.crossOrigin_&&(this.image_.crossOrigin=this.crossOrigin_)}isTainted_(){if(void 0===this.tainted_&&this.imageState_===s.A.LOADED){c||(c=(0,a.Y)(1,1,void 0,{willReadFrequently:!0})),c.drawImage(this.image_,0,0);try{c.getImageData(0,0,1,1),this.tainted_=!1}catch(t){c=null,this.tainted_=!0}}return!0===this.tainted_}dispatchChangeEvent_(){this.dispatchEvent(r.A.CHANGE)}handleImageError_(){this.imageState_=s.A.ERROR,this.dispatchChangeEvent_()}handleImageLoad_(){this.imageState_=s.A.LOADED,this.size_=[this.image_.width,this.image_.height],this.dispatchChangeEvent_()}getImage(t){return this.image_||this.initializeImage_(),this.replaceColor_(t),this.canvas_[t]?this.canvas_[t]:this.image_}getPixelRatio(t){return this.replaceColor_(t),this.canvas_[t]?t:1}getImageState(){return this.imageState_}getHitDetectionImage(){if(this.image_||this.initializeImage_(),!this.hitDetectionImage_)if(this.isTainted_()){const t=this.size_[0],e=this.size_[1],i=(0,a.Y)(t,e);i.fillRect(0,0,t,e),this.hitDetectionImage_=i.canvas}else this.hitDetectionImage_=this.image_;return this.hitDetectionImage_}getSize(){return this.size_}getSrc(){return this.src_}load(){if(this.imageState_===s.A.IDLE){this.image_||this.initializeImage_(),this.imageState_=s.A.LOADING;try{void 0!==this.src_&&(this.image_.src=this.src_)}catch(t){this.handleImageError_()}this.image_ instanceof HTMLImageElement&&(0,l.RA)(this.image_,this.src_).then((t=>{this.image_=t,this.handleImageLoad_()})).catch(this.handleImageError_.bind(this))}}replaceColor_(t){if(!this.color_||this.canvas_[t]||this.imageState_!==s.A.LOADED)return;const e=this.image_,i=document.createElement("canvas");i.width=Math.ceil(e.width*t),i.height=Math.ceil(e.height*t);const n=i.getContext("2d");n.scale(t,t),n.drawImage(e,0,0),n.globalCompositeOperation="multiply",n.fillStyle=(0,o.oJ)(this.color_),n.fillRect(0,0,i.width/t,i.height/t),n.globalCompositeOperation="destination-in",n.drawImage(e,0,0),this.canvas_[t]=i}ready(){return this.ready_||(this.ready_=new Promise((t=>{if(this.imageState_===s.A.LOADED||this.imageState_===s.A.ERROR)t();else{const e=()=>{this.imageState_!==s.A.LOADED&&this.imageState_!==s.A.ERROR||(this.removeEventListener(r.A.CHANGE,e),t())};this.addEventListener(r.A.CHANGE,e)}}))),this.ready_}}function d(t,e,i,n,r,s){let o=void 0===e?void 0:h.ue.get(e,i,r);return o||(o=new u(t,t&&"src"in t?t.src||void 0:e,i,n,r),h.ue.set(e,i,r,o,s)),s&&o&&!h.ue.getPattern(e,i,r)&&h.ue.set(e,i,r,o,s),o}},2241:(t,e,i)=>{"use strict";i.d(e,{ue:()=>a});var n=i(6141),r=i(3730),s=i(8711);function o(t,e,i){return e+":"+t+":"+(i?(0,r._j)(i):"null")}const a=new class{constructor(){this.cache_={},this.patternCache_={},this.cacheSize_=0,this.maxCacheSize_=32}clear(){this.cache_={},this.patternCache_={},this.cacheSize_=0}canExpireCache(){return this.cacheSize_>this.maxCacheSize_}expire(){if(this.canExpireCache()){let t=0;for(const e in this.cache_){const i=this.cache_[e];0!=(3&t++)||i.hasListener()||(delete this.cache_[e],delete this.patternCache_[e],--this.cacheSize_)}}}get(t,e,i){const n=o(t,e,i);return n in this.cache_?this.cache_[n]:null}getPattern(t,e,i){const n=o(t,e,i);return n in this.patternCache_?this.patternCache_[n]:null}set(t,e,i,r,a){const l=o(t,e,i),h=l in this.cache_;this.cache_[l]=r,a&&(r.getImageState()===n.A.IDLE&&r.load(),r.getImageState()===n.A.LOADING?r.ready().then((()=>{this.patternCache_[l]=(0,s.lr)().createPattern(r.getImage(1),"repeat")})):this.patternCache_[l]=(0,s.lr)().createPattern(r.getImage(1),"repeat")),h||++this.cacheSize_}setSize(t){this.maxCacheSize_=t,this.expire()}}},940:(t,e,i)=>{"use strict";i.d(e,{A:()=>o});var n=i(4087),r=i(6782);class s{constructor(t){this.opacity_=t.opacity,this.rotateWithView_=t.rotateWithView,this.rotation_=t.rotation,this.scale_=t.scale,this.scaleArray_=(0,r.xq)(t.scale),this.displacement_=t.displacement,this.declutterMode_=t.declutterMode}clone(){const t=this.getScale();return new s({opacity:this.getOpacity(),scale:Array.isArray(t)?t.slice():t,rotation:this.getRotation(),rotateWithView:this.getRotateWithView(),displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()})}getOpacity(){return this.opacity_}getRotateWithView(){return this.rotateWithView_}getRotation(){return this.rotation_}getScale(){return this.scale_}getScaleArray(){return this.scaleArray_}getDisplacement(){return this.displacement_}getDeclutterMode(){return this.declutterMode_}getAnchor(){return(0,n.b0)()}getImage(t){return(0,n.b0)()}getHitDetectionImage(){return(0,n.b0)()}getPixelRatio(t){return 1}getImageState(){return(0,n.b0)()}getImageSize(){return(0,n.b0)()}getOrigin(){return(0,n.b0)()}getSize(){return(0,n.b0)()}setDisplacement(t){this.displacement_=t}setOpacity(t){this.opacity_=t}setRotateWithView(t){this.rotateWithView_=t}setRotation(t){this.rotation_=t}setScale(t){this.scale_=t,this.scaleArray_=(0,r.xq)(t)}listenImageChange(t){(0,n.b0)()}load(){(0,n.b0)()}unlistenImageChange(t){(0,n.b0)()}ready(){return Promise.resolve()}}const o=s},6936:(t,e,i)=>{"use strict";i.d(e,{A:()=>c});var n=i(6141),r=i(940),s=i(3730),o=i(7295),a=i(8711),l=i(8774);class h extends r.A{constructor(t){super({opacity:1,rotateWithView:void 0!==t.rotateWithView&&t.rotateWithView,rotation:void 0!==t.rotation?t.rotation:0,scale:void 0!==t.scale?t.scale:1,displacement:void 0!==t.displacement?t.displacement:[0,0],declutterMode:t.declutterMode}),this.canvases_,this.hitDetectionCanvas_=null,this.fill_=void 0!==t.fill?t.fill:null,this.origin_=[0,0],this.points_=t.points,this.radius=t.radius,this.radius2_=t.radius2,this.angle_=void 0!==t.angle?t.angle:0,this.stroke_=void 0!==t.stroke?t.stroke:null,this.size_,this.renderOptions_,this.imageState_=this.fill_&&this.fill_.loading()?n.A.LOADING:n.A.LOADED,this.imageState_===n.A.LOADING&&this.ready().then((()=>this.imageState_=n.A.LOADED)),this.render()}clone(){const t=this.getScale(),e=new h({fill:this.getFill()?this.getFill().clone():void 0,points:this.getPoints(),radius:this.getRadius(),radius2:this.getRadius2(),angle:this.getAngle(),stroke:this.getStroke()?this.getStroke().clone():void 0,rotation:this.getRotation(),rotateWithView:this.getRotateWithView(),scale:Array.isArray(t)?t.slice():t,displacement:this.getDisplacement().slice(),declutterMode:this.getDeclutterMode()});return e.setOpacity(this.getOpacity()),e}getAnchor(){const t=this.size_,e=this.getDisplacement(),i=this.getScaleArray();return[t[0]/2-e[0]/i[0],t[1]/2+e[1]/i[1]]}getAngle(){return this.angle_}getFill(){return this.fill_}setFill(t){this.fill_=t,this.render()}getHitDetectionImage(){return this.hitDetectionCanvas_||(this.hitDetectionCanvas_=this.createHitDetectionCanvas_(this.renderOptions_)),this.hitDetectionCanvas_}getImage(t){let e=this.canvases_[t];if(!e){const i=this.renderOptions_,n=(0,a.Y)(i.size*t,i.size*t);this.draw_(i,n,t),e=n.canvas,this.canvases_[t]=e}return e}getPixelRatio(t){return t}getImageSize(){return this.size_}getImageState(){return this.imageState_}getOrigin(){return this.origin_}getPoints(){return this.points_}getRadius(){return this.radius}getRadius2(){return this.radius2_}getSize(){return this.size_}getStroke(){return this.stroke_}setStroke(t){this.stroke_=t,this.render()}listenImageChange(t){}load(){}unlistenImageChange(t){}calculateLineJoinSize_(t,e,i){if(0===e||this.points_===1/0||"bevel"!==t&&"miter"!==t)return e;let n=this.radius,r=void 0===this.radius2_?n:this.radius2_;if(n{"use strict";i.d(e,{A:()=>r});class n{constructor(t){t=t||{},this.color_=void 0!==t.color?t.color:null,this.lineCap_=t.lineCap,this.lineDash_=void 0!==t.lineDash?t.lineDash:null,this.lineDashOffset_=t.lineDashOffset,this.lineJoin_=t.lineJoin,this.miterLimit_=t.miterLimit,this.width_=t.width}clone(){const t=this.getColor();return new n({color:Array.isArray(t)?t.slice():t||void 0,lineCap:this.getLineCap(),lineDash:this.getLineDash()?this.getLineDash().slice():void 0,lineDashOffset:this.getLineDashOffset(),lineJoin:this.getLineJoin(),miterLimit:this.getMiterLimit(),width:this.getWidth()})}getColor(){return this.color_}getLineCap(){return this.lineCap_}getLineDash(){return this.lineDash_}getLineDashOffset(){return this.lineDashOffset_}getLineJoin(){return this.lineJoin_}getMiterLimit(){return this.miterLimit_}getWidth(){return this.width_}setColor(t){this.color_=t}setLineCap(t){this.lineCap_=t}setLineDash(t){this.lineDash_=t}setLineDashOffset(t){this.lineDashOffset_=t}setLineJoin(t){this.lineJoin_=t}setMiterLimit(t){this.miterLimit_=t}setWidth(t){this.width_=t}}const r=n},9276:(t,e,i)=>{"use strict";i.d(e,{Ay:()=>d,d1:()=>c,mC:()=>l});var n=i(7733),r=i(3628),s=i(953),o=i(588);class a{constructor(t){t=t||{},this.geometry_=null,this.geometryFunction_=u,void 0!==t.geometry&&this.setGeometry(t.geometry),this.fill_=void 0!==t.fill?t.fill:null,this.image_=void 0!==t.image?t.image:null,this.renderer_=void 0!==t.renderer?t.renderer:null,this.hitDetectionRenderer_=void 0!==t.hitDetectionRenderer?t.hitDetectionRenderer:null,this.stroke_=void 0!==t.stroke?t.stroke:null,this.text_=void 0!==t.text?t.text:null,this.zIndex_=t.zIndex}clone(){let t=this.getGeometry();return t&&"object"==typeof t&&(t=t.clone()),new a({geometry:t??void 0,fill:this.getFill()?this.getFill().clone():void 0,image:this.getImage()?this.getImage().clone():void 0,renderer:this.getRenderer()??void 0,stroke:this.getStroke()?this.getStroke().clone():void 0,text:this.getText()?this.getText().clone():void 0,zIndex:this.getZIndex()})}getRenderer(){return this.renderer_}setRenderer(t){this.renderer_=t}setHitDetectionRenderer(t){this.hitDetectionRenderer_=t}getHitDetectionRenderer(){return this.hitDetectionRenderer_}getGeometry(){return this.geometry_}getGeometryFunction(){return this.geometryFunction_}getFill(){return this.fill_}setFill(t){this.fill_=t}getImage(){return this.image_}setImage(t){this.image_=t}getStroke(){return this.stroke_}setStroke(t){this.stroke_=t}getText(){return this.text_}setText(t){this.text_=t}getZIndex(){return this.zIndex_}setGeometry(t){"function"==typeof t?this.geometryFunction_=t:"string"==typeof t?this.geometryFunction_=function(e){return e.get(t)}:t?void 0!==t&&(this.geometryFunction_=function(){return t}):this.geometryFunction_=u,this.geometry_=t}setZIndex(t){this.zIndex_=t}}function l(t){let e;if("function"==typeof t)e=t;else{let i;Array.isArray(t)?i=t:((0,o.v)("function"==typeof t.getZIndex,"Expected an `Style` or an array of `Style`"),i=[t]),e=function(){return i}}return e}let h=null;function c(t,e){if(!h){const t=new r.A({color:"rgba(255,255,255,0.4)"}),e=new s.A({color:"#3399CC",width:1.25});h=[new a({image:new n.A({fill:t,stroke:e,radius:5}),fill:t,stroke:e})]}return h}function u(t){return t.getGeometry()}const d=a},1426:(t,e,i)=>{"use strict";i.d(e,{A:()=>o});var n=i(3628),r=i(6782);class s{constructor(t){t=t||{},this.font_=t.font,this.rotation_=t.rotation,this.rotateWithView_=t.rotateWithView,this.scale_=t.scale,this.scaleArray_=(0,r.xq)(void 0!==t.scale?t.scale:1),this.text_=t.text,this.textAlign_=t.textAlign,this.justify_=t.justify,this.repeat_=t.repeat,this.textBaseline_=t.textBaseline,this.fill_=void 0!==t.fill?t.fill:new n.A({color:"#333"}),this.maxAngle_=void 0!==t.maxAngle?t.maxAngle:Math.PI/4,this.placement_=void 0!==t.placement?t.placement:"point",this.overflow_=!!t.overflow,this.stroke_=void 0!==t.stroke?t.stroke:null,this.offsetX_=void 0!==t.offsetX?t.offsetX:0,this.offsetY_=void 0!==t.offsetY?t.offsetY:0,this.backgroundFill_=t.backgroundFill?t.backgroundFill:null,this.backgroundStroke_=t.backgroundStroke?t.backgroundStroke:null,this.padding_=void 0===t.padding?null:t.padding,this.declutterMode_=t.declutterMode}clone(){const t=this.getScale();return new s({font:this.getFont(),placement:this.getPlacement(),repeat:this.getRepeat(),maxAngle:this.getMaxAngle(),overflow:this.getOverflow(),rotation:this.getRotation(),rotateWithView:this.getRotateWithView(),scale:Array.isArray(t)?t.slice():t,text:this.getText(),textAlign:this.getTextAlign(),justify:this.getJustify(),textBaseline:this.getTextBaseline(),fill:this.getFill()?this.getFill().clone():void 0,stroke:this.getStroke()?this.getStroke().clone():void 0,offsetX:this.getOffsetX(),offsetY:this.getOffsetY(),backgroundFill:this.getBackgroundFill()?this.getBackgroundFill().clone():void 0,backgroundStroke:this.getBackgroundStroke()?this.getBackgroundStroke().clone():void 0,padding:this.getPadding()||void 0,declutterMode:this.getDeclutterMode()})}getOverflow(){return this.overflow_}getFont(){return this.font_}getMaxAngle(){return this.maxAngle_}getPlacement(){return this.placement_}getRepeat(){return this.repeat_}getOffsetX(){return this.offsetX_}getOffsetY(){return this.offsetY_}getFill(){return this.fill_}getRotateWithView(){return this.rotateWithView_}getRotation(){return this.rotation_}getScale(){return this.scale_}getScaleArray(){return this.scaleArray_}getStroke(){return this.stroke_}getText(){return this.text_}getTextAlign(){return this.textAlign_}getJustify(){return this.justify_}getTextBaseline(){return this.textBaseline_}getBackgroundFill(){return this.backgroundFill_}getBackgroundStroke(){return this.backgroundStroke_}getPadding(){return this.padding_}getDeclutterMode(){return this.declutterMode_}setOverflow(t){this.overflow_=t}setFont(t){this.font_=t}setMaxAngle(t){this.maxAngle_=t}setOffsetX(t){this.offsetX_=t}setOffsetY(t){this.offsetY_=t}setPlacement(t){this.placement_=t}setRepeat(t){this.repeat_=t}setRotateWithView(t){this.rotateWithView_=t}setFill(t){this.fill_=t}setRotation(t){this.rotation_=t}setScale(t){this.scale_=t,this.scaleArray_=(0,r.xq)(void 0!==t?t:1)}setStroke(t){this.stroke_=t}setText(t){this.text_=t}setTextAlign(t){this.textAlign_=t}setJustify(t){this.justify_=t}setTextBaseline(t){this.textBaseline_=t}setBackgroundFill(t){this.backgroundFill_=t}setBackgroundStroke(t){this.backgroundStroke_=t}setPadding(t){this.padding_=t}}const o=s},186:(t,e,i)=>{"use strict";function n(t,e,i,n){return void 0!==n?(n[0]=t,n[1]=e,n[2]=i,n):[t,e,i]}function r(t,e,i){return t+"/"+e+"/"+i}function s(t){return r(t[0],t[1],t[2])}function o(t){const[e,i,n]=t.substring(t.lastIndexOf("/")+1,t.length).split(",").map(Number);return r(e,i,n)}function a(t){return t.split("/").map(Number)}function l(t){return e=t[0],(t[1]<i||i>e.getMaxZoom())return!1;const s=e.getFullTileRange(i);return!s||s.containsXY(n,r)}i.d(e,{K:()=>a,N:()=>n,N5:()=>h,dp:()=>r,gr:()=>o,i7:()=>s,tW:()=>l})},7115:(t,e,i)=>{"use strict";i.d(e,{L:()=>n,R:()=>r});const n=42,r=256},9703:(t,e,i)=>{"use strict";i.d(e,{Bb:()=>c,T9:()=>f,Tl:()=>d,Zz:()=>p,cL:()=>o,dI:()=>m,hs:()=>u,k3:()=>h,lw:()=>a,vt:()=>s});var n=i(588);const r=new Array(6);function s(){return[1,0,0,1,0,0]}function o(t){return l(t,1,0,0,1,0,0)}function a(t,e){const i=t[0],n=t[1],r=t[2],s=t[3],o=t[4],a=t[5],l=e[0],h=e[1],c=e[2],u=e[3],d=e[4],p=e[5];return t[0]=i*l+r*h,t[1]=n*l+s*h,t[2]=i*c+r*u,t[3]=n*c+s*u,t[4]=i*d+r*p+o,t[5]=n*d+s*p+a,t}function l(t,e,i,n,r,s,o){return t[0]=e,t[1]=i,t[2]=n,t[3]=r,t[4]=s,t[5]=o,t}function h(t,e){return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[4]=e[4],t[5]=e[5],t}function c(t,e){const i=e[0],n=e[1];return e[0]=t[0]*i+t[2]*n+t[4],e[1]=t[1]*i+t[3]*n+t[5],e}function u(t,e,i){return a(t,l(r,e,0,0,i,0,0))}function d(t,e,i){return a(t,l(r,1,0,0,1,e,i))}function p(t,e,i,n,r,s,o,a){const l=Math.sin(s),h=Math.cos(s);return t[0]=n*h,t[1]=r*l,t[2]=-n*l,t[3]=r*h,t[4]=o*n*h-a*n*l+e,t[5]=o*r*l+a*r*h+i,t}function f(t,e){const i=(r=e)[0]*r[3]-r[1]*r[2];var r;(0,n.v)(0!==i,"Transformation matrix cannot be inverted");const s=e[0],o=e[1],a=e[2],l=e[3],h=e[4],c=e[5];return t[0]=l/i,t[1]=-o/i,t[2]=-a/i,t[3]=s/i,t[4]=(a*c-l*h)/i,t[5]=-(s*c-o*h)/i,t}const g=[1e6,1e6,1e6,1e6,2,2];function m(t){return"matrix("+t.map(((t,e)=>Math.round(t*g[e])/g[e])).join(", ")+")"}},4087:(t,e,i)=>{"use strict";function n(){throw new Error("Unimplemented abstract method.")}i.d(e,{b0:()=>n,v6:()=>s});let r=0;function s(t){return t.ol_uid||(t.ol_uid=String(++r))}},48:(t,e,i)=>{"use strict";function n(t,e,i,n,s){r(t,e,i||0,n||t.length-1,s||o)}function r(t,e,i,n,o){for(;n>i;){if(n-i>600){var a=n-i+1,l=e-i+1,h=Math.log(a),c=.5*Math.exp(2*h/3),u=.5*Math.sqrt(h*c*(a-c)/a)*(l-a/2<0?-1:1);r(t,e,Math.max(i,Math.floor(e-l*c/a+u)),Math.min(n,Math.floor(e+(a-l)*c/a+u)),o)}var d=t[e],p=i,f=n;for(s(t,i,e),o(t[n],d)>0&&s(t,i,n);p0;)f--}0===o(t[i],d)?s(t,i,f):s(t,++f,n),f<=e&&(i=f+1),e<=f&&(n=f-1)}}function s(t,e,i){var n=t[e];t[e]=t[i],t[i]=n}function o(t,e){return te?1:0}i.d(e,{A:()=>a});class a{constructor(t=9){this._maxEntries=Math.max(4,t),this._minEntries=Math.max(2,Math.ceil(.4*this._maxEntries)),this.clear()}all(){return this._all(this.data,[])}search(t){let e=this.data;const i=[];if(!_(t,e))return i;const n=this.toBBox,r=[];for(;e;){for(let s=0;s=0&&r[e].children.length>this._maxEntries;)this._split(r,e),e--;this._adjustParentBBoxes(n,r,e)}_split(t,e){const i=t[e],n=i.children.length,r=this._minEntries;this._chooseSplitAxis(i,r,n);const s=this._chooseSplitIndex(i,r,n),o=v(i.children.splice(s,i.children.length-s));o.height=i.height,o.leaf=i.leaf,h(i,this.toBBox),h(o,this.toBBox),e?t[e-1].children.push(o):this._splitRoot(i,o)}_splitRoot(t,e){this.data=v([t,e]),this.data.height=t.height+1,this.data.leaf=!1,h(this.data,this.toBBox)}_chooseSplitIndex(t,e,i){let n,r=1/0,s=1/0;for(let o=e;o<=i-e;o++){const e=c(t,0,o,this.toBBox),a=c(t,o,i,this.toBBox),l=m(e,a),h=f(e)+f(a);l=e;n--){const e=t.children[n];u(o,t.leaf?r(e):e),a+=g(o)}return a}_adjustParentBBoxes(t,e,i){for(let n=i;n>=0;n--)u(e[n],t)}_condense(t){for(let e,i=t.length-1;i>=0;i--)0===t[i].children.length?i>0?(e=t[i-1].children,e.splice(e.indexOf(t[i]),1)):this.clear():h(t[i],this.toBBox)}}function l(t,e,i){if(!i)return e.indexOf(t);for(let n=0;n=t.minX&&e.maxY>=t.minY}function v(t){return{children:t,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function x(t,e,i,r,s){const o=[e,i];for(;o.length;){if((i=o.pop())-(e=o.pop())<=r)continue;const a=e+Math.ceil((i-e)/r/2)*r;n(t,a,e,i,s),o.push(e,a,a,i)}}},316:(t,e,i)=>{"use strict";i.d(e,{Bb:()=>ao,V5:()=>Hs,AV:()=>Bs,Ay:()=>ao,QD:()=>ho,mt:()=>Rn});var n={};i.r(n),i.d(n,{array:()=>Ut,color:()=>Kt,number:()=>Vt});var r=i(7733),s=i(3628),o=i(9700),a=i(4778),l=i(953),h=i(9276),c=i(1426),u=i(4238),d=i(8959);class p{constructor(t,e,i,n=1){this.r=t,this.g=e,this.b=i,this.a=n}static parse(t){if(!t)return;if(t instanceof p)return t;if("string"!=typeof t)return;const e=(0,d.M)(t);return e?new p(e[0]/255*e[3],e[1]/255*e[3],e[2]/255*e[3],e[3]):void 0}toString(){const[t,e,i,n]=this.toArray();return`rgba(${Math.round(t)},${Math.round(e)},${Math.round(i)},${n})`}toArray(){const{r:t,g:e,b:i,a:n}=this;return 0===n?[0,0,0,0]:[255*t/n,255*e/n,255*i/n,n]}toArray01(){const{r:t,g:e,b:i,a:n}=this;return 0===n?[0,0,0,0]:[t/n,e/n,i/n,n]}toArray01PremultipliedAlpha(){const{r:t,g:e,b:i,a:n}=this;return[t,e,i,n]}}p.black=new p(0,0,0,1),p.white=new p(1,1,1,1),p.transparent=new p(0,0,0,0),p.red=new p(1,0,0,1),p.blue=new p(0,0,1,1);const f=p;var g=i(6889);function m(t){return"object"==typeof t?["literal",t]:t}function y(t){switch(t.colorSpace){case"hcl":return"interpolate-hcl";case"lab":return"interpolate-lab";default:return"interpolate"}}function _(t,e){const i=m((n=t.default,r=e.default,void 0!==n?n:void 0!==r?r:void 0));var n,r;return void 0===i&&"resolvedImage"===e.type?"":i}function v(t,e,i){const n=w(t,e),r=["get",t.property];if("categorical"===n&&"boolean"==typeof i[0][0]){g(t.stops.length>0&&t.stops.length<=2);const n=["case"];for(const t of i)n.push(["==",r,t[0]],t[1]);return n.push(_(t,e)),n}if("categorical"===n){const n=["match",r];for(const t of i)b(n,t[0],t[1],!1);return n.push(_(t,e)),n}if("interval"===n){const e=["step",["number",r]];for(const t of i)b(e,t[0],t[1],!0);return x(e),void 0===t.default?e:["case",["==",["typeof",r],"number"],e,m(t.default)]}if("exponential"===n){const e=void 0!==t.base?t.base:1,n=[y(t),1===e?["linear"]:["exponential",e],["number",r]];for(const t of i)b(n,t[0],t[1],!1);return void 0===t.default?n:["case",["==",["typeof",r],"number"],n,m(t.default)]}throw new Error(`Unknown property function type ${n}`)}function x(t){"step"===t[0]&&3===t.length&&(t.push(0),t.push(t[3]))}function b(t,e,i,n){t.length>3&&e===t[t.length-2]||(n&&2===t.length||t.push(e),t.push(i))}function w(t,e){return t.type?t.type:(g(e.expression),e.expression.interpolated?"exponential":"interval")}function A(t){const e=["concat"],i=/{([^{}]+)}/g;let n=0;for(let r=i.exec(t);null!==r;r=i.exec(t)){const s=t.slice(n,i.lastIndex-r[0].length);n=i.lastIndex,s.length>0&&e.push(s),e.push(["get",r[1]])}if(1===e.length)return t;if(n`:"value"===t.itemType.kind?"array":`array<${e}>`}return t.kind}const G=[R,I,k,M,P,D,L,z(F),j];function q(t,e){if("error"===e.kind)return null;if("array"===t.kind){if("array"===e.kind&&(0===e.N&&"value"===e.itemType.kind||!q(t.itemType,e.itemType))&&("number"!=typeof t.N||t.N===e.N))return null}else{if(t.kind===e.kind)return null;if("value"===t.kind)for(const t of G)if(!q(t,e))return null}return`Expected ${N(t)} but found ${N(e)} instead.`}function W(t,e){return e.some((e=>e.kind===t.kind))}function Y(t,e){return e.some((e=>"null"===e?null===t:"array"===e?Array.isArray(t):"object"===e?t&&!Array.isArray(t)&&"object"==typeof t:e===typeof t))}class X{constructor(t,e,i){this.sensitivity=t?e?"variant":"case":e?"accent":"base",this.locale=i,this.collator=new Intl.Collator(this.locale?this.locale:[],{sensitivity:this.sensitivity,usage:"search"})}compare(t,e){return this.collator.compare(t,e)}resolvedLocale(){return new Intl.Collator(this.locale?this.locale:[]).resolvedOptions().locale}}class V{constructor(t,e,i,n,r){this.text=t.normalize?t.normalize():t,this.image=e,this.scale=i,this.fontStack=n,this.textColor=r}}class K{constructor(t){this.sections=t}static fromString(t){return new K([new V(t,null,null,null,null)])}isEmpty(){return 0===this.sections.length||!this.sections.some((t=>0!==t.text.length||t.image&&0!==t.image.name.length))}static factory(t){return t instanceof K?t:K.fromString(t)}toString(){return 0===this.sections.length?"":this.sections.map((t=>t.text)).join("")}serialize(){const t=["format"];for(const e of this.sections){if(e.image){t.push(["image",e.image.name]);continue}t.push(e.text);const i={};e.fontStack&&(i["text-font"]=["literal",e.fontStack.split(",")]),e.scale&&(i["font-scale"]=e.scale),e.textColor&&(i["text-color"]=["rgba"].concat(e.textColor.toArray())),t.push(i)}return t}}class U{constructor(t){this.name=t.name,this.available=t.available}toString(){return this.name}static fromString(t){return t?new U({name:t,available:!1}):null}serialize(){return["image",this.name]}}function B(t,e,i,n){return"number"==typeof t&&t>=0&&t<=255&&"number"==typeof e&&e>=0&&e<=255&&"number"==typeof i&&i>=0&&i<=255?void 0===n||"number"==typeof n&&n>=0&&n<=1?null:`Invalid rgba value [${[t,e,i,n].join(", ")}]: 'a' must be between 0 and 1.`:`Invalid rgba value [${("number"==typeof n?[t,e,i,n]:[t,e,i]).join(", ")}]: 'r', 'g', and 'b' must be between 0 and 255.`}function Z(t){if(null===t)return!0;if("string"==typeof t)return!0;if("boolean"==typeof t)return!0;if("number"==typeof t)return!0;if(t instanceof f)return!0;if(t instanceof X)return!0;if(t instanceof K)return!0;if(t instanceof U)return!0;if(Array.isArray(t)){for(const e of t)if(!Z(e))return!1;return!0}if("object"==typeof t){for(const e in t)if(!Z(t[e]))return!1;return!0}return!1}function H(t){if(null===t)return R;if("string"==typeof t)return k;if("boolean"==typeof t)return M;if("number"==typeof t)return I;if(t instanceof f)return P;if(t instanceof X)return O;if(t instanceof K)return D;if(t instanceof U)return j;if(Array.isArray(t)){const e=t.length;let i;for(const e of t){const t=H(e);if(i){if(i===t)continue;i=F;break}i=t}return z(i||F,e)}return g("object"==typeof t),L}function $(t){const e=typeof t;return null===t?"":"string"===e||"number"===e||"boolean"===e?String(t):t instanceof f||t instanceof K||t instanceof U?t.toString():JSON.stringify(t)}class J{constructor(t,e){this.type=t,this.value=e}static parse(t,e){if(2!==t.length)return e.error(`'literal' expression requires exactly one argument, but found ${t.length-1} instead.`);if(!Z(t[1]))return e.error("invalid value");const i=t[1];let n=H(i);const r=e.expectedType;return"array"!==n.kind||0!==n.N||!r||"array"!==r.kind||"number"==typeof r.N&&0!==r.N||(n=r),new J(n,i)}evaluate(){return this.value}eachChild(){}outputDefined(){return!0}serialize(){return"array"===this.type.kind||"object"===this.type.kind?["literal",this.value]:this.value instanceof f?["rgba"].concat(this.value.toArray()):this.value instanceof K?this.value.serialize():(g(null===this.value||"string"==typeof this.value||"number"==typeof this.value||"boolean"==typeof this.value),this.value)}}const Q=J,tt=class{constructor(t){this.name="ExpressionEvaluationError",this.message=t}toJSON(){return this.message}},et={string:k,number:I,boolean:M,object:L};class it{constructor(t,e){this.type=t,this.args=e}static parse(t,e){if(t.length<2)return e.error("Expected at least one argument.");let i,n=1;const r=t[0];if("array"===r){let r,s;if(t.length>2){const i=t[1];if("string"!=typeof i||!(i in et)||"object"===i)return e.error('The item type argument of "array" must be one of string, number, boolean',1);r=et[i],n++}else r=F;if(t.length>3){if(null!==t[2]&&("number"!=typeof t[2]||t[2]<0||t[2]!==Math.floor(t[2])))return e.error('The length argument to "array" must be a positive integer literal',2);s=t[2],n++}i=z(r,s)}else g(et[r],r),i=et[r];const s=[];for(;nt.outputDefined()))}serialize(){const t=this.type,e=[t.kind];if("array"===t.kind){const i=t.itemType;if("string"===i.kind||"number"===i.kind||"boolean"===i.kind){e.push(i.kind);const n=t.N;("number"==typeof n||this.args.length>1)&&e.push(n)}}return e.concat(this.args.map((t=>t.serialize())))}}const nt=it;class rt{constructor(t){this.type=D,this.sections=t}static parse(t,e){if(t.length<2)return e.error("Expected at least one argument.");const i=t[1];if(!Array.isArray(i)&&"object"==typeof i)return e.error("First argument must be an image or text section.");const n=[];let r=!1;for(let i=1;i<=t.length-1;++i){const s=t[i];if(r&&"object"==typeof s&&!Array.isArray(s)){r=!1;let t=null;if(s["font-scale"]&&(t=e.parse(s["font-scale"],1,I),!t))return null;let i=null;if(s["text-font"]&&(i=e.parse(s["text-font"],1,z(k)),!i))return null;let o=null;if(s["text-color"]&&(o=e.parse(s["text-color"],1,P),!o))return null;const a=n[n.length-1];a.scale=t,a.font=i,a.textColor=o}else{const s=e.parse(t[i],1,F);if(!s)return null;const o=s.type.kind;if("string"!==o&&"value"!==o&&"null"!==o&&"resolvedImage"!==o)return e.error("Formatted text type must be 'string', 'value', 'image' or 'null'.");r=!0,n.push({content:s,scale:null,font:null,textColor:null})}}return new rt(n)}evaluate(t){return new K(this.sections.map((e=>{const i=e.content.evaluate(t);return H(i)===j?new V("",i,null,null,null):new V($(i),null,e.scale?e.scale.evaluate(t):null,e.font?e.font.evaluate(t).join(","):null,e.textColor?e.textColor.evaluate(t):null)})))}eachChild(t){for(const e of this.sections)t(e.content),e.scale&&t(e.scale),e.font&&t(e.font),e.textColor&&t(e.textColor)}outputDefined(){return!1}serialize(){const t=["format"];for(const e of this.sections){t.push(e.content.serialize());const i={};e.scale&&(i["font-scale"]=e.scale.serialize()),e.font&&(i["text-font"]=e.font.serialize()),e.textColor&&(i["text-color"]=e.textColor.serialize()),t.push(i)}return t}}class st{constructor(t){this.type=j,this.input=t}static parse(t,e){if(2!==t.length)return e.error("Expected two arguments.");const i=e.parse(t[1],1,k);return i?new st(i):e.error("No image name provided.")}evaluate(t){const e=this.input.evaluate(t),i=U.fromString(e);return i&&t.availableImages&&(i.available=t.availableImages.indexOf(e)>-1),i}eachChild(t){t(this.input)}outputDefined(){return!1}serialize(){return["image",this.input.serialize()]}}const ot={"to-boolean":M,"to-color":P,"to-number":I,"to-string":k};class at{constructor(t,e){this.type=t,this.args=e}static parse(t,e){if(t.length<2)return e.error("Expected at least one argument.");const i=t[0];if(g(ot[i],i),("to-boolean"===i||"to-string"===i)&&2!==t.length)return e.error("Expected one argument.");const n=ot[i],r=[];for(let i=1;i4?`Invalid rbga value ${JSON.stringify(e)}: expected an array containing either three or four numeric values.`:B(e[0],e[1],e[2],e[3]),!i))return new f(e[0]/255,e[1]/255,e[2]/255,e[3])}throw new tt(i||`Could not parse color from value '${"string"==typeof e?e:String(JSON.stringify(e))}'`)}if("number"===this.type.kind){let e=null;for(const i of this.args){if(e=i.evaluate(t),null===e)return 0;const n=Number(e);if(!isNaN(n))return n}throw new tt(`Could not convert ${JSON.stringify(e)} to number.`)}return"formatted"===this.type.kind?K.fromString($(this.args[0].evaluate(t))):"resolvedImage"===this.type.kind?U.fromString($(this.args[0].evaluate(t))):$(this.args[0].evaluate(t))}eachChild(t){this.args.forEach(t)}outputDefined(){return this.args.every((t=>t.outputDefined()))}serialize(){if("formatted"===this.type.kind)return new rt([{content:this.args[0],scale:null,font:null,textColor:null}]).serialize();if("resolvedImage"===this.type.kind)return new st(this.args[0]).serialize();const t=[`to-${this.type.kind}`];return this.eachChild((e=>{t.push(e.serialize())})),t}}const lt=at,ht=["Unknown","Point","LineString","Polygon"],ct=class{constructor(){this.globals=null,this.feature=null,this.featureState=null,this.formattedSection=null,this._parseColorCache={},this.availableImages=null,this.canonical=null,this.featureTileCoord=null,this.featureDistanceData=null}id(){return this.feature&&void 0!==this.feature.id?this.feature.id:null}geometryType(){return this.feature?"number"==typeof this.feature.type?ht[this.feature.type]:this.feature.type:null}geometry(){return this.feature&&"geometry"in this.feature?this.feature.geometry:null}canonicalID(){return this.canonical}properties(){return this.feature&&this.feature.properties||{}}distanceFromCenter(){if(this.featureTileCoord&&this.featureDistanceData){const t=this.featureDistanceData.center,e=this.featureDistanceData.scale,{x:i,y:n}=this.featureTileCoord,r=i*e-t[0],s=n*e-t[1];return this.featureDistanceData.bearing[0]*r+this.featureDistanceData.bearing[1]*s}return 0}parseColor(t){let e=this._parseColorCache[t];return e||(e=this._parseColorCache[t]=f.parse(t)),e}};class ut{constructor(t,e,i,n){this.name=t,this.type=e,this._evaluate=i,this.args=n}evaluate(t){return this._evaluate(t,this.args)}eachChild(t){this.args.forEach(t)}outputDefined(){return!1}serialize(){return[this.name].concat(this.args.map((t=>t.serialize())))}static parse(t,e){const i=t[0],n=ut.definitions[i];if(!n)return e.error(`Unknown expression "${i}". If you wanted a literal array, use ["literal", [...]].`,0);const r=Array.isArray(n)?n[0]:n.type,s=Array.isArray(n)?[[n[1],n[2]]]:n.overloads,o=s.filter((([e])=>!Array.isArray(e)||e.length===t.length-1));let a=null;for(const[n,s]of o){a=new Nt(e.registry,e.path,null,e.scope);const o=[];let l=!1;for(let e=1;e0),1===o.length)e.errors.push(...a.errors);else{const i=(o.length?o:s).map((([t])=>{return e=t,Array.isArray(e)?`(${e.map(N).join(", ")})`:`(${N(e.type)}...)`;var e})).join(" | "),n=[];for(let i=1;i=e[2]||t[1]<=e[1]||t[3]>=e[3])}function yt(t,e){const i=(180+t[0])/360,n=(r=t[1],(180-180/Math.PI*Math.log(Math.tan(Math.PI/4+r*Math.PI/360)))/360);var r;const s=Math.pow(2,e.z);return[Math.round(i*s*ft),Math.round(n*s*ft)]}function _t(t,e,i){const n=t[0]-e[0],r=t[1]-e[1],s=t[0]-i[0],o=t[1]-i[1];return n*o-s*r==0&&n*s<=0&&r*o<=0}function vt(t,e){let i=!1;for(let o=0,a=e.length;on[1]!=s[1]>n[1]&&n[0]<(s[0]-r[0])*(n[1]-r[1])/(s[1]-r[1])+r[0]&&(i=!i)}}var n,r,s;return i}function xt(t,e){for(let i=0;i0&&u<0||c<0&&u>0}function wt(t,e,i,n){const r=[e[0]-t[0],e[1]-t[1]];return 0!=(s=[n[0]-i[0],n[1]-i[1]])[0]*(o=r)[1]-s[1]*o[0]&&!(!bt(t,e,i,n)||!bt(i,n,t,e));var s,o}function At(t,e,i){for(const n of i)for(let i=0;ii[2]){const e=.5*n;let r=t[0]-i[0]>e?-n:i[0]-t[0]>e?n:0;0===r&&(r=t[0]-i[2]>e?-n:i[2]-t[0]>e?n:0),t[0]+=r}gt(e,t)}function It(t,e,i,n){const r=Math.pow(2,n.z)*ft,s=[n.x*ft,n.y*ft],o=[];if(!t)return o;for(const n of t)for(const t of n){const n=[t.x+s[0],t.y+s[1]];Rt(n,e,i,r),o.push(n)}return o}function kt(t,e,i,n){const r=Math.pow(2,n.z)*ft,s=[n.x*ft,n.y*ft],o=[];if(!t)return o;for(const i of t){const t=[];for(const n of i){const i=[n.x+s[0],n.y+s[1]];gt(e,i),t.push(i)}o.push(t)}if(e[2]-e[0]<=r/2){(a=e)[0]=a[1]=1/0,a[2]=a[3]=-1/0;for(const t of o)for(const n of t)Rt(n,e,i,r)}var a;return o}class Mt{constructor(t,e){this.type=M,this.geojson=t,this.geometries=e}static parse(t,e){if(2!==t.length)return e.error(`'within' expression requires exactly one argument, but found ${t.length-1} instead.`);if(Z(t[1])){const e=t[1];if("FeatureCollection"===e.type)for(let t=0;t{e&&!Lt(t)&&(e=!1)})),e}function Ft(t){if(t instanceof dt&&"feature-state"===t.name)return!1;let e=!0;return t.eachChild((t=>{e&&!Ft(t)&&(e=!1)})),e}function Ot(t,e){if(t instanceof dt&&e.indexOf(t.name)>=0)return!1;let i=!0;return t.eachChild((t=>{i&&!Ot(t,e)&&(i=!1)})),i}class Dt{constructor(t,e){this.type=e.type,this.name=t,this.boundExpression=e}static parse(t,e){if(2!==t.length||"string"!=typeof t[1])return e.error("'var' expression requires exactly one string literal argument.");const i=t[1];return e.scope.has(i)?new Dt(i,e.scope.get(i)):e.error(`Unknown variable "${i}". Make sure "${i}" has been bound in an enclosing "let" expression before using it.`,1)}evaluate(t){return this.boundExpression.evaluate(t)}eachChild(){}outputDefined(){return!1}serialize(){return["var",this.name]}}const jt=Dt;class zt{constructor(t,e=[],i,n=new T,r=[]){this.registry=t,this.path=e,this.key=e.map((t=>`[${t}]`)).join(""),this.scope=n,this.errors=r,this.expectedType=i}parse(t,e,i,n,r={}){return e?this.concat(e,i,n)._parse(t,r):this._parse(t,r)}_parse(t,e){function i(t,e,i){return"assert"===i?new nt(e,[t]):"coerce"===i?new lt(e,[t]):t}if(null!==t&&"string"!=typeof t&&"boolean"!=typeof t&&"number"!=typeof t||(t=["literal",t]),Array.isArray(t)){if(0===t.length)return this.error('Expected an array with at least one element. If you wanted a literal array, use ["literal", []].');const n=t[0];if("string"!=typeof n)return this.error(`Expression name must be a string, but found ${typeof n} instead. If you wanted a literal array, use ["literal", [...]].`,0),null;const r=this.registry[n];if(r){let n=r.parse(t,this);if(!n)return null;if(this.expectedType){const t=this.expectedType,r=n.type;if("string"!==t.kind&&"number"!==t.kind&&"boolean"!==t.kind&&"object"!==t.kind&&"array"!==t.kind||"value"!==r.kind)if("color"!==t.kind&&"formatted"!==t.kind&&"resolvedImage"!==t.kind||"value"!==r.kind&&"string"!==r.kind){if(this.checkSubtype(t,r))return null}else n=i(n,t,e.typeAnnotation||"coerce");else n=i(n,t,e.typeAnnotation||"assert")}if(!(n instanceof Q)&&"resolvedImage"!==n.type.kind&&Gt(n)){const t=new ct;try{n=new Q(n.type,n.evaluate(t))}catch(t){return this.error(t.message),null}}return n}return this.error(`Unknown expression "${n}". If you wanted a literal array, use ["literal", [...]].`,0)}return void 0===t?this.error("'undefined' value invalid. Use null instead."):"object"==typeof t?this.error('Bare objects invalid. Use ["literal", {...}] instead.'):this.error(`Expected an array, but found ${typeof t} instead.`)}concat(t,e,i){const n="number"==typeof t?this.path.concat(t):this.path,r=i?this.scope.concat(i):this.scope;return new zt(this.registry,n,e||null,r,this.errors)}error(t,...e){const i=`${this.key}${e.map((t=>`[${t}]`)).join("")}`;this.errors.push(new C(i,t))}checkSubtype(t,e){const i=q(t,e);return i&&this.error(i),i}}const Nt=zt;function Gt(t){if(t instanceof jt)return Gt(t.boundExpression);if(t instanceof dt&&"error"===t.name)return!1;if(t instanceof pt)return!1;if(t instanceof Pt)return!1;const e=t instanceof lt||t instanceof nt;let i=!0;return t.eachChild((t=>{i=e?i&&Gt(t):i&&t instanceof Q})),!!i&&Lt(t)&&Ot(t,["zoom","heatmap-density","line-progress","sky-radial-progress","accumulated","is-supported-script","pitch","distance-from-center"])}function qt(t,e){const i=t.length-1;let n,r,s=0,o=i,a=0;for(;s<=o;)if(a=Math.floor((s+o)/2),n=t[a],r=t[a+1],n<=e){if(a===i||ee))throw new tt("Input is not a number.");o=a-1}return 0}class Wt{constructor(t,e,i){this.type=t,this.input=e,this.labels=[],this.outputs=[];for(const[t,e]of i)this.labels.push(t),this.outputs.push(e)}static parse(t,e){if(t.length-1<4)return e.error(`Expected at least 4 arguments, but found only ${t.length-1}.`);if((t.length-1)%2!=0)return e.error("Expected an even number of arguments.");const i=e.parse(t[1],1,I);if(!i)return null;const n=[];let r=null;e.expectedType&&"value"!==e.expectedType.kind&&(r=e.expectedType);for(let i=1;i=s)return e.error('Input/output pairs for "step" expressions must be arranged with input values in strictly ascending order.',a);const h=e.parse(o,l,r);if(!h)return null;r=r||h.type,n.push([s,h])}return new Wt(r,i,n)}evaluate(t){const e=this.labels,i=this.outputs;if(1===e.length)return i[0].evaluate(t);const n=this.input.evaluate(t);if(n<=e[0])return i[0].evaluate(t);const r=e.length;return n>=e[r-1]?i[r-1].evaluate(t):i[qt(e,n)].evaluate(t)}eachChild(t){t(this.input);for(const e of this.outputs)t(e)}outputDefined(){return this.outputs.every((t=>t.outputDefined()))}serialize(){const t=["step",this.input.serialize()];for(let e=0;e0&&t.push(this.labels[e]),t.push(this.outputs[e].serialize());return t}}const Yt=Wt;var Xt=i(5380);function Vt(t,e,i){return t*(1-i)+e*i}function Kt(t,e,i){return new f(Vt(t.r,e.r,i),Vt(t.g,e.g,i),Vt(t.b,e.b,i),Vt(t.a,e.a,i))}function Ut(t,e,i){return t.map(((t,n)=>Vt(t,e[n],i)))}const Bt=.95047,Zt=1.08883,Ht=4/29,$t=6/29,Jt=3*$t*$t,Qt=$t*$t*$t,te=Math.PI/180,ee=180/Math.PI;function ie(t){return t>Qt?Math.pow(t,1/3):t/Jt+Ht}function ne(t){return t>$t?t*t*t:Jt*(t-Ht)}function re(t){return 255*(t<=.0031308?12.92*t:1.055*Math.pow(t,1/2.4)-.055)}function se(t){return(t/=255)<=.04045?t/12.92:Math.pow((t+.055)/1.055,2.4)}function oe(t){const e=se(t.r),i=se(t.g),n=se(t.b),r=ie((.4124564*e+.3575761*i+.1804375*n)/Bt),s=ie((.2126729*e+.7151522*i+.072175*n)/1);return{l:116*s-16,a:500*(r-s),b:200*(s-ie((.0193339*e+.119192*i+.9503041*n)/Zt)),alpha:t.a}}function ae(t){let e=(t.l+16)/116,i=isNaN(t.a)?e:e+t.a/500,n=isNaN(t.b)?e:e-t.b/200;return e=1*ne(e),i=Bt*ne(i),n=Zt*ne(n),new f(re(3.2404542*i-1.5371385*e-.4985314*n),re(-.969266*i+1.8760108*e+.041556*n),re(.0556434*i-.2040259*e+1.0572252*n),t.alpha)}function le(t,e,i){const n=e-t;return t+i*(n>180||n<-180?n-360*Math.round(n/360):n)}const he={forward:oe,reverse:ae,interpolate:function(t,e,i){return{l:Vt(t.l,e.l,i),a:Vt(t.a,e.a,i),b:Vt(t.b,e.b,i),alpha:Vt(t.alpha,e.alpha,i)}}},ce=function(t){const{l:e,a:i,b:n}=oe(t),r=Math.atan2(n,i)*ee;return{h:r<0?r+360:r,c:Math.sqrt(i*i+n*n),l:e,alpha:t.a}},ue=function(t){const e=t.h*te,i=t.c;return ae({l:t.l,a:Math.cos(e)*i,b:Math.sin(e)*i,alpha:t.alpha})},de=function(t,e,i){return{h:le(t.h,e.h,i),c:Vt(t.c,e.c,i),l:Vt(t.l,e.l,i),alpha:Vt(t.alpha,e.alpha,i)}};class pe{constructor(t,e,i,n,r){this.type=t,this.operator=e,this.interpolation=i,this.input=n,this.labels=[],this.outputs=[];for(const[t,e]of r)this.labels.push(t),this.outputs.push(e)}static interpolationFactor(t,e,i,n){let r=0;if("exponential"===t.name)r=fe(e,t.base,i,n);else if("linear"===t.name)r=fe(e,1,i,n);else if("cubic-bezier"===t.name){const s=t.controlPoints;r=new Xt(s[0],s[1],s[2],s[3]).solve(fe(e,1,i,n))}return r}static parse(t,e){let[i,n,r,...s]=t;if(!Array.isArray(n)||0===n.length)return e.error("Expected an interpolation type expression.",1);if("linear"===n[0])n={name:"linear"};else if("exponential"===n[0]){const t=n[1];if("number"!=typeof t)return e.error("Exponential interpolation requires a numeric base.",1,1);n={name:"exponential",base:t}}else{if("cubic-bezier"!==n[0])return e.error(`Unknown interpolation type ${String(n[0])}`,1,0);{const t=n.slice(1);if(4!==t.length||t.some((t=>"number"!=typeof t||t<0||t>1)))return e.error("Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.",1);n={name:"cubic-bezier",controlPoints:t}}}if(t.length-1<4)return e.error(`Expected at least 4 arguments, but found only ${t.length-1}.`);if((t.length-1)%2!=0)return e.error("Expected an even number of arguments.");if(r=e.parse(r,2,I),!r)return null;const o=[];let a=null;"interpolate-hcl"===i||"interpolate-lab"===i?a=P:e.expectedType&&"value"!==e.expectedType.kind&&(a=e.expectedType);for(let t=0;t=i)return e.error('Input/output pairs for "interpolate" expressions must be arranged with input values in strictly ascending order.',r);const h=e.parse(n,l,a);if(!h)return null;a=a||h.type,o.push([i,h])}return"number"===a.kind||"color"===a.kind||"array"===a.kind&&"number"===a.itemType.kind&&"number"==typeof a.N?new pe(a,i,n,r,o):e.error(`Type ${N(a)} is not interpolatable.`)}evaluate(t){const e=this.labels,i=this.outputs;if(1===e.length)return i[0].evaluate(t);const r=this.input.evaluate(t);if(r<=e[0])return i[0].evaluate(t);const s=e.length;if(r>=e[s-1])return i[s-1].evaluate(t);const o=qt(e,r),a=e[o],l=e[o+1],h=pe.interpolationFactor(this.interpolation,r,a,l),c=i[o].evaluate(t),u=i[o+1].evaluate(t);return"interpolate"===this.operator?n[this.type.kind.toLowerCase()](c,u,h):"interpolate-hcl"===this.operator?ue(de(ce(c),ce(u),h)):he.reverse(he.interpolate(he.forward(c),he.forward(u),h))}eachChild(t){t(this.input);for(const e of this.outputs)t(e)}outputDefined(){return this.outputs.every((t=>t.outputDefined()))}serialize(){let t;t="linear"===this.interpolation.name?["linear"]:"exponential"===this.interpolation.name?1===this.interpolation.base?["linear"]:["exponential",this.interpolation.base]:["cubic-bezier"].concat(this.interpolation.controlPoints);const e=[this.operator,t,this.input.serialize()];for(let t=0;tq(n,t.type)));return new me(s?F:i,r)}evaluate(t){let e,i=null,n=0;for(const r of this.args){if(n++,i=r.evaluate(t),i&&i instanceof U&&!i.available&&(e||(e=i),i=null,n===this.args.length))return e;if(null!==i)break}return i}eachChild(t){this.args.forEach(t)}outputDefined(){return this.args.every((t=>t.outputDefined()))}serialize(){const t=["coalesce"];return this.eachChild((e=>{t.push(e.serialize())})),t}}const ye=me;class _e{constructor(t,e){this.type=e.type,this.bindings=[].concat(t),this.result=e}evaluate(t){return this.result.evaluate(t)}eachChild(t){for(const e of this.bindings)t(e[1]);t(this.result)}static parse(t,e){if(t.length<4)return e.error(`Expected at least 3 arguments, but found ${t.length-1} instead.`);const i=[];for(let n=1;n=i.length)throw new tt(`Array index out of bounds: ${e} > ${i.length-1}.`);if(e!==Math.floor(e))throw new tt(`Array index must be an integer, but found ${e} instead.`);return i[e]}eachChild(t){t(this.index),t(this.input)}outputDefined(){return!1}serialize(){return["at",this.index.serialize(),this.input.serialize()]}}const be=xe;class we{constructor(t,e){this.type=M,this.needle=t,this.haystack=e}static parse(t,e){if(3!==t.length)return e.error(`Expected 2 arguments, but found ${t.length-1} instead.`);const i=e.parse(t[1],1,F),n=e.parse(t[2],2,F);return i&&n?W(i.type,[M,k,I,R,F])?new we(i,n):e.error(`Expected first argument to be of type boolean, string, number or null, but found ${N(i.type)} instead`):null}evaluate(t){const e=this.needle.evaluate(t),i=this.haystack.evaluate(t);if(null==i)return!1;if(!Y(e,["boolean","string","number","null"]))throw new tt(`Expected first argument to be of type boolean, string, number or null, but found ${N(H(e))} instead.`);if(!Y(i,["string","array"]))throw new tt(`Expected second argument to be of type array or string, but found ${N(H(i))} instead.`);return i.indexOf(e)>=0}eachChild(t){t(this.needle),t(this.haystack)}outputDefined(){return!0}serialize(){return["in",this.needle.serialize(),this.haystack.serialize()]}}const Ae=we;class Ee{constructor(t,e,i){this.type=I,this.needle=t,this.haystack=e,this.fromIndex=i}static parse(t,e){if(t.length<=2||t.length>=5)return e.error(`Expected 3 or 4 arguments, but found ${t.length-1} instead.`);const i=e.parse(t[1],1,F),n=e.parse(t[2],2,F);if(!i||!n)return null;if(!W(i.type,[M,k,I,R,F]))return e.error(`Expected first argument to be of type boolean, string, number or null, but found ${N(i.type)} instead`);if(4===t.length){const r=e.parse(t[3],3,I);return r?new Ee(i,n,r):null}return new Ee(i,n)}evaluate(t){const e=this.needle.evaluate(t),i=this.haystack.evaluate(t);if(!Y(e,["boolean","string","number","null"]))throw new tt(`Expected first argument to be of type boolean, string, number or null, but found ${N(H(e))} instead.`);if(!Y(i,["string","array"]))throw new tt(`Expected second argument to be of type array or string, but found ${N(H(i))} instead.`);if(this.fromIndex){const n=this.fromIndex.evaluate(t);return i.indexOf(e,n)}return i.indexOf(e)}eachChild(t){t(this.needle),t(this.haystack),this.fromIndex&&t(this.fromIndex)}outputDefined(){return!1}serialize(){if(null!=this.fromIndex&&void 0!==this.fromIndex){const t=this.fromIndex.serialize();return["index-of",this.needle.serialize(),this.haystack.serialize(),t]}return["index-of",this.needle.serialize(),this.haystack.serialize()]}}const Ce=Ee;class Se{constructor(t,e,i,n,r,s){this.inputType=t,this.type=e,this.input=i,this.cases=n,this.outputs=r,this.otherwise=s}static parse(t,e){if(t.length<5)return e.error(`Expected at least 4 arguments, but found only ${t.length-1}.`);if(t.length%2!=1)return e.error("Expected an even number of arguments.");let i,n;e.expectedType&&"value"!==e.expectedType.kind&&(n=e.expectedType);const r={},s=[];for(let o=2;oNumber.MAX_SAFE_INTEGER)return h.error(`Branch labels must be integers no larger than ${Number.MAX_SAFE_INTEGER}.`);if("number"==typeof t&&Math.floor(t)!==t)return h.error("Numeric branch labels must be integer values.");if(i){if(h.checkSubtype(i,H(t)))return null}else i=H(t);if(void 0!==r[String(t)])return h.error("Branch labels must be unique.");r[String(t)]=s.length}const c=e.parse(l,o,n);if(!c)return null;n=n||c.type,s.push(c)}const o=e.parse(t[1],1,F);if(!o)return null;const a=e.parse(t[t.length-1],t.length-1,n);return a?(g(i&&n),"value"!==o.type.kind&&e.concat(1).checkSubtype(i,o.type)?null:new Se(i,n,o,r,s,a)):null}evaluate(t){const e=this.input.evaluate(t);return(H(e)===this.inputType&&this.outputs[this.cases[e]]||this.otherwise).evaluate(t)}eachChild(t){t(this.input),this.outputs.forEach(t),t(this.otherwise)}outputDefined(){return this.outputs.every((t=>t.outputDefined()))&&this.otherwise.outputDefined()}serialize(){const t=["match",this.input.serialize()],e=Object.keys(this.cases).sort(),i=[],n={};for(const t of e){const e=n[this.cases[t]];void 0===e?(n[this.cases[t]]=i.length,i.push([this.cases[t],[t]])):i[e][1].push(t)}const r=t=>"number"===this.inputType.kind?Number(t):t;for(const[e,n]of i)1===n.length?t.push(r(n[0])):t.push(n.map(r)),t.push(this.outputs[e].serialize());return t.push(this.otherwise.serialize()),t}}const Te=Se;class Re{constructor(t,e,i){this.type=t,this.branches=e,this.otherwise=i}static parse(t,e){if(t.length<4)return e.error(`Expected at least 3 arguments, but found only ${t.length-1}.`);if(t.length%2!=0)return e.error("Expected an odd number of arguments.");let i;e.expectedType&&"value"!==e.expectedType.kind&&(i=e.expectedType);const n=[];for(let r=1;re.outputDefined()))&&this.otherwise.outputDefined()}serialize(){const t=["case"];return this.eachChild((e=>{t.push(e.serialize())})),t}}const Ie=Re;class ke{constructor(t,e,i,n){this.type=t,this.input=e,this.beginIndex=i,this.endIndex=n}static parse(t,e){if(t.length<=2||t.length>=5)return e.error(`Expected 3 or 4 arguments, but found ${t.length-1} instead.`);const i=e.parse(t[1],1,F),n=e.parse(t[2],2,I);if(!i||!n)return null;if(!W(i.type,[z(F),k,F]))return e.error(`Expected first argument to be of type array or string, but found ${N(i.type)} instead`);if(4===t.length){const r=e.parse(t[3],3,I);return r?new ke(i.type,i,n,r):null}return new ke(i.type,i,n)}evaluate(t){const e=this.input.evaluate(t),i=this.beginIndex.evaluate(t);if(!Y(e,["string","array"]))throw new tt(`Expected first argument to be of type array or string, but found ${N(H(e))} instead.`);if(this.endIndex){const n=this.endIndex.evaluate(t);return e.slice(i,n)}return e.slice(i)}eachChild(t){t(this.input),t(this.beginIndex),this.endIndex&&t(this.endIndex)}outputDefined(){return!1}serialize(){if(null!=this.endIndex&&void 0!==this.endIndex){const t=this.endIndex.serialize();return["slice",this.input.serialize(),this.beginIndex.serialize(),t]}return["slice",this.input.serialize(),this.beginIndex.serialize()]}}const Me=ke;function Pe(t,e){return"=="===t||"!="===t?"boolean"===e.kind||"string"===e.kind||"number"===e.kind||"null"===e.kind||"value"===e.kind:"string"===e.kind||"number"===e.kind||"value"===e.kind}function Le(t,e,i,n){return 0===n.compare(e,i)}function Fe(t,e,i){const n="=="!==t&&"!="!==t;return class r{constructor(t,e,i){this.type=M,this.lhs=t,this.rhs=e,this.collator=i,this.hasUntypedArgument="value"===t.type.kind||"value"===e.type.kind}static parse(t,e){if(3!==t.length&&4!==t.length)return e.error("Expected two or three arguments.");const i=t[0];let s=e.parse(t[1],1,F);if(!s)return null;if(!Pe(i,s.type))return e.concat(1).error(`"${i}" comparisons are not supported for type '${N(s.type)}'.`);let o=e.parse(t[2],2,F);if(!o)return null;if(!Pe(i,o.type))return e.concat(2).error(`"${i}" comparisons are not supported for type '${N(o.type)}'.`);if(s.type.kind!==o.type.kind&&"value"!==s.type.kind&&"value"!==o.type.kind)return e.error(`Cannot compare types '${N(s.type)}' and '${N(o.type)}'.`);n&&("value"===s.type.kind&&"value"!==o.type.kind?s=new nt(o.type,[s]):"value"!==s.type.kind&&"value"===o.type.kind&&(o=new nt(s.type,[o])));let a=null;if(4===t.length){if("string"!==s.type.kind&&"string"!==o.type.kind&&"value"!==s.type.kind&&"value"!==o.type.kind)return e.error("Cannot use collator to compare non-string types.");if(a=e.parse(t[3],3,O),!a)return null}return new r(s,o,a)}evaluate(r){const s=this.lhs.evaluate(r),o=this.rhs.evaluate(r);if(n&&this.hasUntypedArgument){const e=H(s),i=H(o);if(e.kind!==i.kind||"string"!==e.kind&&"number"!==e.kind)throw new tt(`Expected arguments for "${t}" to be (string, string) or (number, number), but found (${e.kind}, ${i.kind}) instead.`)}if(this.collator&&!n&&this.hasUntypedArgument){const t=H(s),i=H(o);if("string"!==t.kind||"string"!==i.kind)return e(r,s,o)}return this.collator?i(r,s,o,this.collator.evaluate(r)):e(r,s,o)}eachChild(t){t(this.lhs),t(this.rhs),this.collator&&t(this.collator)}outputDefined(){return!0}serialize(){const e=[t];return this.eachChild((t=>{e.push(t.serialize())})),e}}}const Oe=Fe("==",(function(t,e,i){return e===i}),Le),De=Fe("!=",(function(t,e,i){return e!==i}),(function(t,e,i,n){return!Le(0,e,i,n)})),je=Fe("<",(function(t,e,i){return e",(function(t,e,i){return e>i}),(function(t,e,i,n){return n.compare(e,i)>0})),Ne=Fe("<=",(function(t,e,i){return e<=i}),(function(t,e,i,n){return n.compare(e,i)<=0})),Ge=Fe(">=",(function(t,e,i){return e>=i}),(function(t,e,i,n){return n.compare(e,i)>=0}));class qe{constructor(t,e,i,n,r,s){this.type=k,this.number=t,this.locale=e,this.currency=i,this.unit=n,this.minFractionDigits=r,this.maxFractionDigits=s}static parse(t,e){if(3!==t.length)return e.error("Expected two arguments.");const i=e.parse(t[1],1,I);if(!i)return null;const n=t[2];if("object"!=typeof n||Array.isArray(n))return e.error("NumberFormat options argument must be an object.");let r=null;if(n.locale&&(r=e.parse(n.locale,1,k),!r))return null;let s=null;if(n.currency&&(s=e.parse(n.currency,1,k),!s))return null;let o=null;if(n.unit&&(o=e.parse(n.unit,1,k),!o))return null;let a=null;if(n["min-fraction-digits"]&&(a=e.parse(n["min-fraction-digits"],1,I),!a))return null;let l=null;return n["max-fraction-digits"]&&(l=e.parse(n["max-fraction-digits"],1,I),!l)?null:new qe(i,r,s,o,a,l)}evaluate(t){return new Intl.NumberFormat(this.locale?this.locale.evaluate(t):[],{style:(this.currency?"currency":this.unit&&"unit")||"decimal",currency:this.currency?this.currency.evaluate(t):void 0,unit:this.unit?this.unit.evaluate(t):void 0,minimumFractionDigits:this.minFractionDigits?this.minFractionDigits.evaluate(t):void 0,maximumFractionDigits:this.maxFractionDigits?this.maxFractionDigits.evaluate(t):void 0}).format(this.number.evaluate(t))}eachChild(t){t(this.number),this.locale&&t(this.locale),this.currency&&t(this.currency),this.unit&&t(this.unit),this.minFractionDigits&&t(this.minFractionDigits),this.maxFractionDigits&&t(this.maxFractionDigits)}outputDefined(){return!1}serialize(){const t={};return this.locale&&(t.locale=this.locale.serialize()),this.currency&&(t.currency=this.currency.serialize()),this.unit&&(t.unit=this.unit.serialize()),this.minFractionDigits&&(t["min-fraction-digits"]=this.minFractionDigits.serialize()),this.maxFractionDigits&&(t["max-fraction-digits"]=this.maxFractionDigits.serialize()),["number-format",this.number.serialize(),t]}}class We{constructor(t){this.type=I,this.input=t}static parse(t,e){if(2!==t.length)return e.error(`Expected 1 argument, but found ${t.length-1} instead.`);const i=e.parse(t[1],1);return i?"array"!==i.type.kind&&"string"!==i.type.kind&&"value"!==i.type.kind?e.error(`Expected argument of type string or array, but found ${N(i.type)} instead.`):new We(i):null}evaluate(t){const e=this.input.evaluate(t);if("string"==typeof e)return e.length;if(Array.isArray(e))return e.length;throw new tt(`Expected value to be of type string or array, but found ${N(H(e))} instead.`)}eachChild(t){t(this.input)}outputDefined(){return!1}serialize(){const t=["length"];return this.eachChild((e=>{t.push(e.serialize())})),t}}const Ye={"==":Oe,"!=":De,">":ze,"<":je,">=":Ge,"<=":Ne,array:nt,at:be,boolean:nt,case:Ie,coalesce:ye,collator:pt,format:rt,image:st,in:Ae,"index-of":Ce,interpolate:ge,"interpolate-hcl":ge,"interpolate-lab":ge,length:We,let:ve,literal:Q,match:Te,number:nt,"number-format":qe,object:nt,slice:Me,step:Yt,string:nt,"to-boolean":lt,"to-color":lt,"to-number":lt,"to-string":lt,var:jt,within:Pt};function Xe(t,[e,i,n,r]){e=e.evaluate(t),i=i.evaluate(t),n=n.evaluate(t);const s=r?r.evaluate(t):1,o=B(e,i,n,s);if(o)throw new tt(o);return new f(e/255*s,i/255*s,n/255*s,s)}function Ve(t,e){return t in e}function Ke(t,e){const i=e[t];return void 0===i?null:i}function Ue(t){return{type:t}}dt.register(Ye,{error:[{kind:"error"},[k],(t,[e])=>{throw new tt(e.evaluate(t))}],typeof:[k,[F],(t,[e])=>N(H(e.evaluate(t)))],"to-rgba":[z(I,4),[P],(t,[e])=>e.evaluate(t).toArray()],rgb:[P,[I,I,I],Xe],rgba:[P,[I,I,I,I],Xe],has:{type:M,overloads:[[[k],(t,[e])=>Ve(e.evaluate(t),t.properties())],[[k,L],(t,[e,i])=>Ve(e.evaluate(t),i.evaluate(t))]]},get:{type:F,overloads:[[[k],(t,[e])=>Ke(e.evaluate(t),t.properties())],[[k,L],(t,[e,i])=>Ke(e.evaluate(t),i.evaluate(t))]]},"feature-state":[F,[k],(t,[e])=>Ke(e.evaluate(t),t.featureState||{})],properties:[L,[],t=>t.properties()],"geometry-type":[k,[],t=>t.geometryType()],id:[F,[],t=>t.id()],zoom:[I,[],t=>t.globals.zoom],pitch:[I,[],t=>t.globals.pitch||0],"distance-from-center":[I,[],t=>t.distanceFromCenter()],"heatmap-density":[I,[],t=>t.globals.heatmapDensity||0],"line-progress":[I,[],t=>t.globals.lineProgress||0],"sky-radial-progress":[I,[],t=>t.globals.skyRadialProgress||0],accumulated:[F,[],t=>void 0===t.globals.accumulated?null:t.globals.accumulated],"+":[I,Ue(I),(t,e)=>{let i=0;for(const n of e)i+=n.evaluate(t);return i}],"*":[I,Ue(I),(t,e)=>{let i=1;for(const n of e)i*=n.evaluate(t);return i}],"-":{type:I,overloads:[[[I,I],(t,[e,i])=>e.evaluate(t)-i.evaluate(t)],[[I],(t,[e])=>-e.evaluate(t)]]},"/":[I,[I,I],(t,[e,i])=>e.evaluate(t)/i.evaluate(t)],"%":[I,[I,I],(t,[e,i])=>e.evaluate(t)%i.evaluate(t)],ln2:[I,[],()=>Math.LN2],pi:[I,[],()=>Math.PI],e:[I,[],()=>Math.E],"^":[I,[I,I],(t,[e,i])=>Math.pow(e.evaluate(t),i.evaluate(t))],sqrt:[I,[I],(t,[e])=>Math.sqrt(e.evaluate(t))],log10:[I,[I],(t,[e])=>Math.log(e.evaluate(t))/Math.LN10],ln:[I,[I],(t,[e])=>Math.log(e.evaluate(t))],log2:[I,[I],(t,[e])=>Math.log(e.evaluate(t))/Math.LN2],sin:[I,[I],(t,[e])=>Math.sin(e.evaluate(t))],cos:[I,[I],(t,[e])=>Math.cos(e.evaluate(t))],tan:[I,[I],(t,[e])=>Math.tan(e.evaluate(t))],asin:[I,[I],(t,[e])=>Math.asin(e.evaluate(t))],acos:[I,[I],(t,[e])=>Math.acos(e.evaluate(t))],atan:[I,[I],(t,[e])=>Math.atan(e.evaluate(t))],min:[I,Ue(I),(t,e)=>Math.min(...e.map((e=>e.evaluate(t))))],max:[I,Ue(I),(t,e)=>Math.max(...e.map((e=>e.evaluate(t))))],abs:[I,[I],(t,[e])=>Math.abs(e.evaluate(t))],round:[I,[I],(t,[e])=>{const i=e.evaluate(t);return i<0?-Math.round(-i):Math.round(i)}],floor:[I,[I],(t,[e])=>Math.floor(e.evaluate(t))],ceil:[I,[I],(t,[e])=>Math.ceil(e.evaluate(t))],"filter-==":[M,[k,F],(t,[e,i])=>t.properties()[e.value]===i.value],"filter-id-==":[M,[F],(t,[e])=>t.id()===e.value],"filter-type-==":[M,[k],(t,[e])=>t.geometryType()===e.value],"filter-<":[M,[k,F],(t,[e,i])=>{const n=t.properties()[e.value],r=i.value;return typeof n==typeof r&&n{const i=t.id(),n=e.value;return typeof i==typeof n&&i":[M,[k,F],(t,[e,i])=>{const n=t.properties()[e.value],r=i.value;return typeof n==typeof r&&n>r}],"filter-id->":[M,[F],(t,[e])=>{const i=t.id(),n=e.value;return typeof i==typeof n&&i>n}],"filter-<=":[M,[k,F],(t,[e,i])=>{const n=t.properties()[e.value],r=i.value;return typeof n==typeof r&&n<=r}],"filter-id-<=":[M,[F],(t,[e])=>{const i=t.id(),n=e.value;return typeof i==typeof n&&i<=n}],"filter->=":[M,[k,F],(t,[e,i])=>{const n=t.properties()[e.value],r=i.value;return typeof n==typeof r&&n>=r}],"filter-id->=":[M,[F],(t,[e])=>{const i=t.id(),n=e.value;return typeof i==typeof n&&i>=n}],"filter-has":[M,[F],(t,[e])=>e.value in t.properties()],"filter-has-id":[M,[],t=>null!==t.id()&&void 0!==t.id()],"filter-type-in":[M,[z(k)],(t,[e])=>e.value.indexOf(t.geometryType())>=0],"filter-id-in":[M,[z(F)],(t,[e])=>e.value.indexOf(t.id())>=0],"filter-in-small":[M,[k,z(F)],(t,[e,i])=>i.value.indexOf(t.properties()[e.value])>=0],"filter-in-large":[M,[k,z(F)],(t,[e,i])=>function(t,e,i,n){for(;i<=n;){const r=i+n>>1;if(e[r]===t)return!0;e[r]>t?n=r-1:i=r+1}return!1}(t.properties()[e.value],i.value,0,i.value.length-1)],all:{type:M,overloads:[[[M,M],(t,[e,i])=>e.evaluate(t)&&i.evaluate(t)],[Ue(M),(t,e)=>{for(const i of e)if(!i.evaluate(t))return!1;return!0}]]},any:{type:M,overloads:[[[M,M],(t,[e,i])=>e.evaluate(t)||i.evaluate(t)],[Ue(M),(t,e)=>{for(const i of e)if(i.evaluate(t))return!0;return!1}]]},"!":[M,[M],(t,[e])=>!e.evaluate(t)],"is-supported-script":[M,[k],(t,[e])=>{const i=t.globals&&t.globals.isSupportedScript;return!i||i(e.evaluate(t))}],upcase:[k,[k],(t,[e])=>e.evaluate(t).toUpperCase()],downcase:[k,[k],(t,[e])=>e.evaluate(t).toLowerCase()],concat:[k,Ue(F),(t,e)=>e.map((e=>$(e.evaluate(t)))).join("")],"resolved-locale":[k,[O],(t,[e])=>e.evaluate(t).resolvedLocale()]});const Be=Ye;function Ze(t){return{result:"success",value:t}}function He(t){return{result:"error",value:t}}function $e(t){return"object"==typeof t&&null!==t&&!Array.isArray(t)}class Je{constructor(t,e){var i;this.expression=t,this._warningHistory={},this._evaluator=new ct,this._defaultValue=e?"color"===(i=e).type&&($e(i.default)||Array.isArray(i.default))?new f(0,0,0,0):"color"===i.type?f.parse(i.default)||null:void 0===i.default?null:i.default:null,this._enumValues=e&&"enum"===e.type?e.values:null}evaluateWithoutErrorHandling(t,e,i,n,r,s,o,a){return this._evaluator.globals=t,this._evaluator.feature=e,this._evaluator.featureState=i,this._evaluator.canonical=n||null,this._evaluator.availableImages=r||null,this._evaluator.formattedSection=s,this._evaluator.featureTileCoord=o||null,this._evaluator.featureDistanceData=a||null,this.expression.evaluate(this._evaluator)}evaluate(t,e,i,n,r,s,o,a){this._evaluator.globals=t,this._evaluator.feature=e||null,this._evaluator.featureState=i||null,this._evaluator.canonical=n||null,this._evaluator.availableImages=r||null,this._evaluator.formattedSection=s||null,this._evaluator.featureTileCoord=o||null,this._evaluator.featureDistanceData=a||null;try{const t=this.expression.evaluate(this._evaluator);if(null==t||"number"==typeof t&&t!=t)return this._defaultValue;if(this._enumValues&&!(t in this._enumValues))throw new tt(`Expected value to be one of ${Object.keys(this._enumValues).map((t=>JSON.stringify(t))).join(", ")}, but found ${JSON.stringify(t)} instead.`);return t}catch(t){return this._warningHistory[t.message]||(this._warningHistory[t.message]=!0,"undefined"!=typeof console&&console.warn(t.message)),this._defaultValue}}}function Qe(t,e){const i=new Nt(Be,[],e?function(t){const e={color:P,string:k,number:I,enum:k,boolean:M,formatted:D,resolvedImage:j};return"array"===t.type?z(e[t.value]||F,t.length):e[t.type]}(e):void 0),n=i.parse(t,void 0,void 0,void 0,e&&"string"===e.type?{typeAnnotation:"coerce"}:void 0);return n?Ze(new Je(n,e)):(g(i.errors.length>0),He(i.errors))}class ti{constructor(t,e){this.kind=t,this._styleExpression=e,this.isStateDependent="constant"!==t&&!Ft(e.expression)}evaluateWithoutErrorHandling(t,e,i,n,r,s){return this._styleExpression.evaluateWithoutErrorHandling(t,e,i,n,r,s)}evaluate(t,e,i,n,r,s){return this._styleExpression.evaluate(t,e,i,n,r,s)}}class ei{constructor(t,e,i,n){this.kind=t,this.zoomStops=i,this._styleExpression=e,this.isStateDependent="camera"!==t&&!Ft(e.expression),this.interpolationType=n}evaluateWithoutErrorHandling(t,e,i,n,r,s){return this._styleExpression.evaluateWithoutErrorHandling(t,e,i,n,r,s)}evaluate(t,e,i,n,r,s){return this._styleExpression.evaluate(t,e,i,n,r,s)}interpolationFactor(t,e,i){return this.interpolationType?ge.interpolationFactor(this.interpolationType,t,e,i):0}}function ii(t,e){if("error"===(t=Qe(t,e)).result)return t;const i=t.value.expression,n=Lt(i);if(!n&&"data-driven"!==e["property-type"])return He([new C("","data expressions not supported")]);const r=Ot(i,["zoom","pitch","distance-from-center"]);if(!(r||(s=e,s.expression&&s.expression.parameters.indexOf("zoom")>-1)))return He([new C("","zoom expressions not supported")]);var s;const o=ni(i);if(!o&&!r)return He([new C("",'"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.')]);if(o instanceof C)return He([o]);if(o instanceof ge&&!function(t){return!!t.expression&&t.expression.interpolated}(e))return He([new C("",'"interpolate" expressions cannot be used with this property')]);if(!o)return Ze(new ti(n?"constant":"source",t.value));const a=o instanceof ge?o.interpolation:void 0;return Ze(new ei(n?"camera":"composite",t.value,o.labels,a))}function ni(t){let e=null;if(t instanceof ve)e=ni(t.result);else if(t instanceof ye){for(const i of t.args)if(e=ni(i),e)break}else(t instanceof Yt||t instanceof ge)&&t.input instanceof dt&&"zoom"===t.input.name&&(e=t);return e instanceof C||t.eachChild((t=>{const i=ni(t);i instanceof C?e=i:!e&&i?e=new C("",'"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.'):e&&i&&e!==i&&(e=new C("",'Only one zoom-based "step" or "interpolate" subexpression may be used in an expression.'))})),e}function ri(t){if(Array.isArray(t))return t.map(ri);if(t instanceof Object&&!(t instanceof Number||t instanceof String||t instanceof Boolean)){const e={};for(const i in t)e[i]=ri(t[i]);return e}return function(t){return t instanceof Number||t instanceof String||t instanceof Boolean?t.valueOf():t}(t)}const si=JSON.parse('{"$version":8,"$root":{"version":{"required":true,"type":"enum","values":[8],"doc":"Style specification version number. Must be 8.","example":8},"name":{"type":"string","doc":"A human-readable name for the style.","example":"Bright"},"metadata":{"type":"*","doc":"Arbitrary properties useful to track with the stylesheet, but do not influence rendering. Properties should be prefixed to avoid collisions, like \'mapbox:\'."},"center":{"type":"array","value":"number","doc":"Default map center in longitude and latitude. The style center will be used only if the map has not been positioned by other means (e.g. map options or user interaction).","example":[-73.9749,40.7736]},"zoom":{"type":"number","doc":"Default zoom level. The style zoom will be used only if the map has not been positioned by other means (e.g. map options or user interaction).","example":12.5},"bearing":{"type":"number","default":0,"period":360,"units":"degrees","doc":"Default bearing, in degrees. The bearing is the compass direction that is \\"up\\"; for example, a bearing of 90° orients the map so that east is up. This value will be used only if the map has not been positioned by other means (e.g. map options or user interaction).","example":29},"pitch":{"type":"number","default":0,"units":"degrees","doc":"Default pitch, in degrees. Zero is perpendicular to the surface, for a look straight down at the map, while a greater value like 60 looks ahead towards the horizon. The style pitch will be used only if the map has not been positioned by other means (e.g. map options or user interaction).","example":50},"light":{"type":"light","doc":"The global light source.","example":{"anchor":"viewport","color":"white","intensity":0.4}},"terrain":{"type":"terrain","doc":"A global modifier that elevates layers and markers based on a DEM data source."},"fog":{"type":"fog","doc":"A global effect that fades layers and markers based on their distance to the camera. The fog can be used to approximate the effect of atmosphere on distant objects and enhance the depth perception of the map when used with terrain or 3D features. Note: fog is renamed to atmosphere in the Android and iOS SDKs and planned to be changed in GL-JS v.3.0.0."},"sources":{"required":true,"type":"sources","doc":"Data source specifications.","example":{"mapbox-streets":{"type":"vector","url":"mapbox://mapbox.mapbox-streets-v6"}}},"sprite":{"type":"string","doc":"A base URL for retrieving the sprite image and metadata. The extensions `.png`, `.json` and scale factor `@2x.png` will be automatically appended. This property is required if any layer uses the `background-pattern`, `fill-pattern`, `line-pattern`, `fill-extrusion-pattern`, or `icon-image` properties. The URL must be absolute, containing the [scheme, authority and path components](https://en.wikipedia.org/wiki/URL#Syntax).","example":"mapbox://sprites/mapbox/bright-v8"},"glyphs":{"type":"string","doc":"A URL template for loading signed-distance-field glyph sets in PBF format. The URL must include `{fontstack}` and `{range}` tokens. This property is required if any layer uses the `text-field` layout property. The URL must be absolute, containing the [scheme, authority and path components](https://en.wikipedia.org/wiki/URL#Syntax).","example":"mapbox://fonts/mapbox/{fontstack}/{range}.pbf"},"transition":{"type":"transition","doc":"A global transition definition to use as a default across properties, to be used for timing transitions between one value and the next when no property-specific transition is set. Collision-based symbol fading is controlled independently of the style\'s `transition` property.","example":{"duration":300,"delay":0}},"projection":{"type":"projection","doc":"The projection the map should be rendered in. Supported projections are Mercator, Globe, Albers, Equal Earth, Equirectangular (WGS84), Lambert conformal conic, Natural Earth, and Winkel Tripel. Terrain, sky and fog are supported by only Mercator and globe. CustomLayerInterface is not supported outside of Mercator.","example":{"name":"albers","center":[-154,50],"parallels":[55,65]}},"layers":{"required":true,"type":"array","value":"layer","doc":"Layers will be drawn in the order of this array.","example":[{"id":"water","source":"mapbox-streets","source-layer":"water","type":"fill","paint":{"fill-color":"#00ffff"}}]}},"sources":{"*":{"type":"source","doc":"Specification of a data source. For vector and raster sources, either TileJSON or a URL to a TileJSON must be provided. For image and video sources, a URL must be provided. For GeoJSON sources, a URL or inline GeoJSON must be provided."}},"source":["source_vector","source_raster","source_raster_dem","source_geojson","source_video","source_image"],"source_vector":{"type":{"required":true,"type":"enum","values":{"vector":{"doc":"A vector tile source."}},"doc":"The type of the source."},"url":{"type":"string","doc":"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://`."},"tiles":{"type":"array","value":"string","doc":"An array of one or more tile source URLs, as in the TileJSON spec."},"bounds":{"type":"array","value":"number","length":4,"default":[-180,-85.051129,180,85.051129],"doc":"An array containing the longitude and latitude of the southwest and northeast corners of the source\'s bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."},"scheme":{"type":"enum","values":{"xyz":{"doc":"Slippy map tilenames scheme."},"tms":{"doc":"OSGeo spec scheme."}},"default":"xyz","doc":"Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed."},"minzoom":{"type":"number","default":0,"doc":"Minimum zoom level for which tiles are available, as in the TileJSON spec."},"maxzoom":{"type":"number","default":22,"doc":"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."},"attribution":{"type":"string","doc":"Contains an attribution to be displayed when the map is shown to a user."},"promoteId":{"type":"promoteId","doc":"A property to use as a feature id (for feature state). Either a property name, or an object of the form `{: }`. If specified as a string for a vector tile source, the same property is used across all its source layers. If specified as an object only specified source layers will have id overriden, others will fallback to original feature id"},"volatile":{"type":"boolean","default":false,"doc":"A setting to determine whether a source\'s tiles are cached locally.","sdk-support":{"basic functionality":{"android":"9.3.0","ios":"5.10.0"}}},"*":{"type":"*","doc":"Other keys to configure the data source."}},"source_raster":{"type":{"required":true,"type":"enum","values":{"raster":{"doc":"A raster tile source."}},"doc":"The type of the source."},"url":{"type":"string","doc":"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://`."},"tiles":{"type":"array","value":"string","doc":"An array of one or more tile source URLs, as in the TileJSON spec."},"bounds":{"type":"array","value":"number","length":4,"default":[-180,-85.051129,180,85.051129],"doc":"An array containing the longitude and latitude of the southwest and northeast corners of the source\'s bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."},"minzoom":{"type":"number","default":0,"doc":"Minimum zoom level for which tiles are available, as in the TileJSON spec."},"maxzoom":{"type":"number","default":22,"doc":"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."},"tileSize":{"type":"number","default":512,"units":"pixels","doc":"The minimum visual size to display tiles for this layer. Only configurable for raster layers."},"scheme":{"type":"enum","values":{"xyz":{"doc":"Slippy map tilenames scheme."},"tms":{"doc":"OSGeo spec scheme."}},"default":"xyz","doc":"Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed."},"attribution":{"type":"string","doc":"Contains an attribution to be displayed when the map is shown to a user."},"volatile":{"type":"boolean","default":false,"doc":"A setting to determine whether a source\'s tiles are cached locally.","sdk-support":{"basic functionality":{"android":"9.3.0","ios":"5.10.0"}}},"*":{"type":"*","doc":"Other keys to configure the data source."}},"source_raster_dem":{"type":{"required":true,"type":"enum","values":{"raster-dem":{"doc":"A RGB-encoded raster DEM source"}},"doc":"The type of the source."},"url":{"type":"string","doc":"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://`."},"tiles":{"type":"array","value":"string","doc":"An array of one or more tile source URLs, as in the TileJSON spec."},"bounds":{"type":"array","value":"number","length":4,"default":[-180,-85.051129,180,85.051129],"doc":"An array containing the longitude and latitude of the southwest and northeast corners of the source\'s bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL."},"minzoom":{"type":"number","default":0,"doc":"Minimum zoom level for which tiles are available, as in the TileJSON spec."},"maxzoom":{"type":"number","default":22,"doc":"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels."},"tileSize":{"type":"number","default":512,"units":"pixels","doc":"The minimum visual size to display tiles for this layer. Only configurable for raster layers."},"attribution":{"type":"string","doc":"Contains an attribution to be displayed when the map is shown to a user."},"encoding":{"type":"enum","values":{"terrarium":{"doc":"Terrarium format PNG tiles. See https://aws.amazon.com/es/public-datasets/terrain/ for more info."},"mapbox":{"doc":"Mapbox Terrain RGB tiles. See https://www.mapbox.com/help/access-elevation-data/#mapbox-terrain-rgb for more info."}},"default":"mapbox","doc":"The encoding used by this source. Mapbox Terrain RGB is used by default"},"volatile":{"type":"boolean","default":false,"doc":"A setting to determine whether a source\'s tiles are cached locally.","sdk-support":{"basic functionality":{"android":"9.3.0","ios":"5.10.0"}}},"*":{"type":"*","doc":"Other keys to configure the data source."}},"source_geojson":{"type":{"required":true,"type":"enum","values":{"geojson":{"doc":"A GeoJSON data source."}},"doc":"The data type of the GeoJSON source."},"data":{"type":"*","doc":"A URL to a GeoJSON file, or inline GeoJSON."},"maxzoom":{"type":"number","default":18,"doc":"Maximum zoom level at which to create vector tiles (higher means greater detail at high zoom levels)."},"attribution":{"type":"string","doc":"Contains an attribution to be displayed when the map is shown to a user."},"buffer":{"type":"number","default":128,"maximum":512,"minimum":0,"doc":"Size of the tile buffer on each side. A value of 0 produces no buffer. A value of 512 produces a buffer as wide as the tile itself. Larger values produce fewer rendering artifacts near tile edges and slower performance."},"filter":{"type":"*","doc":"An expression for filtering features prior to processing them for rendering."},"tolerance":{"type":"number","default":0.375,"doc":"Douglas-Peucker simplification tolerance (higher means simpler geometries and faster performance)."},"cluster":{"type":"boolean","default":false,"doc":"If the data is a collection of point features, setting this to true clusters the points by radius into groups. Cluster groups become new `Point` features in the source with additional properties:\\n * `cluster` Is `true` if the point is a cluster \\n * `cluster_id` A unqiue id for the cluster to be used in conjunction with the [cluster inspection methods](https://www.mapbox.com/mapbox-gl-js/api/#geojsonsource#getclusterexpansionzoom)\\n * `point_count` Number of original points grouped into this cluster\\n * `point_count_abbreviated` An abbreviated point count"},"clusterRadius":{"type":"number","default":50,"minimum":0,"doc":"Radius of each cluster if clustering is enabled. A value of 512 indicates a radius equal to the width of a tile."},"clusterMaxZoom":{"type":"number","doc":"Max zoom on which to cluster points if clustering is enabled. Defaults to one zoom less than maxzoom (so that last zoom features are not clustered). Clusters are re-evaluated at integer zoom levels so setting clusterMaxZoom to 14 means the clusters will be displayed until z15."},"clusterMinPoints":{"type":"number","doc":"Minimum number of points necessary to form a cluster if clustering is enabled. Defaults to `2`."},"clusterProperties":{"type":"*","doc":"An object defining custom properties on the generated clusters if clustering is enabled, aggregating values from clustered points. Has the form `{\\"property_name\\": [operator, map_expression]}`. `operator` is any expression function that accepts at least 2 operands (e.g. `\\"+\\"` or `\\"max\\"`) — it accumulates the property value from clusters/points the cluster contains; `map_expression` produces the value of a single point.\\n\\nExample: `{\\"sum\\": [\\"+\\", [\\"get\\", \\"scalerank\\"]]}`.\\n\\nFor more advanced use cases, in place of `operator`, you can use a custom reduce expression that references a special `[\\"accumulated\\"]` value, e.g.:\\n`{\\"sum\\": [[\\"+\\", [\\"accumulated\\"], [\\"get\\", \\"sum\\"]], [\\"get\\", \\"scalerank\\"]]}`"},"lineMetrics":{"type":"boolean","default":false,"doc":"Whether to calculate line distance metrics. This is required for line layers that specify `line-gradient` values."},"generateId":{"type":"boolean","default":false,"doc":"Whether to generate ids for the geojson features. When enabled, the `feature.id` property will be auto assigned based on its index in the `features` array, over-writing any previous values."},"promoteId":{"type":"promoteId","doc":"A property to use as a feature id (for feature state). Either a property name, or an object of the form `{: }`."}},"source_video":{"type":{"required":true,"type":"enum","values":{"video":{"doc":"A video data source."}},"doc":"The data type of the video source."},"urls":{"required":true,"type":"array","value":"string","doc":"URLs to video content in order of preferred format."},"coordinates":{"required":true,"doc":"Corners of video specified in longitude, latitude pairs.","type":"array","length":4,"value":{"type":"array","length":2,"value":"number","doc":"A single longitude, latitude pair."}}},"source_image":{"type":{"required":true,"type":"enum","values":{"image":{"doc":"An image data source."}},"doc":"The data type of the image source."},"url":{"required":true,"type":"string","doc":"URL that points to an image."},"coordinates":{"required":true,"doc":"Corners of image specified in longitude, latitude pairs.","type":"array","length":4,"value":{"type":"array","length":2,"value":"number","doc":"A single longitude, latitude pair."}}},"layer":{"id":{"type":"string","doc":"Unique layer name.","required":true},"type":{"type":"enum","values":{"fill":{"doc":"A filled polygon with an optional stroked border.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}}},"line":{"doc":"A stroked line.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}}},"symbol":{"doc":"An icon or a text label.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}}},"circle":{"doc":"A filled circle.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}}},"heatmap":{"doc":"A heatmap.","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"fill-extrusion":{"doc":"An extruded (3D) polygon.","sdk-support":{"basic functionality":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}}},"raster":{"doc":"Raster map textures such as satellite imagery.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}}},"hillshade":{"doc":"Client-side hillshading visualization based on DEM data. Currently, the implementation only supports Mapbox Terrain RGB and Mapzen Terrarium tiles.","sdk-support":{"basic functionality":{"js":"0.43.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"background":{"doc":"The background color or pattern of the map.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}}},"sky":{"doc":"A spherical dome around the map that is always rendered behind all other layers.","sdk-support":{"basic functionality":{"js":"2.0.0","ios":"10.0.0","android":"10.0.0"}}}},"doc":"Rendering type of this layer.","required":true},"metadata":{"type":"*","doc":"Arbitrary properties useful to track with the layer, but do not influence rendering. Properties should be prefixed to avoid collisions, like \'mapbox:\'."},"source":{"type":"string","doc":"Name of a source description to be used for this layer. Required for all layer types except `background`."},"source-layer":{"type":"string","doc":"Layer to use from a vector tile source. Required for vector tile sources; prohibited for all other source types, including GeoJSON sources."},"minzoom":{"type":"number","minimum":0,"maximum":24,"doc":"The minimum zoom level for the layer. At zoom levels less than the minzoom, the layer will be hidden."},"maxzoom":{"type":"number","minimum":0,"maximum":24,"doc":"The maximum zoom level for the layer. At zoom levels equal to or greater than the maxzoom, the layer will be hidden."},"filter":{"type":"filter","doc":"An expression specifying conditions on source features. Only features that match the filter are displayed. Zoom expressions in filters are only evaluated at integer zoom levels. The `[\\"feature-state\\", ...]` expression is not supported in filter expressions. The `[\\"pitch\\"]` and `[\\"distance-from-center\\"]` expressions are supported only for filter expressions on the symbol layer."},"layout":{"type":"layout","doc":"Layout properties for the layer."},"paint":{"type":"paint","doc":"Default paint properties for this layer."}},"layout":["layout_fill","layout_line","layout_circle","layout_heatmap","layout_fill-extrusion","layout_symbol","layout_raster","layout_hillshade","layout_background","layout_sky"],"layout_background":{"visibility":{"type":"enum","values":{"visible":{"doc":"The layer is shown."},"none":{"doc":"The layer is not shown."}},"default":"visible","doc":"Whether this layer is displayed.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"property-type":"constant"}},"layout_sky":{"visibility":{"type":"enum","values":{"visible":{"doc":"The layer is shown."},"none":{"doc":"The layer is not shown."}},"default":"visible","doc":"Whether this layer is displayed.","sdk-support":{"basic functionality":{"js":"2.0.0","ios":"10.0.0","android":"10.0.0"}},"property-type":"constant"}},"layout_fill":{"fill-sort-key":{"type":"number","doc":"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.","sdk-support":{"basic functionality":{"js":"1.2.0","android":"9.1.0","ios":"5.8.0","macos":"0.15.0"},"data-driven styling":{"js":"1.2.0","android":"9.1.0","ios":"5.8.0","macos":"0.15.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"visibility":{"type":"enum","values":{"visible":{"doc":"The layer is shown."},"none":{"doc":"The layer is not shown."}},"default":"visible","doc":"Whether this layer is displayed.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"property-type":"constant"}},"layout_circle":{"circle-sort-key":{"type":"number","doc":"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.","sdk-support":{"basic functionality":{"js":"1.2.0","android":"9.2.0","ios":"5.9.0","macos":"0.16.0"},"data-driven styling":{"js":"1.2.0","android":"9.2.0","ios":"5.9.0","macos":"0.16.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"visibility":{"type":"enum","values":{"visible":{"doc":"The layer is shown."},"none":{"doc":"The layer is not shown."}},"default":"visible","doc":"Whether this layer is displayed.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"property-type":"constant"}},"layout_heatmap":{"visibility":{"type":"enum","values":{"visible":{"doc":"The layer is shown."},"none":{"doc":"The layer is not shown."}},"default":"visible","doc":"Whether this layer is displayed.","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}},"property-type":"constant"}},"layout_fill-extrusion":{"visibility":{"type":"enum","values":{"visible":{"doc":"The layer is shown."},"none":{"doc":"The layer is not shown."}},"default":"visible","doc":"Whether this layer is displayed.","sdk-support":{"basic functionality":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}},"property-type":"constant"},"fill-extrusion-edge-radius":{"type":"number","private":true,"default":0,"minimum":0,"maximum":1,"doc":"Radius of a fill extrusion edge in meters. If not zero, rounds extrusion edges for a smoother appearance.","sdk-support":{"basic functionality":{"js":"v2.10.0","android":"10.7.0","ios":"10.7.0"}},"property-type":"constant"}},"layout_line":{"line-cap":{"type":"enum","values":{"butt":{"doc":"A cap with a squared-off end which is drawn to the exact endpoint of the line."},"round":{"doc":"A cap with a rounded end which is drawn beyond the endpoint of the line at a radius of one-half of the line\'s width and centered on the endpoint of the line."},"square":{"doc":"A cap with a squared-off end which is drawn beyond the endpoint of the line at a distance of one-half of the line\'s width."}},"default":"butt","doc":"The display of line endings.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"2.3.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-join":{"type":"enum","values":{"bevel":{"doc":"A join with a squared-off end which is drawn beyond the endpoint of the line at a distance of one-half of the line\'s width."},"round":{"doc":"A join with a rounded end which is drawn beyond the endpoint of the line at a radius of one-half of the line\'s width and centered on the endpoint of the line."},"miter":{"doc":"A join with a sharp, angled corner which is drawn with the outer sides beyond the endpoint of the path until they meet."}},"default":"miter","doc":"The display of lines when joining.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.40.0","android":"5.2.0","ios":"3.7.0","macos":"0.6.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-miter-limit":{"type":"number","default":2,"doc":"Used to automatically convert miter joins to bevel joins for sharp angles.","requires":[{"line-join":"miter"}],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"line-round-limit":{"type":"number","default":1.05,"doc":"Used to automatically convert round joins to miter joins for shallow angles.","requires":[{"line-join":"round"}],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"line-sort-key":{"type":"number","doc":"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.","sdk-support":{"basic functionality":{"js":"1.2.0","android":"9.1.0","ios":"5.8.0","macos":"0.15.0"},"data-driven styling":{"js":"1.2.0","android":"9.1.0","ios":"5.8.0","macos":"0.15.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"visibility":{"type":"enum","values":{"visible":{"doc":"The layer is shown."},"none":{"doc":"The layer is not shown."}},"default":"visible","doc":"Whether this layer is displayed.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"property-type":"constant"}},"layout_symbol":{"symbol-placement":{"type":"enum","values":{"point":{"doc":"The label is placed at the point where the geometry is located."},"line":{"doc":"The label is placed along the line of the geometry. Can only be used on `LineString` and `Polygon` geometries."},"line-center":{"doc":"The label is placed at the center of the line of the geometry. Can only be used on `LineString` and `Polygon` geometries. Note that a single feature in a vector tile may contain multiple line geometries."}},"default":"point","doc":"Label placement relative to its geometry.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"`line-center` value":{"js":"0.47.0","android":"6.4.0","ios":"4.3.0","macos":"0.10.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"symbol-spacing":{"type":"number","default":250,"minimum":1,"units":"pixels","doc":"Distance between two symbol anchors.","requires":[{"symbol-placement":"line"}],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"symbol-avoid-edges":{"type":"boolean","default":false,"doc":"If true, the symbols will not cross tile edges to avoid mutual collisions. Recommended in layers that don\'t have enough padding in the vector tile to prevent collisions, or if it is a point symbol layer placed after a line symbol layer. When using a client that supports global collision detection, like Mapbox GL JS version 0.42.0 or greater, enabling this property is not needed to prevent clipped labels at tile boundaries.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"symbol-sort-key":{"type":"number","doc":"Sorts features in ascending order based on this value. Features with lower sort keys are drawn and placed first. When `icon-allow-overlap` or `text-allow-overlap` is `false`, features with a lower sort key will have priority during placement. When `icon-allow-overlap` or `text-allow-overlap` is set to `true`, features with a higher sort key will overlap over features with a lower sort key.","sdk-support":{"basic functionality":{"js":"0.53.0","android":"7.4.0","ios":"4.11.0","macos":"0.14.0"},"data-driven styling":{"js":"0.53.0","android":"7.4.0","ios":"4.11.0","macos":"0.14.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"symbol-z-order":{"type":"enum","values":{"auto":{"doc":"Sorts symbols by `symbol-sort-key` if set. Otherwise, sorts symbols by their y-position relative to the viewport if `icon-allow-overlap` or `text-allow-overlap` is set to `true` or `icon-ignore-placement` or `text-ignore-placement` is `false`."},"viewport-y":{"doc":"Sorts symbols by their y-position relative to the viewport if `icon-allow-overlap` or `text-allow-overlap` is set to `true` or `icon-ignore-placement` or `text-ignore-placement` is `false`."},"source":{"doc":"Sorts symbols by `symbol-sort-key` if set. Otherwise, no sorting is applied; symbols are rendered in the same order as the source data."}},"default":"auto","doc":"Determines whether overlapping symbols in the same layer are rendered in the order that they appear in the data source or by their y-position relative to the viewport. To control the order and prioritization of symbols otherwise, use `symbol-sort-key`.","sdk-support":{"basic functionality":{"js":"0.49.0","android":"6.6.0","ios":"4.5.0","macos":"0.12.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-allow-overlap":{"type":"boolean","default":false,"doc":"If true, the icon will be visible even if it collides with other previously drawn symbols.","requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-ignore-placement":{"type":"boolean","default":false,"doc":"If true, other symbols can be visible even if they collide with the icon.","requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-optional":{"type":"boolean","default":false,"doc":"If true, text will display without their corresponding icons when the icon collides with other symbols and the text does not.","requires":["icon-image","text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-rotation-alignment":{"type":"enum","values":{"map":{"doc":"When `symbol-placement` is set to `point`, aligns icons east-west. When `symbol-placement` is set to `line` or `line-center`, aligns icon x-axes with the line."},"viewport":{"doc":"Produces icons whose x-axes are aligned with the x-axis of the viewport, regardless of the value of `symbol-placement`."},"auto":{"doc":"When `symbol-placement` is set to `point`, this is equivalent to `viewport`. When `symbol-placement` is set to `line` or `line-center`, this is equivalent to `map`."}},"default":"auto","doc":"In combination with `symbol-placement`, determines the rotation behavior of icons.","requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"`auto` value":{"js":"0.25.0","android":"4.2.0","ios":"3.4.0","macos":"0.3.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-size":{"type":"number","default":1,"minimum":0,"units":"factor of the original icon size","doc":"Scales the original size of the icon by the provided factor. The new pixel size of the image will be the original pixel size multiplied by `icon-size`. 1 is the original size; 3 triples the size of the image.","requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.35.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-text-fit":{"type":"enum","values":{"none":{"doc":"The icon is displayed at its intrinsic aspect ratio."},"width":{"doc":"The icon is scaled in the x-dimension to fit the width of the text."},"height":{"doc":"The icon is scaled in the y-dimension to fit the height of the text."},"both":{"doc":"The icon is scaled in both x- and y-dimensions."}},"default":"none","doc":"Scales the icon to fit around the associated text.","requires":["icon-image","text-field"],"sdk-support":{"basic functionality":{"js":"0.21.0","android":"4.2.0","ios":"3.4.0","macos":"0.2.1"},"stretchable icons":{"js":"1.6.0","android":"9.2.0","ios":"5.8.0","macos":"0.15.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-text-fit-padding":{"type":"array","value":"number","length":4,"default":[0,0,0,0],"units":"pixels","doc":"Size of the additional area added to dimensions determined by `icon-text-fit`, in clockwise order: top, right, bottom, left.","requires":["icon-image","text-field",{"icon-text-fit":["both","width","height"]}],"sdk-support":{"basic functionality":{"js":"0.21.0","android":"4.2.0","ios":"3.4.0","macos":"0.2.1"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"icon-image":{"type":"resolvedImage","doc":"Name of image in sprite to use for drawing an image background.","tokens":true,"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.35.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-rotate":{"type":"number","default":0,"period":360,"units":"degrees","doc":"Rotates the icon clockwise.","requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.21.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-padding":{"type":"number","default":2,"minimum":0,"units":"pixels","doc":"Size of the additional area around the icon bounding box used for detecting symbol collisions.","requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"icon-keep-upright":{"type":"boolean","default":false,"doc":"If true, the icon may be flipped to prevent it from being rendered upside-down.","requires":["icon-image",{"icon-rotation-alignment":"map"},{"symbol-placement":["line","line-center"]}],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-offset":{"type":"array","value":"number","length":2,"default":[0,0],"doc":"Offset distance of icon from its anchor. Positive values indicate right and down, while negative values indicate left and up. Each component is multiplied by the value of `icon-size` to obtain the final offset in pixels. When combined with `icon-rotate` the offset will be as if the rotated direction was up.","requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.29.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-anchor":{"type":"enum","values":{"center":{"doc":"The center of the icon is placed closest to the anchor."},"left":{"doc":"The left side of the icon is placed closest to the anchor."},"right":{"doc":"The right side of the icon is placed closest to the anchor."},"top":{"doc":"The top of the icon is placed closest to the anchor."},"bottom":{"doc":"The bottom of the icon is placed closest to the anchor."},"top-left":{"doc":"The top left corner of the icon is placed closest to the anchor."},"top-right":{"doc":"The top right corner of the icon is placed closest to the anchor."},"bottom-left":{"doc":"The bottom left corner of the icon is placed closest to the anchor."},"bottom-right":{"doc":"The bottom right corner of the icon is placed closest to the anchor."}},"default":"center","doc":"Part of the icon placed closest to the anchor.","requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.40.0","android":"5.2.0","ios":"3.7.0","macos":"0.6.0"},"data-driven styling":{"js":"0.40.0","android":"5.2.0","ios":"3.7.0","macos":"0.6.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-pitch-alignment":{"type":"enum","values":{"map":{"doc":"The icon is aligned to the plane of the map."},"viewport":{"doc":"The icon is aligned to the plane of the viewport."},"auto":{"doc":"Automatically matches the value of `icon-rotation-alignment`."}},"default":"auto","doc":"Orientation of icon when map is pitched.","requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.39.0","android":"5.2.0","ios":"3.7.0","macos":"0.6.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-pitch-alignment":{"type":"enum","values":{"map":{"doc":"The text is aligned to the plane of the map."},"viewport":{"doc":"The text is aligned to the plane of the viewport."},"auto":{"doc":"Automatically matches the value of `text-rotation-alignment`."}},"default":"auto","doc":"Orientation of text when map is pitched.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.21.0","android":"4.2.0","ios":"3.4.0","macos":"0.2.1"},"`auto` value":{"js":"0.25.0","android":"4.2.0","ios":"3.4.0","macos":"0.3.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-rotation-alignment":{"type":"enum","values":{"map":{"doc":"When `symbol-placement` is set to `point`, aligns text east-west. When `symbol-placement` is set to `line` or `line-center`, aligns text x-axes with the line."},"viewport":{"doc":"Produces glyphs whose x-axes are aligned with the x-axis of the viewport, regardless of the value of `symbol-placement`."},"auto":{"doc":"When `symbol-placement` is set to `point`, this is equivalent to `viewport`. When `symbol-placement` is set to `line` or `line-center`, this is equivalent to `map`."}},"default":"auto","doc":"In combination with `symbol-placement`, determines the rotation behavior of the individual glyphs forming the text.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"`auto` value":{"js":"0.25.0","android":"4.2.0","ios":"3.4.0","macos":"0.3.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-field":{"type":"formatted","default":"","tokens":true,"doc":"Value to use for a text label. If a plain `string` is provided, it will be treated as a `formatted` with default/inherited formatting options. SDF images are not supported in formatted text and will be ignored.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.33.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-font":{"type":"array","value":"string","default":["Open Sans Regular","Arial Unicode MS Regular"],"doc":"Font stack to use for displaying text.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.43.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-size":{"type":"number","default":16,"minimum":0,"units":"pixels","doc":"Font size.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.35.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-max-width":{"type":"number","default":10,"minimum":0,"units":"ems","doc":"The maximum line width for text wrapping.","requires":["text-field",{"symbol-placement":["point"]}],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.40.0","android":"5.2.0","ios":"3.7.0","macos":"0.6.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-line-height":{"type":"number","default":1.2,"units":"ems","doc":"Text leading value for multi-line text.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"2.3.0","android":"10.0.0","ios":"10.0.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-letter-spacing":{"type":"number","default":0,"units":"ems","doc":"Text tracking amount.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.40.0","android":"5.2.0","ios":"3.7.0","macos":"0.6.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-justify":{"type":"enum","values":{"auto":{"doc":"The text is aligned towards the anchor position."},"left":{"doc":"The text is aligned to the left."},"center":{"doc":"The text is centered."},"right":{"doc":"The text is aligned to the right."}},"default":"center","doc":"Text justification options.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.39.0","android":"5.2.0","ios":"3.7.0","macos":"0.6.0"},"auto":{"js":"0.54.0","android":"7.4.0","ios":"4.10.0","macos":"0.14.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-radial-offset":{"type":"number","units":"ems","default":0,"doc":"Radial offset of text, in the direction of the symbol\'s anchor. Useful in combination with `text-variable-anchor`, which defaults to using the two-dimensional `text-offset` if present.","sdk-support":{"basic functionality":{"js":"0.54.0","android":"7.4.0","ios":"4.10.0","macos":"0.14.0"},"data-driven styling":{"js":"0.54.0","android":"7.4.0","ios":"4.10.0","macos":"0.14.0"}},"requires":["text-field"],"property-type":"data-driven","expression":{"interpolated":true,"parameters":["zoom","feature"]}},"text-variable-anchor":{"type":"array","value":"enum","values":{"center":{"doc":"The center of the text is placed closest to the anchor."},"left":{"doc":"The left side of the text is placed closest to the anchor."},"right":{"doc":"The right side of the text is placed closest to the anchor."},"top":{"doc":"The top of the text is placed closest to the anchor."},"bottom":{"doc":"The bottom of the text is placed closest to the anchor."},"top-left":{"doc":"The top left corner of the text is placed closest to the anchor."},"top-right":{"doc":"The top right corner of the text is placed closest to the anchor."},"bottom-left":{"doc":"The bottom left corner of the text is placed closest to the anchor."},"bottom-right":{"doc":"The bottom right corner of the text is placed closest to the anchor."}},"requires":["text-field",{"symbol-placement":["point"]}],"doc":"To increase the chance of placing high-priority labels on the map, you can provide an array of `text-anchor` locations: the renderer will attempt to place the label at each location, in order, before moving onto the next label. Use `text-justify: auto` to choose justification based on anchor position. To apply an offset, use the `text-radial-offset` or the two-dimensional `text-offset`.","sdk-support":{"basic functionality":{"js":"0.54.0","android":"7.4.0","ios":"4.10.0","macos":"0.14.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-anchor":{"type":"enum","values":{"center":{"doc":"The center of the text is placed closest to the anchor."},"left":{"doc":"The left side of the text is placed closest to the anchor."},"right":{"doc":"The right side of the text is placed closest to the anchor."},"top":{"doc":"The top of the text is placed closest to the anchor."},"bottom":{"doc":"The bottom of the text is placed closest to the anchor."},"top-left":{"doc":"The top left corner of the text is placed closest to the anchor."},"top-right":{"doc":"The top right corner of the text is placed closest to the anchor."},"bottom-left":{"doc":"The bottom left corner of the text is placed closest to the anchor."},"bottom-right":{"doc":"The bottom right corner of the text is placed closest to the anchor."}},"default":"center","doc":"Part of the text placed closest to the anchor.","requires":["text-field",{"!":"text-variable-anchor"}],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.39.0","android":"5.2.0","ios":"3.7.0","macos":"0.6.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-max-angle":{"type":"number","default":45,"units":"degrees","doc":"Maximum angle change between adjacent characters.","requires":["text-field",{"symbol-placement":["line","line-center"]}],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"text-writing-mode":{"type":"array","value":"enum","values":{"horizontal":{"doc":"If a text\'s language supports horizontal writing mode, symbols would be laid out horizontally."},"vertical":{"doc":"If a text\'s language supports vertical writing mode, symbols would be laid out vertically."}},"doc":"The property allows control over a symbol\'s orientation. Note that the property values act as a hint, so that a symbol whose language doesn’t support the provided orientation will be laid out in its natural orientation. Example: English point symbol will be rendered horizontally even if array value contains single \'vertical\' enum value. For symbol with point placement, the order of elements in an array define priority order for the placement of an orientation variant. For symbol with line placement, the default text writing mode is either [\'horizontal\', \'vertical\'] or [\'vertical\', \'horizontal\'], the order doesn\'t affect the placement.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"1.3.0","android":"8.3.0","ios":"5.3.0","macos":"0.15.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-rotate":{"type":"number","default":0,"period":360,"units":"degrees","doc":"Rotates the text clockwise.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.35.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-padding":{"type":"number","default":2,"minimum":0,"units":"pixels","doc":"Size of the additional area around the text bounding box used for detecting symbol collisions.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"text-keep-upright":{"type":"boolean","default":true,"doc":"If true, the text may be flipped vertically to prevent it from being rendered upside-down.","requires":["text-field",{"text-rotation-alignment":"map"},{"symbol-placement":["line","line-center"]}],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-transform":{"type":"enum","values":{"none":{"doc":"The text is not altered."},"uppercase":{"doc":"Forces all letters to be displayed in uppercase."},"lowercase":{"doc":"Forces all letters to be displayed in lowercase."}},"default":"none","doc":"Specifies how to capitalize text, similar to the CSS `text-transform` property.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.33.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-offset":{"type":"array","doc":"Offset distance of text from its anchor. Positive values indicate right and down, while negative values indicate left and up. If used with text-variable-anchor, input values will be taken as absolute values. Offsets along the x- and y-axis will be applied automatically based on the anchor position.","value":"number","units":"ems","length":2,"default":[0,0],"requires":["text-field",{"!":"text-radial-offset"}],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.35.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-allow-overlap":{"type":"boolean","default":false,"doc":"If true, the text will be visible even if it collides with other previously drawn symbols.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-ignore-placement":{"type":"boolean","default":false,"doc":"If true, other symbols can be visible even if they collide with the text.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-optional":{"type":"boolean","default":false,"doc":"If true, icons will display without their corresponding text when the text collides with other symbols and the icon does not.","requires":["text-field","icon-image"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"visibility":{"type":"enum","values":{"visible":{"doc":"The layer is shown."},"none":{"doc":"The layer is not shown."}},"default":"visible","doc":"Whether this layer is displayed.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"property-type":"constant"}},"layout_raster":{"visibility":{"type":"enum","values":{"visible":{"doc":"The layer is shown."},"none":{"doc":"The layer is not shown."}},"default":"visible","doc":"Whether this layer is displayed.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"property-type":"constant"}},"layout_hillshade":{"visibility":{"type":"enum","values":{"visible":{"doc":"The layer is shown."},"none":{"doc":"The layer is not shown."}},"default":"visible","doc":"Whether this layer is displayed.","sdk-support":{"basic functionality":{"js":"0.43.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}},"property-type":"constant"}},"filter":{"type":"array","value":"*","doc":"A filter selects specific features from a layer."},"filter_symbol":{"type":"boolean","doc":"Expression which determines whether or not to display a symbol. Symbols support dynamic filtering, meaning this expression can use the `[\\"pitch\\"]` and `[\\"distance-from-center\\"]` expressions to reference the current state of the view.","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature","pitch","distance-from-center"]}},"filter_fill":{"type":"boolean","doc":"Expression which determines whether or not to display a polygon. Fill layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\"pitch\\"]` and `[\\"distance-from-center\\"]` expressions to reference the current state of the view.","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_line":{"type":"boolean","doc":"Expression which determines whether or not to display a Polygon or LineString. Line layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\"pitch\\"]` and `[\\"distance-from-center\\"]` expressions to reference the current state of the view.","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_circle":{"type":"boolean","doc":"Expression which determines whether or not to display a circle. Circle layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\"pitch\\"]` and `[\\"distance-from-center\\"]` expressions to reference the current state of the view.","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_fill-extrusion":{"type":"boolean","doc":"Expression which determines whether or not to display a Polygon. Fill-extrusion layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\"pitch\\"]` and `[\\"distance-from-center\\"]` expressions to reference the current state of the view.","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_heatmap":{"type":"boolean","doc":"Expression used to determine whether a point is being displayed or not. Heatmap layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\"pitch\\"]` and `[\\"distance-from-center\\"]` expressions to reference the current state of the view.","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_operator":{"type":"enum","values":{"==":{"doc":"`[\\"==\\", key, value]` equality: `feature[key] = value`"},"!=":{"doc":"`[\\"!=\\", key, value]` inequality: `feature[key] ≠ value`"},">":{"doc":"`[\\">\\", key, value]` greater than: `feature[key] > value`"},">=":{"doc":"`[\\">=\\", key, value]` greater than or equal: `feature[key] ≥ value`"},"<":{"doc":"`[\\"<\\", key, value]` less than: `feature[key] < value`"},"<=":{"doc":"`[\\"<=\\", key, value]` less than or equal: `feature[key] ≤ value`"},"in":{"doc":"`[\\"in\\", key, v0, ..., vn]` set inclusion: `feature[key] ∈ {v0, ..., vn}`"},"!in":{"doc":"`[\\"!in\\", key, v0, ..., vn]` set exclusion: `feature[key] ∉ {v0, ..., vn}`"},"all":{"doc":"`[\\"all\\", f0, ..., fn]` logical `AND`: `f0 ∧ ... ∧ fn`"},"any":{"doc":"`[\\"any\\", f0, ..., fn]` logical `OR`: `f0 ∨ ... ∨ fn`"},"none":{"doc":"`[\\"none\\", f0, ..., fn]` logical `NOR`: `¬f0 ∧ ... ∧ ¬fn`"},"has":{"doc":"`[\\"has\\", key]` `feature[key]` exists"},"!has":{"doc":"`[\\"!has\\", key]` `feature[key]` does not exist"},"within":{"doc":"`[\\"within\\", object]` feature geometry is within object geometry"}},"doc":"The filter operator."},"geometry_type":{"type":"enum","values":{"Point":{"doc":"Filter to point geometries."},"LineString":{"doc":"Filter to line geometries."},"Polygon":{"doc":"Filter to polygon geometries."}},"doc":"The geometry type for the filter to select."},"function":{"expression":{"type":"expression","doc":"An expression."},"stops":{"type":"array","doc":"An array of stops.","value":"function_stop"},"base":{"type":"number","default":1,"minimum":0,"doc":"The exponential base of the interpolation curve. It controls the rate at which the result increases. Higher values make the result increase more towards the high end of the range. With `1` the stops are interpolated linearly."},"property":{"type":"string","doc":"The name of a feature property to use as the function input.","default":"$zoom"},"type":{"type":"enum","values":{"identity":{"doc":"Return the input value as the output value."},"exponential":{"doc":"Generate an output by interpolating between stops just less than and just greater than the function input."},"interval":{"doc":"Return the output value of the stop just less than the function input."},"categorical":{"doc":"Return the output value of the stop equal to the function input."}},"doc":"The interpolation strategy to use in function evaluation.","default":"exponential"},"colorSpace":{"type":"enum","values":{"rgb":{"doc":"Use the RGB color space to interpolate color values"},"lab":{"doc":"Use the LAB color space to interpolate color values."},"hcl":{"doc":"Use the HCL color space to interpolate color values, interpolating the Hue, Chroma, and Luminance channels individually."}},"doc":"The color space in which colors interpolated. Interpolating colors in perceptual color spaces like LAB and HCL tend to produce color ramps that look more consistent and produce colors that can be differentiated more easily than those interpolated in RGB space.","default":"rgb"},"default":{"type":"*","required":false,"doc":"A value to serve as a fallback function result when a value isn\'t otherwise available. It is used in the following circumstances:\\n* In categorical functions, when the feature value does not match any of the stop domain values.\\n* In property and zoom-and-property functions, when a feature does not contain a value for the specified property.\\n* In identity functions, when the feature value is not valid for the style property (for example, if the function is being used for a `circle-color` property but the feature property value is not a string or not a valid color).\\n* In interval or exponential property and zoom-and-property functions, when the feature value is not numeric.\\nIf no default is provided, the style property\'s default is used in these circumstances."}},"function_stop":{"type":"array","minimum":0,"maximum":24,"value":["number","color"],"length":2,"doc":"Zoom level and value pair."},"expression":{"type":"array","value":"*","minimum":1,"doc":"An expression defines a function that can be used for data-driven style properties or feature filters."},"expression_name":{"doc":"","type":"enum","values":{"let":{"doc":"Binds expressions to named variables, which can then be referenced in the result expression using [\\"var\\", \\"variable_name\\"].","group":"Variable binding","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"var":{"doc":"References variable bound using \\"let\\".","group":"Variable binding","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"literal":{"doc":"Provides a literal array or object value.","group":"Types","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"array":{"doc":"Asserts that the input is an array (optionally with a specific item type and length). If, when the input expression is evaluated, it is not of the asserted type, then this assertion will cause the whole expression to be aborted.","group":"Types","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"at":{"doc":"Retrieves an item from an array.","group":"Lookup","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"in":{"doc":"Determines whether an item exists in an array or a substring exists in a string. In the specific case when the second and third arguments are string literals, you must wrap at least one of them in a [`literal`](#types-literal) expression to hint correct interpretation to the [type system](#type-system).","group":"Lookup","sdk-support":{"basic functionality":{"js":"1.6.0","android":"9.1.0","ios":"5.8.0","macos":"0.15.0"}}},"index-of":{"doc":"Returns the first position at which an item can be found in an array or a substring can be found in a string, or `-1` if the input cannot be found. Accepts an optional index from where to begin the search.","group":"Lookup","sdk-support":{"basic functionality":{"js":"1.10.0","android":"10.0.0","ios":"10.0.0"}}},"slice":{"doc":"Returns an item from an array or a substring from a string from a specified start index, or between a start index and an end index if set. The return value is inclusive of the start index but not of the end index.","group":"Lookup","sdk-support":{"basic functionality":{"js":"1.10.0","android":"10.0.0","ios":"10.0.0"}}},"case":{"doc":"Selects the first output whose corresponding test condition evaluates to true, or the fallback value otherwise.","group":"Decision","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"match":{"doc":"Selects the output for which the label value matches the input value, or the fallback value if no match is found. The input can be any expression (for example, `[\\"get\\", \\"building_type\\"]`). Each label must be unique, and must be either:\\n - a single literal value; or\\n - an array of literal values, the values of which must be all strings or all numbers (for example `[100, 101]` or `[\\"c\\", \\"b\\"]`).\\n\\nThe input matches if any of the values in the array matches using strict equality, similar to the `\\"in\\"` operator.\\nIf the input type does not match the type of the labels, the result will be the fallback value.","group":"Decision","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"coalesce":{"doc":"Evaluates each expression in turn until the first valid value is obtained. Invalid values are `null` and [`\'image\'`](#types-image) expressions that are unavailable in the style. If all values are invalid, `coalesce` returns the first value listed.","group":"Decision","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"step":{"doc":"Produces discrete, stepped results by evaluating a piecewise-constant function defined by pairs of input and output values (\\"stops\\"). The `input` may be any numeric expression (e.g., `[\\"get\\", \\"population\\"]`). Stop inputs must be numeric literals in strictly ascending order. Returns the output value of the stop just less than the input, or the first output if the input is less than the first stop.","group":"Ramps, scales, curves","sdk-support":{"basic functionality":{"js":"0.42.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"interpolate":{"doc":"Produces continuous, smooth results by interpolating between pairs of input and output values (\\"stops\\"). The `input` may be any numeric expression (e.g., `[\\"get\\", \\"population\\"]`). Stop inputs must be numeric literals in strictly ascending order. The output type must be `number`, `array`, or `color`.\\n\\nInterpolation types:\\n- `[\\"linear\\"]`: Interpolates linearly between the pair of stops just less than and just greater than the input.\\n- `[\\"exponential\\", base]`: Interpolates exponentially between the stops just less than and just greater than the input. `base` controls the rate at which the output increases: higher values make the output increase more towards the high end of the range. With values close to 1 the output increases linearly.\\n- `[\\"cubic-bezier\\", x1, y1, x2, y2]`: Interpolates using the cubic bezier curve defined by the given control points.","group":"Ramps, scales, curves","sdk-support":{"basic functionality":{"js":"0.42.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"interpolate-hcl":{"doc":"Produces continuous, smooth results by interpolating between pairs of input and output values (\\"stops\\"). Works like `interpolate`, but the output type must be `color`, and the interpolation is performed in the Hue-Chroma-Luminance color space.","group":"Ramps, scales, curves","sdk-support":{"basic functionality":{"js":"0.49.0"}}},"interpolate-lab":{"doc":"Produces continuous, smooth results by interpolating between pairs of input and output values (\\"stops\\"). Works like `interpolate`, but the output type must be `color`, and the interpolation is performed in the CIELAB color space.","group":"Ramps, scales, curves","sdk-support":{"basic functionality":{"js":"0.49.0"}}},"ln2":{"doc":"Returns mathematical constant ln(2).","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"pi":{"doc":"Returns the mathematical constant pi.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"e":{"doc":"Returns the mathematical constant e.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"typeof":{"doc":"Returns a string describing the type of the given value.","group":"Types","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"string":{"doc":"Asserts that the input value is a string. If multiple values are provided, each one is evaluated in order until a string is obtained. If none of the inputs are strings, the expression is an error.","group":"Types","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"number":{"doc":"Asserts that the input value is a number. If multiple values are provided, each one is evaluated in order until a number is obtained. If none of the inputs are numbers, the expression is an error.","group":"Types","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"boolean":{"doc":"Asserts that the input value is a boolean. If multiple values are provided, each one is evaluated in order until a boolean is obtained. If none of the inputs are booleans, the expression is an error.","group":"Types","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"object":{"doc":"Asserts that the input value is an object. If multiple values are provided, each one is evaluated in order until an object is obtained. If none of the inputs are objects, the expression is an error.","group":"Types","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"collator":{"doc":"Returns a `collator` for use in locale-dependent comparison operations. The `case-sensitive` and `diacritic-sensitive` options default to `false`. The `locale` argument specifies the IETF language tag of the locale to use. If none is provided, the default locale is used. If the requested locale is not available, the `collator` will use a system-defined fallback locale. Use `resolved-locale` to test the results of locale fallback behavior.","group":"Types","sdk-support":{"basic functionality":{"js":"0.45.0","android":"6.5.0","ios":"4.2.0","macos":"0.9.0"}}},"format":{"doc":"Returns a `formatted` string for displaying mixed-format text in the `text-field` property. The input may contain a string literal or expression, including an [`\'image\'`](#types-image) expression. Strings may be followed by a style override object that supports the following properties:\\n- `\\"text-font\\"`: Overrides the font stack specified by the root layout property.\\n- `\\"text-color\\"`: Overrides the color specified by the root paint property.\\n- `\\"font-scale\\"`: Applies a scaling factor on `text-size` as specified by the root layout property.","group":"Types","sdk-support":{"basic functionality":{"js":"0.48.0","android":"6.7.0","ios":"4.6.0","macos":"0.12.0"},"text-font":{"js":"0.48.0","android":"6.7.0","ios":"4.6.0","macos":"0.12.0"},"font-scale":{"js":"0.48.0","android":"6.7.0","ios":"4.6.0","macos":"0.12.0"},"text-color":{"js":"1.3.0","android":"7.3.0","ios":"4.10.0","macos":"0.14.0"},"image":{"js":"1.6.0","android":"8.6.0","ios":"5.7.0","macos":"0.15.0"}}},"image":{"doc":"Returns a [`ResolvedImage`](/mapbox-gl-js/style-spec/types/#resolvedimage) for use in [`icon-image`](/mapbox-gl-js/style-spec/layers/#layout-symbol-icon-image), `*-pattern` entries, and as a section in the [`\'format\'`](#types-format) expression. A [`\'coalesce\'`](#coalesce) expression containing `image` expressions will evaluate to the first listed image that is currently in the style. This validation process is synchronous and requires the image to have been added to the style before requesting it in the `\'image\'` argument.","group":"Types","sdk-support":{"basic functionality":{"js":"1.4.0","android":"8.6.0","ios":"5.7.0","macos":"0.15.0"}}},"number-format":{"doc":"Converts the input number into a string representation using the providing formatting rules. If set, the `locale` argument specifies the locale to use, as a BCP 47 language tag. If set, the `currency` argument specifies an ISO 4217 code to use for currency-style formatting. If set, the `unit` argument specifies a [simple ECMAScript unit](https://tc39.es/proposal-unified-intl-numberformat/section6/locales-currencies-tz_proposed_out.html#sec-issanctionedsimpleunitidentifier) to use for unit-style formatting. If set, the `min-fraction-digits` and `max-fraction-digits` arguments specify the minimum and maximum number of fractional digits to include.","group":"Types","sdk-support":{"basic functionality":{"js":"0.54.0","android":"8.4.0","ios":"5.4.0","macos":"0.15.0"}}},"to-string":{"doc":"Converts the input value to a string. If the input is `null`, the result is `\\"\\"`. If the input is a [`boolean`](#types-boolean), the result is `\\"true\\"` or `\\"false\\"`. If the input is a number, it is converted to a string as specified by the [\\"NumberToString\\" algorithm](https://tc39.github.io/ecma262/#sec-tostring-applied-to-the-number-type) of the ECMAScript Language Specification. If the input is a [`color`](#color), it is converted to a string of the form `\\"rgba(r,g,b,a)\\"`, where `r`, `g`, and `b` are numerals ranging from 0 to 255, and `a` ranges from 0 to 1. If the input is an [`\'image\'`](#types-image) expression, `\'to-string\'` returns the image name. Otherwise, the input is converted to a string in the format specified by the [`JSON.stringify`](https://tc39.github.io/ecma262/#sec-json.stringify) function of the ECMAScript Language Specification.","group":"Types","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"to-number":{"doc":"Converts the input value to a number, if possible. If the input is `null` or `false`, the result is 0. If the input is `true`, the result is 1. If the input is a string, it is converted to a number as specified by the [\\"ToNumber Applied to the String Type\\" algorithm](https://tc39.github.io/ecma262/#sec-tonumber-applied-to-the-string-type) of the ECMAScript Language Specification. If multiple values are provided, each one is evaluated in order until the first successful conversion is obtained. If none of the inputs can be converted, the expression is an error.","group":"Types","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"to-boolean":{"doc":"Converts the input value to a boolean. The result is `false` when then input is an empty string, 0, `false`, `null`, or `NaN`; otherwise it is `true`.","group":"Types","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"to-rgba":{"doc":"Returns a four-element array containing the input color\'s red, green, blue, and alpha components, in that order.","group":"Color","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"to-color":{"doc":"Converts the input value to a color. If multiple values are provided, each one is evaluated in order until the first successful conversion is obtained. If none of the inputs can be converted, the expression is an error.","group":"Types","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"rgb":{"doc":"Creates a color value from red, green, and blue components, which must range between 0 and 255, and an alpha component of 1. If any component is out of range, the expression is an error.","group":"Color","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"rgba":{"doc":"Creates a color value from red, green, blue components, which must range between 0 and 255, and an alpha component which must range between 0 and 1. If any component is out of range, the expression is an error.","group":"Color","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"get":{"doc":"Retrieves a property value from the current feature\'s properties, or from another object if a second argument is provided. Returns `null` if the requested property is missing.","group":"Lookup","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"has":{"doc":"Tests for the presence of an property value in the current feature\'s properties, or from another object if a second argument is provided.","group":"Lookup","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"length":{"doc":"Returns the length of an array or string.","group":"Lookup","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"properties":{"doc":"Returns the feature properties object. Note that in some cases, it may be more efficient to use `[\\"get\\", \\"property_name\\"]` directly.","group":"Feature data","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"feature-state":{"doc":"Retrieves a property value from the current feature\'s state. Returns `null` if the requested property is not present on the feature\'s state. A feature\'s state is not part of the GeoJSON or vector tile data, and must be set programmatically on each feature. Features are identified by their `id` attribute, which must be an integer or a string that can be cast to an integer. Note that [\\"feature-state\\"] can only be used with paint properties that support data-driven styling.","group":"Feature data","sdk-support":{"basic functionality":{"js":"0.46.0","android":"10.0.0","ios":"10.0.0"}}},"geometry-type":{"doc":"Returns the feature\'s geometry type: `Point`, `LineString` or `Polygon`. `Multi*` feature types return the singular forms.","group":"Feature data","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"id":{"doc":"Returns the feature\'s id, if it has one.","group":"Feature data","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"zoom":{"doc":"Returns the current zoom level. Note that in style layout and paint properties, [\\"zoom\\"] may only appear as the input to a top-level \\"step\\" or \\"interpolate\\" expression.","group":"Camera","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"pitch":{"doc":"Returns the current pitch in degrees. `[\\"pitch\\"]` may only be used in the `filter` expression for a `symbol` layer.","group":"Camera","sdk-support":{"basic functionality":{"js":"2.6.0","android":"10.9.0","ios":"10.9.0"}}},"distance-from-center":{"doc":"Returns the distance of a `symbol` instance from the center of the map. The distance is measured in pixels divided by the height of the map container. It measures 0 at the center, decreases towards the camera and increase away from the camera. For example, if the height of the map is 1000px, a value of -1 means 1000px away from the center towards the camera, and a value of 1 means a distance of 1000px away from the camera from the center. `[\\"distance-from-center\\"]` may only be used in the `filter` expression for a `symbol` layer.","group":"Camera","sdk-support":{"basic functionality":{"js":"2.6.0","android":"10.9.0","ios":"10.9.0"}}},"heatmap-density":{"doc":"Returns the kernel density estimation of a pixel in a heatmap layer, which is a relative measure of how many data points are crowded around a particular pixel. Can only be used in the `heatmap-color` property.","group":"Heatmap","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"line-progress":{"doc":"Returns the progress along a gradient line. Can only be used in the `line-gradient` property.","group":"Feature data","sdk-support":{"basic functionality":{"js":"0.45.0","android":"6.5.0","ios":"4.6.0","macos":"0.12.0"}}},"sky-radial-progress":{"doc":"Returns the distance of a point on the sky from the sun position. Returns 0 at sun position and 1 when the distance reaches `sky-gradient-radius`. Can only be used in the `sky-gradient` property.","group":"sky","sdk-support":{"basic functionality":{"js":"2.0.0","ios":"10.0.0","android":"10.0.0"}}},"accumulated":{"doc":"Returns the value of a cluster property accumulated so far. Can only be used in the `clusterProperties` option of a clustered GeoJSON source.","group":"Feature data","sdk-support":{"basic functionality":{"js":"0.53.0","android":"8.4.0","ios":"5.5.0","macos":"0.15.0"}}},"+":{"doc":"Returns the sum of the inputs.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"*":{"doc":"Returns the product of the inputs.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"-":{"doc":"For two inputs, returns the result of subtracting the second input from the first. For a single input, returns the result of subtracting it from 0.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"/":{"doc":"Returns the result of floating point division of the first input by the second.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"%":{"doc":"Returns the remainder after integer division of the first input by the second.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"^":{"doc":"Returns the result of raising the first input to the power specified by the second.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"sqrt":{"doc":"Returns the square root of the input.","group":"Math","sdk-support":{"basic functionality":{"js":"0.42.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"log10":{"doc":"Returns the base-ten logarithm of the input.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"ln":{"doc":"Returns the natural logarithm of the input.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"log2":{"doc":"Returns the base-two logarithm of the input.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"sin":{"doc":"Returns the sine of the input.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"cos":{"doc":"Returns the cosine of the input.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"tan":{"doc":"Returns the tangent of the input.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"asin":{"doc":"Returns the arcsine of the input.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"acos":{"doc":"Returns the arccosine of the input.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"atan":{"doc":"Returns the arctangent of the input.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"min":{"doc":"Returns the minimum value of the inputs.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"max":{"doc":"Returns the maximum value of the inputs.","group":"Math","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"round":{"doc":"Rounds the input to the nearest integer. Halfway values are rounded away from zero. For example, `[\\"round\\", -1.5]` evaluates to -2.","group":"Math","sdk-support":{"basic functionality":{"js":"0.45.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"abs":{"doc":"Returns the absolute value of the input.","group":"Math","sdk-support":{"basic functionality":{"js":"0.45.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"ceil":{"doc":"Returns the smallest integer that is greater than or equal to the input.","group":"Math","sdk-support":{"basic functionality":{"js":"0.45.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"floor":{"doc":"Returns the largest integer that is less than or equal to the input.","group":"Math","sdk-support":{"basic functionality":{"js":"0.45.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"distance":{"doc":"Returns the shortest distance in meters between the evaluated feature and the input geometry. The input value can be a valid GeoJSON of type `Point`, `MultiPoint`, `LineString`, `MultiLineString`, `Polygon`, `MultiPolygon`, `Feature`, or `FeatureCollection`. Distance values returned may vary in precision due to loss in precision from encoding geometries, particularly below zoom level 13.","group":"Math","sdk-support":{"basic functionality":{"android":"9.2.0","ios":"5.9.0","macos":"0.16.0"}}},"==":{"doc":"Returns `true` if the input values are equal, `false` otherwise. The comparison is strictly typed: values of different runtime types are always considered unequal. Cases where the types are known to be different at parse time are considered invalid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.","group":"Decision","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"},"collator":{"js":"0.45.0","android":"6.5.0","ios":"4.2.0","macos":"0.9.0"}}},"!=":{"doc":"Returns `true` if the input values are not equal, `false` otherwise. The comparison is strictly typed: values of different runtime types are always considered unequal. Cases where the types are known to be different at parse time are considered invalid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.","group":"Decision","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"},"collator":{"js":"0.45.0","android":"6.5.0","ios":"4.2.0","macos":"0.9.0"}}},">":{"doc":"Returns `true` if the first input is strictly greater than the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.","group":"Decision","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"},"collator":{"js":"0.45.0","android":"6.5.0","ios":"4.2.0","macos":"0.9.0"}}},"<":{"doc":"Returns `true` if the first input is strictly less than the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.","group":"Decision","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"},"collator":{"js":"0.45.0","android":"6.5.0","ios":"4.2.0","macos":"0.9.0"}}},">=":{"doc":"Returns `true` if the first input is greater than or equal to the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.","group":"Decision","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"},"collator":{"js":"0.45.0","android":"6.5.0","ios":"4.2.0","macos":"0.9.0"}}},"<=":{"doc":"Returns `true` if the first input is less than or equal to the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.","group":"Decision","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"},"collator":{"js":"0.45.0","android":"6.5.0","ios":"4.2.0","macos":"0.9.0"}}},"all":{"doc":"Returns `true` if all the inputs are `true`, `false` otherwise. The inputs are evaluated in order, and evaluation is short-circuiting: once an input expression evaluates to `false`, the result is `false` and no further input expressions are evaluated.","group":"Decision","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"any":{"doc":"Returns `true` if any of the inputs are `true`, `false` otherwise. The inputs are evaluated in order, and evaluation is short-circuiting: once an input expression evaluates to `true`, the result is `true` and no further input expressions are evaluated.","group":"Decision","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"!":{"doc":"Logical negation. Returns `true` if the input is `false`, and `false` if the input is `true`.","group":"Decision","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"within":{"doc":"Returns `true` if the evaluated feature is fully contained inside a boundary of the input geometry, `false` otherwise. The input value can be a valid GeoJSON of type `Polygon`, `MultiPolygon`, `Feature`, or `FeatureCollection`. Supported features for evaluation:\\n- `Point`: Returns `false` if a point is on the boundary or falls outside the boundary.\\n- `LineString`: Returns `false` if any part of a line falls outside the boundary, the line intersects the boundary, or a line\'s endpoint is on the boundary.","group":"Decision","sdk-support":{"basic functionality":{"js":"1.9.0","android":"9.1.0","ios":"5.8.0","macos":"0.15.0"}}},"is-supported-script":{"doc":"Returns `true` if the input string is expected to render legibly. Returns `false` if the input string contains sections that cannot be rendered without potential loss of meaning (e.g. Indic scripts that require complex text shaping, or right-to-left scripts if the the `mapbox-gl-rtl-text` plugin is not in use in Mapbox GL JS).","group":"String","sdk-support":{"basic functionality":{"js":"0.45.0","android":"6.6.0","ios":"4.1.0","macos":"0.8.0"}}},"upcase":{"doc":"Returns the input string converted to uppercase. Follows the Unicode Default Case Conversion algorithm and the locale-insensitive case mappings in the Unicode Character Database.","group":"String","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"downcase":{"doc":"Returns the input string converted to lowercase. Follows the Unicode Default Case Conversion algorithm and the locale-insensitive case mappings in the Unicode Character Database.","group":"String","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"concat":{"doc":"Returns a `string` consisting of the concatenation of the inputs. Each input is converted to a string as if by `to-string`.","group":"String","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}}},"resolved-locale":{"doc":"Returns the IETF language tag of the locale being used by the provided `collator`. This can be used to determine the default system locale, or to determine if a requested locale was successfully loaded.","group":"String","sdk-support":{"basic functionality":{"js":"0.45.0","android":"6.5.0","ios":"4.2.0","macos":"0.9.0"}}}}},"fog":{"range":{"type":"array","default":[0.5,10],"minimum":-20,"maximum":20,"length":2,"value":"number","property-type":"data-constant","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"doc":"The start and end distance range in which fog fades from fully transparent to fully opaque. The distance to the point at the center of the map is defined as zero, so that negative range values are closer to the camera, and positive values are farther away.","example":[0.5,10],"sdk-support":{"basic functionality":{"js":"2.3.0","android":"10.6.0","ios":"10.6.0"}}},"color":{"type":"color","property-type":"data-constant","default":"#ffffff","expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"doc":"The color of the atmosphere region immediately below the horizon and within the `range` and above the horizon and within `horizon-blend`. Using opacity is recommended only for smoothly transitioning fog on/off as anything less than 100% opacity results in more tiles loaded and drawn.","sdk-support":{"basic functionality":{"js":"2.3.0","android":"10.6.0","ios":"10.6.0"}}},"high-color":{"type":"color","property-type":"data-constant","default":"#245cdf","expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"doc":"The color of the atmosphere region above the horizon, `high-color` extends further above the horizon than the `color` property and its spread can be controlled with `horizon-blend`. The opacity can be set to `0` to remove the high atmosphere color contribution.","sdk-support":{"basic functionality":{"js":"2.9.0","android":"10.6.0","ios":"10.6.0"}}},"space-color":{"type":"color","property-type":"data-constant","default":["interpolate",["linear"],["zoom"],4,"#010b19",7,"#367ab9"],"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"doc":"The color of the region above the horizon and after the end of the `horizon-blend` contribution. The opacity can be set to `0` to have a transparent background.","sdk-support":{"basic functionality":{"js":"2.9.0","android":"10.6.0","ios":"10.6.0"}}},"horizon-blend":{"type":"number","property-type":"data-constant","default":["interpolate",["linear"],["zoom"],4,0.2,7,0.1],"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"doc":"Horizon blend applies a smooth fade from the color of the atmosphere to the color of space. A value of zero leaves a sharp transition from atmosphere to space. Increasing the value blends the color of atmosphere into increasingly high angles of the sky.","sdk-support":{"basic functionality":{"js":"2.3.0","android":"10.6.0","ios":"10.6.0"}}},"star-intensity":{"type":"number","property-type":"data-constant","default":["interpolate",["linear"],["zoom"],5,0.35,6,0],"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"doc":"A value controlling the star intensity where `0` will show no stars and `1` will show stars at their maximum intensity.","sdk-support":{"basic functionality":{"js":"2.9.0","android":"10.6.0","ios":"10.6.0"}}}},"light":{"anchor":{"type":"enum","default":"viewport","values":{"map":{"doc":"The position of the light source is aligned to the rotation of the map."},"viewport":{"doc":"The position of the light source is aligned to the rotation of the viewport."}},"property-type":"data-constant","transition":false,"expression":{"interpolated":false,"parameters":["zoom"]},"doc":"Whether extruded geometries are lit relative to the map or viewport.","example":"map","sdk-support":{"basic functionality":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}}},"position":{"type":"array","default":[1.15,210,30],"length":3,"value":"number","property-type":"data-constant","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"doc":"Position of the light source relative to lit (extruded) geometries, in [r radial coordinate, a azimuthal angle, p polar angle] where r indicates the distance from the center of the base of an object to its light, a indicates the position of the light relative to 0° (0° when `light.anchor` is set to `viewport` corresponds to the top of the viewport, or 0° when `light.anchor` is set to `map` corresponds to due north, and degrees proceed clockwise), and p indicates the height of the light (from 0°, directly above, to 180°, directly below).","example":[1.5,90,80],"sdk-support":{"basic functionality":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}}},"color":{"type":"color","property-type":"data-constant","default":"#ffffff","expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"doc":"Color tint for lighting extruded geometries.","sdk-support":{"basic functionality":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}}},"intensity":{"type":"number","property-type":"data-constant","default":0.5,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"doc":"Intensity of lighting (on a scale from 0 to 1). Higher numbers will present as more extreme contrast.","sdk-support":{"basic functionality":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}}}},"projection":{"name":{"type":"enum","values":{"albers":{"doc":"An Albers equal-area projection centered on the continental United States. You can configure the projection for a different region by setting `center` and `parallels` properties. You may want to set max bounds to constrain the map to the relevant region."},"equalEarth":{"doc":"An Equal Earth projection."},"equirectangular":{"doc":"An Equirectangular projection. This projection is very similar to the Plate Carrée projection."},"lambertConformalConic":{"doc":"A Lambert conformal conic projection. You can configure the projection for a region by setting `center` and `parallels` properties. You may want to set max bounds to constrain the map to the relevant region."},"mercator":{"doc":"The Mercator projection is the default projection."},"naturalEarth":{"doc":"A Natural Earth projection."},"winkelTripel":{"doc":"A Winkel Tripel projection."},"globe":{"doc":"A globe projection."}},"default":"mercator","doc":"The name of the projection to be used for rendering the map.","required":true,"sdk-support":{"basic functionality":{"js":"2.6.0"}}},"center":{"type":"array","length":2,"value":"number","property-type":"data-constant","minimum":[-180,-90],"maximum":[180,90],"transition":false,"doc":"The reference longitude and latitude of the projection. `center` takes the form of [lng, lat]. This property is only configurable for conic projections (Albers and Lambert Conformal Conic). All other projections are centered on [0, 0].","example":[-96,37.5],"requires":[{"name":["albers","lambertConformalConic"]}],"sdk-support":{"basic functionality":{"js":"2.6.0"}}},"parallels":{"type":"array","length":2,"value":"number","property-type":"data-constant","minimum":[-90,-90],"maximum":[90,90],"transition":false,"doc":"The standard parallels of the projection, denoting the desired latitude range with minimal distortion. `parallels` takes the form of [lat0, lat1]. This property is only configurable for conic projections (Albers and Lambert Conformal Conic).","example":[29.5,45.5],"requires":[{"name":["albers","lambertConformalConic"]}],"sdk-support":{"basic functionality":{"js":"2.6.0"}}}},"terrain":{"source":{"type":"string","doc":"Name of a source of `raster_dem` type to be used for terrain elevation.","required":true,"sdk-support":{"basic functionality":{"js":"2.0.0","ios":"10.0.0","android":"10.0.0"}}},"exaggeration":{"type":"number","property-type":"data-constant","default":1,"minimum":0,"maximum":1000,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"doc":"Exaggerates the elevation of the terrain by multiplying the data from the DEM with this value.","requires":["source"],"sdk-support":{"basic functionality":{"js":"2.0.0","ios":"10.0.0","android":"10.0.0"}}}},"paint":["paint_fill","paint_line","paint_circle","paint_heatmap","paint_fill-extrusion","paint_symbol","paint_raster","paint_hillshade","paint_background","paint_sky"],"paint_fill":{"fill-antialias":{"type":"boolean","default":true,"doc":"Whether or not the fill should be antialiased.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"fill-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"doc":"The opacity of the entire fill layer. In contrast to the `fill-color`, this value will also affect the 1px stroke around the fill, if the stroke is used.","transition":true,"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.21.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-color":{"type":"color","default":"#000000","doc":"The color of the filled part of this layer. This color can be specified as `rgba` with an alpha component and the color\'s opacity will not affect the opacity of the 1px stroke, if it is used.","transition":true,"requires":[{"!":"fill-pattern"}],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.19.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-outline-color":{"type":"color","doc":"The outline color of the fill. Matches the value of `fill-color` if unspecified.","transition":true,"requires":[{"!":"fill-pattern"},{"fill-antialias":true}],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.19.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","doc":"The geometry\'s offset. Values are [x, y] where negatives indicate left and up, respectively.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"fill-translate-anchor":{"type":"enum","values":{"map":{"doc":"The fill is translated relative to the map."},"viewport":{"doc":"The fill is translated relative to the viewport."}},"doc":"Controls the frame of reference for `fill-translate`.","default":"map","requires":["fill-translate"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"fill-pattern":{"type":"resolvedImage","transition":false,"doc":"Name of image in sprite to use for drawing image fills. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.49.0","android":"6.5.0","macos":"0.11.0","ios":"4.4.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"}},"paint_fill-extrusion":{"fill-extrusion-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"doc":"The opacity of the entire fill extrusion layer. This is rendered on a per-layer, not per-feature, basis, and data-driven styling is not available.","transition":true,"sdk-support":{"basic functionality":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-color":{"type":"color","default":"#000000","doc":"The base color of the extruded fill. The extrusion\'s surfaces will be shaded differently based on this color in combination with the root `light` settings. If this color is specified as `rgba` with an alpha component, the alpha component will be ignored; use `fill-extrusion-opacity` to set layer opacity.","transition":true,"requires":[{"!":"fill-extrusion-pattern"}],"sdk-support":{"basic functionality":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"},"data-driven styling":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","doc":"The geometry\'s offset. Values are [x, y] where negatives indicate left and up (on the flat plane), respectively.","sdk-support":{"basic functionality":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-translate-anchor":{"type":"enum","values":{"map":{"doc":"The fill extrusion is translated relative to the map."},"viewport":{"doc":"The fill extrusion is translated relative to the viewport."}},"doc":"Controls the frame of reference for `fill-extrusion-translate`.","default":"map","requires":["fill-extrusion-translate"],"sdk-support":{"basic functionality":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-pattern":{"type":"resolvedImage","transition":false,"doc":"Name of image in sprite to use for drawing images on extruded fills. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.","sdk-support":{"basic functionality":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"},"data-driven styling":{"js":"0.49.0","android":"6.5.0","macos":"0.11.0","ios":"4.4.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"fill-extrusion-height":{"type":"number","default":0,"minimum":0,"units":"meters","doc":"The height with which to extrude this layer.","transition":true,"sdk-support":{"basic functionality":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"},"data-driven styling":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-base":{"type":"number","default":0,"minimum":0,"units":"meters","doc":"The height with which to extrude the base of this layer. Must be less than or equal to `fill-extrusion-height`.","transition":true,"requires":["fill-extrusion-height"],"sdk-support":{"basic functionality":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"},"data-driven styling":{"js":"0.27.0","android":"5.1.0","ios":"3.6.0","macos":"0.5.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-vertical-gradient":{"type":"boolean","default":true,"doc":"Whether to apply a vertical gradient to the sides of a fill-extrusion layer. If true, sides will be shaded slightly darker farther down.","transition":false,"sdk-support":{"basic functionality":{"js":"0.50.0","android":"7.0.0","ios":"4.7.0","macos":"0.13.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-ambient-occlusion-intensity":{"property-type":"data-constant","type":"number","private":true,"default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"doc":"Controls the intensity of shading near ground and concave angles between walls. Default value 0.0 disables ambient occlusion and values around 0.3 provide the most plausible results for buildings.","sdk-support":{"basic functionality":{"js":"2.10.0","android":"10.7.0","ios":"10.7.0"}}},"fill-extrusion-ambient-occlusion-radius":{"property-type":"data-constant","type":"number","private":true,"default":3,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"doc":"Shades area near ground and concave angles between walls where the radius defines only vertical impact. Default value 3.0 corresponds to height of one floor and brings the most plausible results for buildings.","requires":["fill-extrusion-edge-radius"],"sdk-support":{"basic functionality":{"js":"2.10.0","android":"10.7.0","ios":"10.7.0"}}}},"paint_line":{"line-opacity":{"type":"number","doc":"The opacity at which the line will be drawn.","default":1,"minimum":0,"maximum":1,"transition":true,"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.29.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-color":{"type":"color","doc":"The color with which the line will be drawn.","default":"#000000","transition":true,"requires":[{"!":"line-pattern"}],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.23.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","doc":"The geometry\'s offset. Values are [x, y] where negatives indicate left and up, respectively.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"line-translate-anchor":{"type":"enum","values":{"map":{"doc":"The line is translated relative to the map."},"viewport":{"doc":"The line is translated relative to the viewport."}},"doc":"Controls the frame of reference for `line-translate`.","default":"map","requires":["line-translate"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"line-width":{"type":"number","default":1,"minimum":0,"transition":true,"units":"pixels","doc":"Stroke thickness.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.39.0","android":"5.2.0","ios":"3.7.0","macos":"0.6.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-gap-width":{"type":"number","default":0,"minimum":0,"doc":"Draws a line casing outside of a line\'s actual path. Value indicates the width of the inner gap.","transition":true,"units":"pixels","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.29.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-offset":{"type":"number","default":0,"doc":"The line\'s offset. For linear features, a positive value offsets the line to the right, relative to the direction of the line, and a negative value to the left. For polygon features, a positive value results in an inset, and a negative value results in an outset.","transition":true,"units":"pixels","sdk-support":{"basic functionality":{"js":"0.12.1","android":"3.0.0","ios":"3.1.0","macos":"0.1.0"},"data-driven styling":{"js":"0.29.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-blur":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","doc":"Blur applied to the line, in pixels.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.29.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-dasharray":{"type":"array","value":"number","doc":"Specifies the lengths of the alternating dashes and gaps that form the dash pattern. The lengths are later scaled by the line width. To convert a dash length to pixels, multiply the length by the current line width. Note that GeoJSON sources with `lineMetrics: true` specified won\'t render dashed lines to the expected scale. Also note that zoom-dependent expressions will be evaluated only at integer zoom levels.","minimum":0,"transition":false,"units":"line widths","requires":[{"!":"line-pattern"}],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"2.3.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-pattern":{"type":"resolvedImage","transition":false,"doc":"Name of image in sprite to use for drawing image lines. For seamless patterns, image width must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.49.0","android":"6.5.0","macos":"0.11.0","ios":"4.4.0"}},"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-gradient":{"type":"color","doc":"Defines a gradient with which to color a line feature. Can only be used with GeoJSON sources that specify `\\"lineMetrics\\": true`.","transition":false,"requires":[{"!":"line-pattern"},{"source":"geojson","has":{"lineMetrics":true}}],"sdk-support":{"basic functionality":{"js":"0.45.0","android":"6.5.0","ios":"4.4.0","macos":"0.11.0"},"data-driven styling":{}},"expression":{"interpolated":true,"parameters":["line-progress"]},"property-type":"color-ramp"},"line-trim-offset":{"type":"array","value":"number","doc":"The line part between [trim-start, trim-end] will be marked as transparent to make a route vanishing effect. The line trim-off offset is based on the whole line range [0.0, 1.0].","length":2,"default":[0,0],"minimum":[0,0],"maximum":[1,1],"transition":false,"requires":[{"source":"geojson","has":{"lineMetrics":true}}],"sdk-support":{"basic functionality":{"js":"2.9.0","android":"10.5.0","ios":"10.5.0","macos":"10.5.0"}},"property-type":"constant"}},"paint_circle":{"circle-radius":{"type":"number","default":5,"minimum":0,"transition":true,"units":"pixels","doc":"Circle radius.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.18.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-color":{"type":"color","default":"#000000","doc":"The fill color of the circle.","transition":true,"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.18.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-blur":{"type":"number","default":0,"doc":"Amount to blur the circle. 1 blurs the circle such that only the centerpoint is full opacity.","transition":true,"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.20.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-opacity":{"type":"number","doc":"The opacity at which the circle will be drawn.","default":1,"minimum":0,"maximum":1,"transition":true,"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.20.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","doc":"The geometry\'s offset. Values are [x, y] where negatives indicate left and up, respectively.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"circle-translate-anchor":{"type":"enum","values":{"map":{"doc":"The circle is translated relative to the map."},"viewport":{"doc":"The circle is translated relative to the viewport."}},"doc":"Controls the frame of reference for `circle-translate`.","default":"map","requires":["circle-translate"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"circle-pitch-scale":{"type":"enum","values":{"map":{"doc":"Circles are scaled according to their apparent distance to the camera."},"viewport":{"doc":"Circles are not scaled."}},"default":"map","doc":"Controls the scaling behavior of the circle when the map is pitched.","sdk-support":{"basic functionality":{"js":"0.21.0","android":"4.2.0","ios":"3.4.0","macos":"0.2.1"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"circle-pitch-alignment":{"type":"enum","values":{"map":{"doc":"The circle is aligned to the plane of the map."},"viewport":{"doc":"The circle is aligned to the plane of the viewport."}},"default":"viewport","doc":"Orientation of circle when map is pitched.","sdk-support":{"basic functionality":{"js":"0.39.0","android":"5.2.0","ios":"3.7.0","macos":"0.6.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"circle-stroke-width":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","doc":"The width of the circle\'s stroke. Strokes are placed outside of the `circle-radius`.","sdk-support":{"basic functionality":{"js":"0.29.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"},"data-driven styling":{"js":"0.29.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-stroke-color":{"type":"color","default":"#000000","doc":"The stroke color of the circle.","transition":true,"sdk-support":{"basic functionality":{"js":"0.29.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"},"data-driven styling":{"js":"0.29.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-stroke-opacity":{"type":"number","doc":"The opacity of the circle\'s stroke.","default":1,"minimum":0,"maximum":1,"transition":true,"sdk-support":{"basic functionality":{"js":"0.29.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"},"data-driven styling":{"js":"0.29.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"}},"paint_heatmap":{"heatmap-radius":{"type":"number","default":30,"minimum":1,"transition":true,"units":"pixels","doc":"Radius of influence of one heatmap point in pixels. Increasing the value makes the heatmap smoother, but less detailed. `queryRenderedFeatures` on heatmap layers will return points within this radius.","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"},"data-driven styling":{"js":"0.43.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"heatmap-weight":{"type":"number","default":1,"minimum":0,"transition":false,"doc":"A measure of how much an individual point contributes to the heatmap. A value of 10 would be equivalent to having 10 points of weight 1 in the same spot. Especially useful when combined with clustering.","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"},"data-driven styling":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"heatmap-intensity":{"type":"number","default":1,"minimum":0,"transition":true,"doc":"Similar to `heatmap-weight` but controls the intensity of the heatmap globally. Primarily used for adjusting the heatmap based on zoom level.","sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"heatmap-color":{"type":"color","default":["interpolate",["linear"],["heatmap-density"],0,"rgba(0, 0, 255, 0)",0.1,"royalblue",0.3,"cyan",0.5,"lime",0.7,"yellow",1,"red"],"doc":"Defines the color of each pixel based on its density value in a heatmap. Should be an expression that uses `[\\"heatmap-density\\"]` as input.","transition":false,"sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"},"data-driven styling":{}},"expression":{"interpolated":true,"parameters":["heatmap-density"]},"property-type":"color-ramp"},"heatmap-opacity":{"type":"number","doc":"The global opacity at which the heatmap layer will be drawn.","default":1,"minimum":0,"maximum":1,"transition":true,"sdk-support":{"basic functionality":{"js":"0.41.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_symbol":{"icon-opacity":{"doc":"The opacity at which the icon will be drawn.","type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.33.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-color":{"type":"color","default":"#000000","transition":true,"doc":"The color of the icon. This can only be used with [SDF icons](/help/troubleshooting/using-recolorable-images-in-mapbox-maps/).","requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.33.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-color":{"type":"color","default":"rgba(0, 0, 0, 0)","transition":true,"doc":"The color of the icon\'s halo. Icon halos can only be used with [SDF icons](/help/troubleshooting/using-recolorable-images-in-mapbox-maps/).","requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.33.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-width":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","doc":"Distance of halo to the icon outline.","requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.33.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-blur":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","doc":"Fade out the halo towards the outside.","requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.33.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","doc":"Distance that the icon\'s anchor is moved from its original placement. Positive values indicate right and down, while negative values indicate left and up.","requires":["icon-image"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"icon-translate-anchor":{"type":"enum","values":{"map":{"doc":"Icons are translated relative to the map."},"viewport":{"doc":"Icons are translated relative to the viewport."}},"doc":"Controls the frame of reference for `icon-translate`.","default":"map","requires":["icon-image","icon-translate"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-opacity":{"type":"number","doc":"The opacity at which the text will be drawn.","default":1,"minimum":0,"maximum":1,"transition":true,"requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.33.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-color":{"type":"color","doc":"The color with which the text will be drawn.","default":"#000000","transition":true,"overridable":true,"requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.33.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-color":{"type":"color","default":"rgba(0, 0, 0, 0)","transition":true,"doc":"The color of the text\'s halo, which helps it stand out from backgrounds.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.33.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-width":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","doc":"Distance of halo to the font outline. Max text halo width is 1/4 of the font-size.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.33.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-blur":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","doc":"The halo\'s fadeout distance towards the outside.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"},"data-driven styling":{"js":"0.33.0","android":"5.0.0","ios":"3.5.0","macos":"0.4.0"}},"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","doc":"Distance that the text\'s anchor is moved from its original placement. Positive values indicate right and down, while negative values indicate left and up.","requires":["text-field"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"text-translate-anchor":{"type":"enum","values":{"map":{"doc":"The text is translated relative to the map."},"viewport":{"doc":"The text is translated relative to the viewport."}},"doc":"Controls the frame of reference for `text-translate`.","default":"map","requires":["text-field","text-translate"],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_raster":{"raster-opacity":{"type":"number","doc":"The opacity at which the image will be drawn.","default":1,"minimum":0,"maximum":1,"transition":true,"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-hue-rotate":{"type":"number","default":0,"period":360,"transition":true,"units":"degrees","doc":"Rotates hues around the color wheel.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-brightness-min":{"type":"number","doc":"Increase or reduce the brightness of the image. The value is the minimum brightness.","default":0,"minimum":0,"maximum":1,"transition":true,"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-brightness-max":{"type":"number","doc":"Increase or reduce the brightness of the image. The value is the maximum brightness.","default":1,"minimum":0,"maximum":1,"transition":true,"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-saturation":{"type":"number","doc":"Increase or reduce the saturation of the image.","default":0,"minimum":-1,"maximum":1,"transition":true,"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-contrast":{"type":"number","doc":"Increase or reduce the contrast of the image.","default":0,"minimum":-1,"maximum":1,"transition":true,"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-resampling":{"type":"enum","doc":"The resampling/interpolation method to use for overscaling, also known as texture magnification filter","values":{"linear":{"doc":"(Bi)linear filtering interpolates pixel values using the weighted average of the four closest original source pixels creating a smooth but blurry look when overscaled"},"nearest":{"doc":"Nearest neighbor filtering interpolates pixel values using the nearest original source pixel creating a sharp but pixelated look when overscaled"}},"default":"linear","sdk-support":{"basic functionality":{"js":"0.47.0","android":"6.3.0","ios":"4.2.0","macos":"0.9.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"raster-fade-duration":{"type":"number","default":300,"minimum":0,"transition":false,"units":"milliseconds","doc":"Fade duration when a new tile is added.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_hillshade":{"hillshade-illumination-direction":{"type":"number","default":335,"minimum":0,"maximum":359,"doc":"The direction of the light source used to generate the hillshading with 0 as the top of the viewport if `hillshade-illumination-anchor` is set to `viewport` and due north if `hillshade-illumination-anchor` is set to `map`.","transition":false,"sdk-support":{"basic functionality":{"js":"0.43.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-illumination-anchor":{"type":"enum","values":{"map":{"doc":"The hillshade illumination is relative to the north direction."},"viewport":{"doc":"The hillshade illumination is relative to the top of the viewport."}},"default":"viewport","doc":"Direction of light source when map is rotated.","sdk-support":{"basic functionality":{"js":"0.43.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-exaggeration":{"type":"number","doc":"Intensity of the hillshade","default":0.5,"minimum":0,"maximum":1,"transition":true,"sdk-support":{"basic functionality":{"js":"0.43.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-shadow-color":{"type":"color","default":"#000000","doc":"The shading color of areas that face away from the light source.","transition":true,"sdk-support":{"basic functionality":{"js":"0.43.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-highlight-color":{"type":"color","default":"#FFFFFF","doc":"The shading color of areas that faces towards the light source.","transition":true,"sdk-support":{"basic functionality":{"js":"0.43.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-accent-color":{"type":"color","default":"#000000","doc":"The shading color used to accentuate rugged terrain like sharp cliffs and gorges.","transition":true,"sdk-support":{"basic functionality":{"js":"0.43.0","android":"6.0.0","ios":"4.0.0","macos":"0.7.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_background":{"background-color":{"type":"color","default":"#000000","doc":"The color with which the background will be drawn.","transition":true,"requires":[{"!":"background-pattern"}],"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"background-pattern":{"type":"resolvedImage","transition":false,"doc":"Name of image in sprite to use for drawing an image background. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.","sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"background-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"doc":"The opacity at which the background will be drawn.","transition":true,"sdk-support":{"basic functionality":{"js":"0.10.0","android":"2.0.1","ios":"2.0.0","macos":"0.1.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_sky":{"sky-type":{"type":"enum","values":{"gradient":{"doc":"Renders the sky with a gradient that can be configured with `sky-gradient-radius` and `sky-gradient`."},"atmosphere":{"doc":"Renders the sky with a simulated atmospheric scattering algorithm, the sun direction can be attached to the light position or explicitly set through `sky-atmosphere-sun`."}},"default":"atmosphere","doc":"The type of the sky","sdk-support":{"basic functionality":{"js":"2.0.0","ios":"10.0.0","android":"10.0.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"sky-atmosphere-sun":{"type":"array","value":"number","length":2,"units":"degrees","minimum":[0,0],"maximum":[360,180],"transition":false,"doc":"Position of the sun center [a azimuthal angle, p polar angle]. The azimuthal angle indicates the position of the sun relative to 0° north, where degrees proceed clockwise. The polar angle indicates the height of the sun, where 0° is directly above, at zenith, and 90° at the horizon. When this property is ommitted, the sun center is directly inherited from the light position.","sdk-support":{"basic functionality":{"js":"2.0.0","ios":"10.0.0","android":"10.0.0"}},"requires":[{"sky-type":"atmosphere"}],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"sky-atmosphere-sun-intensity":{"type":"number","requires":[{"sky-type":"atmosphere"}],"default":10,"minimum":0,"maximum":100,"transition":false,"doc":"Intensity of the sun as a light source in the atmosphere (on a scale from 0 to a 100). Setting higher values will brighten up the sky.","sdk-support":{"basic functionality":{"js":"2.0.0","ios":"10.0.0","android":"10.0.0"}},"property-type":"data-constant"},"sky-gradient-center":{"type":"array","requires":[{"sky-type":"gradient"}],"value":"number","default":[0,0],"length":2,"units":"degrees","minimum":[0,0],"maximum":[360,180],"transition":false,"doc":"Position of the gradient center [a azimuthal angle, p polar angle]. The azimuthal angle indicates the position of the gradient center relative to 0° north, where degrees proceed clockwise. The polar angle indicates the height of the gradient center, where 0° is directly above, at zenith, and 90° at the horizon.","sdk-support":{"basic functionality":{"js":"2.0.0","ios":"10.0.0","android":"10.0.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"sky-gradient-radius":{"type":"number","requires":[{"sky-type":"gradient"}],"default":90,"minimum":0,"maximum":180,"transition":false,"doc":"The angular distance (measured in degrees) from `sky-gradient-center` up to which the gradient extends. A value of 180 causes the gradient to wrap around to the opposite direction from `sky-gradient-center`.","sdk-support":{"basic functionality":{"js":"2.0.0","ios":"10.0.0","android":"10.0.0"}},"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"sky-gradient":{"type":"color","default":["interpolate",["linear"],["sky-radial-progress"],0.8,"#87ceeb",1,"white"],"doc":"Defines a radial color gradient with which to color the sky. The color values can be interpolated with an expression using `sky-radial-progress`. The range [0, 1] for the interpolant covers a radial distance (in degrees) of [0, `sky-gradient-radius`] centered at the position specified by `sky-gradient-center`.","transition":false,"requires":[{"sky-type":"gradient"}],"sdk-support":{"basic functionality":{"js":"2.0.0","ios":"10.0.0","android":"10.0.0"},"data-driven styling":{}},"expression":{"interpolated":true,"parameters":["sky-radial-progress"]},"property-type":"color-ramp"},"sky-atmosphere-halo-color":{"type":"color","default":"white","doc":"A color applied to the atmosphere sun halo. The alpha channel describes how strongly the sun halo is represented in an atmosphere sky layer.","transition":false,"requires":[{"sky-type":"atmosphere"}],"sdk-support":{"basic functionality":{"js":"2.0.0","ios":"10.0.0","android":"10.0.0"}},"property-type":"data-constant"},"sky-atmosphere-color":{"type":"color","default":"white","doc":"A color used to tweak the main atmospheric scattering coefficients. Using white applies the default coefficients giving the natural blue color to the atmosphere. This color affects how heavily the corresponding wavelength is represented during scattering. The alpha channel describes the density of the atmosphere, with 1 maximum density and 0 no density.","transition":false,"requires":[{"sky-type":"atmosphere"}],"sdk-support":{"basic functionality":{"js":"2.0.0","ios":"10.0.0","android":"10.0.0"}},"property-type":"data-constant"},"sky-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"doc":"The opacity of the entire sky layer.","transition":true,"sdk-support":{"basic functionality":{"js":"2.0.0","ios":"10.0.0","android":"10.0.0"}},"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"transition":{"duration":{"type":"number","default":300,"minimum":0,"units":"milliseconds","doc":"Time allotted for transitions to complete."},"delay":{"type":"number","default":0,"minimum":0,"units":"milliseconds","doc":"Length of time before a transition begins."}},"property-type":{"data-driven":{"type":"property-type","doc":"Property is interpolable and can be represented using a property expression."},"color-ramp":{"type":"property-type","doc":"Property should be specified using a color ramp from which the output color can be sampled based on a property calculation."},"data-constant":{"type":"property-type","doc":"Property is interpolable but cannot be represented using a property expression."},"constant":{"type":"property-type","doc":"Property is constant across all zoom levels and property values."}},"promoteId":{"*":{"type":"string","doc":"A name of a feature property to use as ID for feature state."}}}'),oi=si,ai=function(t,e="fill"){if(null==t)return{filter:()=>!0,needGeometry:!1,needFeature:!1};li(t)||(t=gi(t));const i=t;let n=!0;try{n=function(t){if(!ui(t))return t;let e=ri(t);return ci(e),e=hi(e),e}(i)}catch(t){console.warn(`Failed to extract static filter. Filter will continue working, but at higher memory usage and slower framerate.\nThis is most likely a bug, please report this via https://github.com/mapbox/mapbox-gl-js/issues/new?assignees=&labels=&template=Bug_report.md\nand paste the contents of this message in the report.\nThank you!\nFilter Expression:\n${JSON.stringify(i,null,2)}\n `)}const r=oi[`filter_${e}`],s=Qe(n,r);let o=null;if("error"===s.result)throw new Error(s.value.map((t=>`${t.key}: ${t.message}`)).join(", "));o=(t,e,i)=>s.value.evaluate(t,e,{},i);let a=null,l=null;if(n!==i){const t=Qe(i,r);if("error"===t.result)throw new Error(t.value.map((t=>`${t.key}: ${t.message}`)).join(", "));a=(e,i,n,r,s)=>t.value.evaluate(e,i,{},n,void 0,void 0,r,s),l=!Lt(t.value.expression)}return{filter:o,dynamicFilter:a||void 0,needGeometry:fi(n),needFeature:!!l}};function li(t){if(!0===t||!1===t)return!0;if(!Array.isArray(t)||0===t.length)return!1;switch(t[0]){case"has":return t.length>=2&&"$id"!==t[1]&&"$type"!==t[1];case"in":return t.length>=3&&("string"!=typeof t[1]||Array.isArray(t[2]));case"!in":case"!has":case"none":return!1;case"==":case"!=":case">":case">=":case"<":case"<=":return 3!==t.length||Array.isArray(t[1])||Array.isArray(t[2]);case"any":case"all":for(const e of t.slice(1))if(!li(e)&&"boolean"!=typeof e)return!1;return!0;default:return!0}}function hi(t){if(!Array.isArray(t))return t;const e=function(t){if(di.has(t[0]))for(let e=1;ehi(t)))}function ci(t){let e=!1;const i=[];if("case"===t[0]){for(let n=1;n",">=","<","<=","to-boolean"]);function pi(t,e){return te?1:0}function fi(t){if(!Array.isArray(t))return!1;if("within"===t[0])return!0;for(let e=1;e"===e||"<="===e||">="===e?mi(t[1],t[2],e):"any"===e?(i=t.slice(1),["any"].concat(i.map(gi))):"all"===e?["all"].concat(t.slice(1).map(gi)):"none"===e?["all"].concat(t.slice(1).map(gi).map(vi)):"in"===e?yi(t[1],t.slice(2)):"!in"===e?vi(yi(t[1],t.slice(2))):"has"===e?_i(t[1]):"!has"===e?vi(_i(t[1])):"within"!==e||t;var i}function mi(t,e,i){switch(t){case"$type":return[`filter-type-${i}`,e];case"$id":return[`filter-id-${i}`,e];default:return[`filter-${i}`,t,e]}}function yi(t,e){if(0===e.length)return!1;switch(t){case"$type":return["filter-type-in",["literal",e]];case"$id":return["filter-id-in",["literal",e]];default:return e.length>200&&!e.some((t=>typeof t!=typeof e[0]))?["filter-in-large",t,["literal",e.sort(pi)]]:["filter-in-small",t,["literal",e]]}}function _i(t){switch(t){case"$type":return!0;case"$id":return["filter-has-id"];default:return["filter-has",t]}}function vi(t){return["!",t]}const xi=["type","source","source-layer","minzoom","maxzoom","filter","layout"];function bi(t,e){const i={};for(const e in t)"ref"!==e&&(i[e]=t[e]);return xi.forEach((t=>{t in e&&(i[t]=e[t])})),i}function wi(t){t=t.slice();const e=Object.create(null);for(let i=0;i=1.5?"@2x":"";return[`https://api.mapbox.com/v4/${s}/{z}/{x}/{y}${t}.webp?access_token=${e}`]}return Li.map((t=>`https://${t}.tiles.mapbox.com/v4/${s}/{z}/{x}/{y}.vector.pbf?access_token=${e}`))}const Oi={},Di={};let ji=0;function zi(t){return t.id||(t.id=ji++),t.id}function Ni(t){let e=Oi[t.id];return e||(e={},Oi[zi(t)]=e),e}function Gi(t){return t*Math.PI/180}const qi=function(){const t=[];for(let e=78271.51696402048;t.length<=24;e/=2)t.push(e);return t}();function Wi(t,e){if("undefined"!=typeof WorkerGlobalScope&&self instanceof WorkerGlobalScope&&"undefined"!=typeof OffscreenCanvas)return new OffscreenCanvas(t,e);const i=document.createElement("canvas");return i.width=t,i.height=e,i}function Yi(t,e){let i=0;const n=e.length;for(;ir)).then((t=>(t instanceof Request||(t=new Request(t)),t.headers.get("Accept")||t.headers.set("Accept","application/json"),n&&(n.request=t),fetch(t).then((function(t){return delete Vi[e],t.ok?t.json():Promise.reject(new Error("Error fetching source "+e))})).catch((function(t){return delete Vi[e],Promise.reject(new Error("Error fetching source "+e))})))));return Vi[e]=[r,s],s}function Ui(t,e){if("string"!=typeof t)return Promise.resolve(t);if(!t.trim().startsWith("{"))return Ki("Style",t=Pi(t,e.accessToken),e);try{const e=JSON.parse(t);return Promise.resolve(e)}catch(t){return Promise.reject(t)}}const Bi={};function Zi(t,e,i={}){const n=[e,JSON.stringify(t)].toString();let r=Bi[n];if(!r||i.transformRequest){let s;i.transformRequest&&(s=(t,e)=>{const n=i.transformRequest&&i.transformRequest(e,"Tiles")||e;if(t instanceof Ri)t.setLoader(((e,i,r)=>{(0,u.hq)((()=>n)).then((i=>{fetch(i).then((t=>t.arrayBuffer())).then((i=>{const n=t.getFormat().readFeatures(i,{extent:e,featureProjection:r});t.setFeatures(n)})).catch((e=>t.setState(Ci.A.ERROR)))}))}));else{const e=t.getImage();(0,u.hq)((()=>n)).then((i=>{i instanceof Request?fetch(i).then((t=>t.blob())).then((t=>{const i=URL.createObjectURL(t);e.addEventListener("load",(()=>URL.revokeObjectURL(i))),e.addEventListener("error",(()=>URL.revokeObjectURL(i))),e.src=i})).catch((e=>t.setState(Ci.A.ERROR))):e.src=i}))}});const o=t.url;if(o&&!t.tiles){const n=Fi(o,i.accessToken,i.accessTokenParam||"access_token",e||location.href);if(o.startsWith("mapbox://"))r=Promise.resolve({tileJson:Object.assign({},t,{url:void 0,tiles:n}),tileLoadFunction:s});else{const t={};r=Ki("Source",n[0],i,t).then((function(e){return e.tiles=e.tiles.map((function(n){return"tms"===e.scheme&&(n=n.replace("{y}","{-y}")),Fi(n,i.accessToken,i.accessTokenParam||"access_token",t.request.url)[0]})),Promise.resolve({tileJson:e,tileLoadFunction:s})}))}}else t=Object.assign({},t,{tiles:t.tiles.map((function(n){return"tms"===t.scheme&&(n=n.replace("{y}","{-y}")),Fi(n,i.accessToken,i.accessTokenParam||"access_token",e||location.href)[0]}))}),r=Promise.resolve({tileJson:Object.assign({},t),tileLoadFunction:s});Bi[n]=r}return r}function Hi(t,e,i,n){const r=[2*i*e.pixelRatio+e.width,2*i*e.pixelRatio+e.height],s=Wi(r[0],r[1]),o=s.getContext("2d");o.drawImage(t,e.x,e.y,e.width,e.height,i*e.pixelRatio,i*e.pixelRatio,e.width,e.height);const a=o.getImageData(0,0,r[0],r[1]);o.globalCompositeOperation="destination-over",o.fillStyle=`rgba(${255*n.r},${255*n.g},${255*n.b},${n.a})`;const l=a.data;for(let t=0,n=a.width;t0&&o.arc(t,r,i*e.pixelRatio,0,2*Math.PI);return o.fill(),s}function $i(t,e,i){const n=Math.max(0,Math.min(1,(i-t)/(e-t)));return n*n*(3-2*n)}function Ji(t,e,i){const n=Wi(e.width,e.height),r=n.getContext("2d");r.drawImage(t,e.x,e.y,e.width,e.height,0,0,e.width,e.height);const s=r.getImageData(0,0,e.width,e.height),o=s.data;for(let t=0,e=s.width;t0?(o[r+0]=Math.round(255*i.r*l),o[r+1]=Math.round(255*i.g*l),o[r+2]=Math.round(255*i.b*l),o[r+3]=Math.round(255*l)):o[r+3]=0}return r.putImageData(s,0,0),n}const Qi=Array(256).join(" ");function tn(t,e){if(e>=.05){let i="";const n=t.split("\n"),r=Qi.slice(0,Math.round(e/.1));for(let t=0,e=n.length;t0&&(i+="\n"),i+=n[t].split("").join(r);return i}return t}let en;function nn(){return en||(en=Wi(1,1).getContext("2d")),en}function rn(t,e){return nn().measureText(t).width+(t.length-1)*e}const sn={};function on(t,e,i,n){if(-1!==t.indexOf("\n")){const r=t.split("\n"),s=[];for(let t=0,o=r.length;t1){const t=nn();t.font=e;const r=t.measureText("M").width*i;let a="";const l=[];for(let t=0,e=o.length;t1;++t){const i=l[t];if(rn(i,n)<.35*r){const r=t>0?rn(l[t-1],n):1/0,s=t.7*r&&rn(s,n)<.6*r){const o=i.split(" "),a=o.pop();rn(a,n)<.2*r&&(l[t]=o.join(" "),l[t+1]=a+" "+s),e-=1}}s=l.join("\n")}else s=t;s=tn(s,n),sn[r]=s}return s}const an=/font-family: ?([^;]*);/,ln=/("|')/g;let hn;function cn(t){if(!hn){hn={};const t=document.styleSheets;for(let e=0,i=t.length;e`${t.key}: ${t.message}`)).join(", "));return i.value},gn={},mn={zoom:0};let yn,_n;function vn(t,e,i,n,r,s,o){const a=t.id;s||(s={},console.warn("No functionCache provided to getValue()")),s[a]||(s[a]={});const l=s[a];if(!l[i]){let n=(t[e]||gn)[i];const r=si[`${e}_${t.type}`][i];void 0===n&&(n=r.default);let s=(h=n,Array.isArray(h)&&h.length>0&&"string"==typeof h[0]&&h[0]in Be);if(!s&&$e(n)&&(n=function(t,e){let i=t.stops;if(!i)return function(t,e){const i=["get",t.property];if(void 0===t.default)return"string"===e.type?["string",i]:i;if("enum"===e.type)return["match",i,Object.keys(e.values),i,t.default];{const n=["color"===e.type?"to-color":e.type,i,m(t.default)];return"array"===e.type&&n.splice(1,0,e.value,e.length||null),n}}(t,e);const n=i&&"object"==typeof i[0][0],r=n||void 0!==t.property,s=n||!r;return i=i.map((t=>!r&&e.tokens&&"string"==typeof t[1]?[t[0],A(t[1])]:[t[0],m(t[1])])),n?function(t,e,i){const n={},r={},s=[];for(let e=0;ep)).then((t=>{t instanceof Request?fetch(t).then((t=>t.blob())).then((t=>{i=URL.createObjectURL(t),e.src=i})).catch((()=>{})):(e.crossOrigin="anonymous",e.src=t,i&&URL.revokeObjectURL(i))})),e.onload=function(){m=e,y=[e.width,e.height],t.changed(),e.onload=null}}else if("undefined"!=typeof WorkerGlobalScope&&self instanceof WorkerGlobalScope){const t=self;t.postMessage({action:"loadImage",src:p}),t.addEventListener("message",(function(t){"imageLoaded"===t.data.action&&t.data.src===p&&(m=t.data.image,y=[m.width,m.height])}))}const v=wi(e.layers),x={},b=[],w={},A={},E=Ni(e),C=function(t){let e=Di[t.id];return e||(e={},Di[zi(t)]=e),e}(e);let S;for(let t=0,n=v.length;t=O.maxzoom)continue;const N=O.filter;if(!N||bn(D,N,M,S,C)){let n,p,b,C,D,N;L=O;const G=x.index;if(3==k&&("fill"==O.type||"fill-extrusion"==O.type))if(p=vn(O,"paint",O.type+"-opacity",S,M,E,P),O.type+"-pattern"in z){const t=vn(O,"paint",O.type+"-pattern",S,M,E,P);if(t){const e="string"==typeof t?Cn(t,v):t.toString();if(m&&d&&d[e]){++F,N=I[F],N&&N.getFill()&&!N.getStroke()&&!N.getText()||(N=new h.Ay({fill:new s.A}),I[F]=N),b=N.getFill(),N.setZIndex(G);const t=e+"."+p;let i=A[t];if(!i){const n=d[e],r=Wi(n.width,n.height),s=r.getContext("2d");s.globalAlpha=p,s.drawImage(m,n.x,n.y,n.width,n.height,0,0,n.width,n.height),i=s.createPattern(r,"repeat"),A[t]=i}b.setColor(i)}}}else n=An(vn(O,"paint",O.type+"-color",S,M,E,P),p),O.type+"-outline-color"in z&&(D=An(vn(O,"paint",O.type+"-outline-color",S,M,E,P),p)),D||(D=n),(n||D)&&(++F,N=I[F],(!N||n&&!N.getFill()||!n&&N.getFill()||D&&!N.getStroke()||!D&&N.getStroke()||N.getText())&&(N=new h.Ay({fill:n?new s.A:void 0,stroke:D?new l.A:void 0}),I[F]=N),n&&(b=N.getFill(),b.setColor(n)),D&&(C=N.getStroke(),C.setColor(D),C.setWidth(.5)),N.setZIndex(G));if(1!=k&&"line"==O.type){n="line-pattern"in z?void 0:An(vn(O,"paint","line-color",S,M,E,P),vn(O,"paint","line-opacity",S,M,E,P));const t=vn(O,"paint","line-width",S,M,E,P);n&&t>0&&(++F,N=I[F],N&&N.getStroke()&&!N.getFill()&&!N.getText()||(N=new h.Ay({stroke:new l.A}),I[F]=N),C=N.getStroke(),C.setLineCap(vn(O,"layout","line-cap",S,M,E,P)),C.setLineJoin(vn(O,"layout","line-join",S,M,E,P)),C.setMiterLimit(vn(O,"layout","line-miter-limit",S,M,E,P)),C.setColor(n),C.setWidth(t),C.setLineDash(z["line-dasharray"]?vn(O,"paint","line-dasharray",S,M,E,P).map((function(e){return e*t})):null),N.setZIndex(G))}let q,W,Y,X,V,K,U,B,Z,H=!1,$=null,J=0;if((1==k||2==k)&&"icon-image"in j){const e=vn(O,"layout","icon-image",S,M,E,P);if(e){let n;q="string"==typeof e?Cn(e,v):e.toString();const r=g?g(t,q):void 0;if(m&&d&&d[q]||r){const t=vn(O,"layout","icon-rotation-alignment",S,M,E,P);if(2==k){const e=i.getGeometry();if(e.getFlatMidpoint||e.getFlatMidpoints){const i=e.getExtent();if(Math.sqrt(Math.max(Math.pow((i[2]-i[0])/u,2),Math.pow((i[3]-i[1])/u,2)))>150){const i="MultiLineString"===e.getType()?e.getFlatMidpoints():e.getFlatMidpoint();if(_n||(yn=[NaN,NaN],_n=new a.Ay("Point",yn,[],2,{},void 0)),n=_n,yn[0]=i[0],yn[1]=i[1],"line"===vn(O,"layout","symbol-placement",S,M,E,P)&&"map"===t){const t=e.getStride(),n=e.getFlatCoordinates();for(let e=0,r=n.length-t;e=l){J=Math.atan2(s-a,o-r);break}}}}}}if(2!==k||n){const e=vn(O,"layout","icon-size",S,M,E,P),i=void 0!==z["icon-color"]?vn(O,"paint","icon-color",S,M,E,P):null;if(!i||0!==i.a){const n=vn(O,"paint","icon-halo-color",S,M,E,P),s=vn(O,"paint","icon-halo-width",S,M,E,P);let a=`${q}.${e}.${s}.${n}`;if(null!==i&&(a+=`.${i}`),W=w[a],!W){const l=xn(O,S,M,"icon",E);let h;"icon-offset"in j&&(h=vn(O,"layout","icon-offset",S,M,E,P).slice(0),h[0]*=e,h[1]*=-e);let c=i?[255*i.r,255*i.g,255*i.b,i.a]:void 0;if(r){const i={color:c,rotateWithView:"map"===t,displacement:h,declutterMode:l,scale:e};"string"==typeof r?i.src=r:(i.img=r,i.imgSize=[r.width,r.height]),W=new o.A(i)}else{const r=d[q];let a,u,p;s?r.sdf?(a=Hi(Ji(m,r,i||[0,0,0,1]),{x:0,y:0,width:r.width,height:r.height,pixelRatio:r.pixelRatio},s,n),c=void 0):a=Hi(m,r,s,n):(r.sdf?(_||(_=Ji(m,{x:0,y:0,width:y[0],height:y[1]},{r:1,g:1,b:1,a:1})),a=_):a=m,u=[r.width,r.height],p=[r.x,r.y]),W=new o.A({color:c,img:a,imgSize:y,size:u,offset:p,rotateWithView:"map"===t,scale:e/r.pixelRatio,displacement:h,declutterMode:l})}w[a]=W}}W&&(++F,N=I[F],N&&N.getImage()&&!N.getFill()&&!N.getStroke()||(N=new h.Ay,I[F]=N),N.setGeometry(n),W.setRotation(J+Gi(vn(O,"layout","icon-rotate",S,M,E,P))),W.setOpacity(vn(O,"paint","icon-opacity",S,M,E,P)),W.setAnchor(pn[vn(O,"layout","icon-anchor",S,M,E,P)]),N.setImage(W),$=N.getText(),N.setText(void 0),N.setZIndex(G),H=!0,Y=!1)}else Y=!0}}}if(1==k&&"circle"===O.type){++F,N=I[F],N&&N.getImage()&&!N.getFill()&&!N.getStroke()||(N=new h.Ay,I[F]=N);const t="circle-radius"in z?vn(O,"paint","circle-radius",S,M,E,P):5,e=An(vn(O,"paint","circle-stroke-color",S,M,E,P),vn(O,"paint","circle-stroke-opacity",S,M,E,P)),i=vn(O,"paint","circle-translate",S,M,E,P),n=An(vn(O,"paint","circle-color",S,M,E,P),vn(O,"paint","circle-opacity",S,M,E,P)),o=vn(O,"paint","circle-stroke-width",S,M,E,P),a=t+"."+e+"."+n+"."+o+"."+i[0]+"."+i[1];W=w[a],W||(W=new r.A({radius:t,displacement:[i[0],-i[1]],stroke:e&&o>0?new l.A({width:o,color:e}):void 0,fill:n?new s.A({color:n}):void 0,declutterMode:"none"}),w[a]=W),N.setImage(W),$=N.getText(),N.setText(void 0),N.setGeometry(void 0),N.setZIndex(G),H=!0}if("text-field"in j){U=Math.round(vn(O,"layout","text-size",S,M,E,P));const t=vn(O,"layout","text-font",S,M,E,P);K=vn(O,"layout","text-line-height",S,M,E,P),V=Ai(f?f(t,e.metadata?e.metadata["ol:webfonts"]:void 0):t,U,K),V.includes("sans-serif")||(V+=",sans-serif"),B=vn(O,"layout","text-letter-spacing",S,M,E,P),Z=vn(O,"layout","text-max-width",S,M,E,P);const i=vn(O,"layout","text-field",S,M,E,P);X="object"==typeof i&&i.sections?1===i.sections.length?i.toString():i.sections.reduce(((e,i,n)=>{const r=i.fontStack?i.fontStack.split(","):t,s=Ai(f?f(r):r,U*(i.scale||1),K);let o=i.text;if("\n"===o)return e.push("\n",""),e;if(2==k)return e.push(tn(o,B),s),e;o=on(o,s,Z,B).split("\n");for(let t=0,i=o.length;t0&&e.push("\n",""),e.push(o[t],s);return e}),[]):Cn(i,v).trim(),p=vn(O,"paint","text-opacity",S,M,E,P)}if(X&&p&&!Y){H||(++F,N=I[F],N&&N.getText()&&!N.getFill()&&!N.getStroke()||(N=new h.Ay,I[F]=N),N.setImage(void 0),N.setGeometry(void 0));const t=xn(O,S,M,"text",E);N.getText()||N.setText($),$=N.getText(),(!$||"getDeclutterMode"in $&&$.getDeclutterMode()!==t)&&($=new c.A({padding:[2,2,2,2],declutterMode:t}),N.setText($));const e=vn(O,"layout","text-transform",S,M,E,P);"uppercase"==e?X=Array.isArray(X)?X.map(((t,e)=>e%2?t:t.toUpperCase())):X.toUpperCase():"lowercase"==e&&(X=Array.isArray(X)?X.map(((t,e)=>e%2?t:t.toLowerCase())):X.toLowerCase());const i=Array.isArray(X)?X:2==k?tn(X,B):on(X,V,Z,B);if($.setText(i),$.setFont(V),$.setRotation(Gi(vn(O,"layout","text-rotate",S,M,E,P))),"function"==typeof $.setKeepUpright){const t=vn(O,"layout","text-keep-upright",S,M,E,P);$.setKeepUpright(t)}const n=vn(O,"layout","text-anchor",S,M,E,P),r=H||1==k?"point":vn(O,"layout","symbol-placement",S,M,E,P);let s;if("line-center"===r?($.setPlacement("line"),s="center"):$.setPlacement(r),"line"===r&&"function"==typeof $.setRepeat){const t=vn(O,"layout","symbol-spacing",S,M,E,P);$.setRepeat(2*t)}$.setOverflow("point"===r);let o=vn(O,"paint","text-halo-width",S,M,E,P);const a=vn(O,"layout","text-offset",S,M,E,P),l=vn(O,"paint","text-translate",S,M,E,P);let u=0,d=0;if("point"==r){s="center",-1!==n.indexOf("left")?(s="left",d=o):-1!==n.indexOf("right")&&(s="right",d=-o);const t=vn(O,"layout","text-rotation-alignment",S,M,E,P);$.setRotateWithView("map"==t)}else $.setMaxAngle(Gi(vn(O,"layout","text-max-angle",S,M,E,P))*X.length/i.length),$.setRotateWithView(!1);$.setTextAlign(s);let f="middle";0==n.indexOf("bottom")?(f="bottom",u=-o-.5*(K-1)*U):0==n.indexOf("top")&&(f="top",u=o+.5*(K-1)*U),$.setTextBaseline(f);const g=vn(O,"layout","text-justify",S,M,E,P);$.setJustify("auto"===g?void 0:g),$.setOffsetX(a[0]*U+d+l[0]),$.setOffsetY(a[1]*U+u+l[1]),R.setColor(An(vn(O,"paint","text-color",S,M,E,P),p)),$.setFill(R);const m=An(vn(O,"paint","text-halo-color",S,M,E,P),p);if(m&&o>0){T.setColor(m),o*=2;const t=.5*U;T.setWidth(o<=t?o:t),$.setStroke(T)}else $.setStroke(void 0);const y=vn(O,"layout","text-padding",S,M,E,P),_=$.getPadding();y!==_[0]&&(_[0]=y,_[1]=y,_[2]=y,_[3]=y),N.setZIndex(G)}}}return F>-1?(I.length=F+1,Sn&&("set"in i?i.set("mapbox-layer",L):i.getProperties()["mapbox-layer"]=L),I):void 0};return t.setStyle(k),t.set("mapbox-source",S),t.set("mapbox-layers",b),t.set("mapbox-featurestate",t.get("mapbox-featurestate")||{}),k}var In=i(1365),kn=i(764);class Mn extends kn.A{constructor(t){super(t=t||{})}}const Pn=Mn;var Ln=i(1623),Fn=i(6141),On=i(2703),Dn=i(9703),jn=i(915),zn=i(594);class Nn extends Ln.A{constructor(t){super(t),this.image=null}getImage(){return this.image?this.image.getImage():null}prepareFrame(t){const e=t.layerStatesArray[t.layerIndex],i=t.pixelRatio,n=t.viewState,r=n.resolution,s=this.getLayer().getSource(),o=t.viewHints;let a=t.extent;if(void 0!==e.extent&&(a=(0,jn._N)(a,(0,zn.SD)(e.extent,n.projection))),!o[On.A.ANIMATING]&&!o[On.A.INTERACTING]&&!(0,jn.Im)(a))if(s){const t=n.projection,e=s.getImage(a,r,i,t);e&&(this.loadImage(e)?this.image=e:e.getState()===Fn.A.EMPTY&&(this.image=null))}else this.image=null;return!!this.image}getData(t){const e=this.frameState;if(!e)return null;const i=this.getLayer(),n=(0,Dn.Bb)(e.pixelToCoordinateTransform,t.slice()),r=i.getExtent();if(r&&!(0,jn.Ym)(r,n))return null;const s=this.image.getExtent(),o=this.image.getImage(),a=(0,jn.RG)(s),l=Math.floor(o.width*((n[0]-s[0])/a));if(l<0||l>=o.width)return null;const h=(0,jn.Oq)(s),c=Math.floor(o.height*((s[3]-n[1])/h));return c<0||c>=o.height?null:this.getImageData(o,l,c)}renderFrame(t,e){const i=this.image,n=i.getExtent(),r=i.getResolution(),[s,o]=Array.isArray(r)?r:[r,r],a=i.getPixelRatio(),l=t.layerStatesArray[t.layerIndex],h=t.pixelRatio,c=t.viewState,u=c.center,d=c.resolution,p=h*s/(d*a),f=h*o/(d*a);this.prepareContainer(t,e);const g=this.context.canvas.width,m=this.context.canvas.height,y=this.getRenderContext(t);let _=!1,v=!0;if(l.extent){const e=(0,zn.SD)(l.extent,c.projection);v=(0,jn.HY)(e,t.extent),_=v&&!(0,jn.ms)(e,t.extent),_&&this.clipUnrotated(y,t,e)}const x=i.getImage(),b=(0,Dn.Zz)(this.tempTransform,g/2,m/2,p,f,0,a*(n[0]-u[0])/s,a*(u[1]-n[3])/o);this.renderedResolution=o*h/a;const w=x.width*b[0],A=x.height*b[3];if(this.getLayer().getSource().getInterpolate()||(y.imageSmoothingEnabled=!1),this.preRender(y,t),v&&w>=.5&&A>=.5){const t=b[4],e=b[5],i=l.opacity;1!==i&&(y.save(),y.globalAlpha=i),y.drawImage(x,0,0,+x.width,+x.height,t,e,w,A),1!==i&&y.restore()}return this.postRender(this.context,t),_&&y.restore(),y.imageSmoothingEnabled=!0,this.container}}const Gn=Nn,qn=class extends Pn{constructor(t){super(t)}createRenderer(){return new Gn(this)}getData(t){return super.getData(t)}};var Wn=i(5598),Yn=i(303),Xn=i(1217),Vn=i(6702),Kn=i(503),Un=i(2871);const Bn=4294967296,Zn=1/Bn,Hn="undefined"==typeof TextDecoder?null:new TextDecoder("utf-8");class $n{constructor(t=new Uint8Array(16)){this.buf=ArrayBuffer.isView(t)?t:new Uint8Array(t),this.dataView=new DataView(this.buf.buffer),this.pos=0,this.type=0,this.length=this.buf.length}readFields(t,e,i=this.length){for(;this.pos>3,r=this.pos;this.type=7&i,t(n,e,this),this.pos===r&&this.skip(i)}return e}readMessage(t,e){return this.readFields(t,e,this.readVarint()+this.pos)}readFixed32(){const t=this.dataView.getUint32(this.pos,!0);return this.pos+=4,t}readSFixed32(){const t=this.dataView.getInt32(this.pos,!0);return this.pos+=4,t}readFixed64(){const t=this.dataView.getUint32(this.pos,!0)+this.dataView.getUint32(this.pos+4,!0)*Bn;return this.pos+=8,t}readSFixed64(){const t=this.dataView.getUint32(this.pos,!0)+this.dataView.getInt32(this.pos+4,!0)*Bn;return this.pos+=8,t}readFloat(){const t=this.dataView.getFloat32(this.pos,!0);return this.pos+=4,t}readDouble(){const t=this.dataView.getFloat64(this.pos,!0);return this.pos+=8,t}readVarint(t){const e=this.buf;let i,n;return n=e[this.pos++],i=127&n,n<128?i:(n=e[this.pos++],i|=(127&n)<<7,n<128?i:(n=e[this.pos++],i|=(127&n)<<14,n<128?i:(n=e[this.pos++],i|=(127&n)<<21,n<128?i:(n=e[this.pos],i|=(15&n)<<28,function(t,e,i){const n=i.buf;let r,s;if(s=n[i.pos++],r=(112&s)>>4,s<128)return Jn(t,r,e);if(s=n[i.pos++],r|=(127&s)<<3,s<128)return Jn(t,r,e);if(s=n[i.pos++],r|=(127&s)<<10,s<128)return Jn(t,r,e);if(s=n[i.pos++],r|=(127&s)<<17,s<128)return Jn(t,r,e);if(s=n[i.pos++],r|=(127&s)<<24,s<128)return Jn(t,r,e);if(s=n[i.pos++],r|=(1&s)<<31,s<128)return Jn(t,r,e);throw new Error("Expected varint not more than 10 bytes")}(i,t,this)))))}readVarint64(){return this.readVarint(!0)}readSVarint(){const t=this.readVarint();return t%2==1?(t+1)/-2:t/2}readBoolean(){return Boolean(this.readVarint())}readString(){const t=this.readVarint()+this.pos,e=this.pos;return this.pos=t,t-e>=12&&Hn?Hn.decode(this.buf.subarray(e,t)):function(t,e,i){let n="",r=e;for(;r239?4:e>223?3:e>191?2:1;if(r+h>i)break;1===h?e<128&&(l=e):2===h?(s=t[r+1],128==(192&s)&&(l=(31&e)<<6|63&s,l<=127&&(l=null))):3===h?(s=t[r+1],o=t[r+2],128==(192&s)&&128==(192&o)&&(l=(15&e)<<12|(63&s)<<6|63&o,(l<=2047||l>=55296&&l<=57343)&&(l=null))):4===h&&(s=t[r+1],o=t[r+2],a=t[r+3],128==(192&s)&&128==(192&o)&&128==(192&a)&&(l=(15&e)<<18|(63&s)<<12|(63&o)<<6|63&a,(l<=65535||l>=1114112)&&(l=null))),null===l?(l=65533,h=1):l>65535&&(l-=65536,n+=String.fromCharCode(l>>>10&1023|55296),l=56320|1023&l),n+=String.fromCharCode(l),r+=h}return n}(this.buf,e,t)}readBytes(){const t=this.readVarint()+this.pos,e=this.buf.subarray(this.pos,t);return this.pos=t,e}readPackedVarint(t=[],e){const i=this.readPackedEnd();for(;this.pos127;);else if(2===e)this.pos=this.readVarint()+this.pos;else if(5===e)this.pos+=4;else{if(1!==e)throw new Error(`Unimplemented type: ${e}`);this.pos+=8}}writeTag(t,e){this.writeVarint(t<<3|e)}realloc(t){let e=this.length||16;for(;e268435455||t<0?function(t,e){let i,n;if(t>=0?(i=t%4294967296|0,n=t/4294967296|0):(i=~(-t%4294967296),n=~(-t/4294967296),4294967295^i?i=i+1|0:(i=0,n=n+1|0)),t>=0x10000000000000000||t<-0x10000000000000000)throw new Error("Given varint doesn't fit into 10 bytes");e.realloc(10),function(t,e,i){i.buf[i.pos++]=127&t|128,t>>>=7,i.buf[i.pos++]=127&t|128,t>>>=7,i.buf[i.pos++]=127&t|128,t>>>=7,i.buf[i.pos++]=127&t|128,t>>>=7,i.buf[i.pos]=127&t}(i,0,e),function(t,e){const i=(7&t)<<4;e.buf[e.pos++]|=i|((t>>>=3)?128:0),t&&(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),t&&(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),t&&(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),t&&(e.buf[e.pos++]=127&t|((t>>>=7)?128:0),t&&(e.buf[e.pos++]=127&t)))))}(n,e)}(t,this):(this.realloc(4),this.buf[this.pos++]=127&t|(t>127?128:0),t<=127||(this.buf[this.pos++]=127&(t>>>=7)|(t>127?128:0),t<=127||(this.buf[this.pos++]=127&(t>>>=7)|(t>127?128:0),t<=127||(this.buf[this.pos++]=t>>>7&127))))}writeSVarint(t){this.writeVarint(t<0?2*-t-1:2*t)}writeBoolean(t){this.writeVarint(+t)}writeString(t){t=String(t),this.realloc(4*t.length),this.pos++;const e=this.pos;this.pos=function(t,e,i){for(let n,r,s=0;s55295&&n<57344){if(!r){n>56319||s+1===e.length?(t[i++]=239,t[i++]=191,t[i++]=189):r=n;continue}if(n<56320){t[i++]=239,t[i++]=191,t[i++]=189,r=n;continue}n=r-55296<<10|n-56320|65536,r=null}else r&&(t[i++]=239,t[i++]=191,t[i++]=189,r=null);n<128?t[i++]=n:(n<2048?t[i++]=n>>6|192:(n<65536?t[i++]=n>>12|224:(t[i++]=n>>18|240,t[i++]=n>>12&63|128),t[i++]=n>>6&63|128),t[i++]=63&n|128)}return i}(this.buf,t,this.pos);const i=this.pos-e;i>=128&&Qn(e,i,this),this.pos=e-1,this.writeVarint(i),this.pos+=i}writeFloat(t){this.realloc(4),this.dataView.setFloat32(this.pos,t,!0),this.pos+=4}writeDouble(t){this.realloc(8),this.dataView.setFloat64(this.pos,t,!0),this.pos+=8}writeBytes(t){const e=t.length;this.writeVarint(e),this.realloc(e);for(let i=0;i=128&&Qn(i,n,this),this.pos=i-1,this.writeVarint(n),this.pos+=n}writeMessage(t,e,i){this.writeTag(t,2),this.writeRawMessage(e,i)}writePackedVarint(t,e){e.length&&this.writeMessage(t,tr,e)}writePackedSVarint(t,e){e.length&&this.writeMessage(t,er,e)}writePackedBoolean(t,e){e.length&&this.writeMessage(t,rr,e)}writePackedFloat(t,e){e.length&&this.writeMessage(t,ir,e)}writePackedDouble(t,e){e.length&&this.writeMessage(t,nr,e)}writePackedFixed32(t,e){e.length&&this.writeMessage(t,sr,e)}writePackedSFixed32(t,e){e.length&&this.writeMessage(t,or,e)}writePackedFixed64(t,e){e.length&&this.writeMessage(t,ar,e)}writePackedSFixed64(t,e){e.length&&this.writeMessage(t,lr,e)}writeBytesField(t,e){this.writeTag(t,2),this.writeBytes(e)}writeFixed32Field(t,e){this.writeTag(t,5),this.writeFixed32(e)}writeSFixed32Field(t,e){this.writeTag(t,5),this.writeSFixed32(e)}writeFixed64Field(t,e){this.writeTag(t,1),this.writeFixed64(e)}writeSFixed64Field(t,e){this.writeTag(t,1),this.writeSFixed64(e)}writeVarintField(t,e){this.writeTag(t,0),this.writeVarint(e)}writeSVarintField(t,e){this.writeTag(t,0),this.writeSVarint(e)}writeStringField(t,e){this.writeTag(t,2),this.writeString(e)}writeFloatField(t,e){this.writeTag(t,5),this.writeFloat(e)}writeDoubleField(t,e){this.writeTag(t,1),this.writeDouble(e)}writeBooleanField(t,e){this.writeVarintField(t,+e)}}function Jn(t,e,i){return i?4294967296*e+(t>>>0):4294967296*(e>>>0)+(t>>>0)}function Qn(t,e,i){const n=e<=16383?1:e<=2097151?2:e<=268435455?3:Math.floor(Math.log(e)/(7*Math.LN2));i.realloc(n);for(let e=i.pos-1;e>=t;e--)i.buf[e+n]=i.buf[e]}function tr(t,e){for(let i=0;i>3}if(o--,1===s||2===s)a+=t.readSVarint(),l+=t.readSVarint(),1===s&&h>c&&(n.push(h),c=h),i.push(a,l),h+=2;else{if(7!==s)throw new Error("Invalid command found in the PBF");h>c&&(i.push(i[c],i[c+1]),h+=2)}}h>c&&(n.push(h),c=h)}createFeature_(t,e,i){const n=e.type;if(0===n)return null;let r;const s=e.properties;let o;this.idProperty_?(o=s[this.idProperty_],delete s[this.idProperty_]):o=e.id,s[this.layerName_]=e.layer.name;const l=[],h=[];this.readRawGeometry_(t,e,l,h);const c=function(t,e){let i;return 1===t?i=1===e?"Point":"MultiPoint":2===t?i=1===e?"LineString":"MultiLineString":3===t&&(i="Polygon"),i}(n,h.length);if(this.featureClass===a.Ay)r=new this.featureClass(c,l,h,2,s,o),r.transform(i.dataProjection);else{let t;if("Polygon"==c){const e=(0,dr.yJ)(l,h);t=e.length>1?new Un.A(l,"XY",e):new cr.Ay(l,"XY",h)}else t="Point"===c?new hr.A(l,"XY"):"LineString"===c?new Xn.A(l,"XY"):"MultiPoint"===c?new Kn.A(l,"XY"):"MultiLineString"===c?new Vn.A(l,"XY",h):null;r=new(0,this.featureClass),this.geometryName_&&r.setGeometryName(this.geometryName_);const e=(0,Yn.hX)(t,!1,i);r.setGeometry(e),void 0!==o&&r.setId(o),r.setProperties(s,!0)}return r}getType(){return"arraybuffer"}readFeatures(t,e){const i=this.layers_;e=this.adaptOptions(e);const n=(0,zn.Jt)(e.dataProjection);n.setWorldExtent(e.extent),e.dataProjection=n;const r=new $n(t),s=r.readFields(fr,{}),o=[];for(const t in s){if(i&&!i.includes(t))continue;const a=s[t],l=a?[0,0,a.extent,a.extent]:null;n.setExtent(l);for(let t=0,i=a.length;t>3)?i.readString():2===t?i.readFloat():3===t?i.readDouble():4===t?i.readVarint64():5===t?i.readVarint():6===t?i.readSVarint():7===t?i.readBoolean():null;e.values.push(n)}}function mr(t,e,i){if(1==t)e.id=i.readVarint();else if(2==t){const t=i.readVarint()+i.pos;for(;i.pos{const e=this.sourceImage_.getState();e!=Fn.A.LOADED&&e!=Fn.A.ERROR||(this.unlistenSource_(),this.reproject_())})),this.sourceImage_.load())}}unlistenSource_(){(0,kr.JH)(this.sourceListenerKey_),this.sourceListenerKey_=null}}const Pr=Mr;var Lr=i(6444),Fr=i(1597),Or=i(6514);class Dr extends br.Ay{constructor(t,e){super(t),this.image=e}}class jr extends Lr.A{constructor(t){super({attributions:t.attributions,projection:t.projection,state:t.state,interpolate:void 0===t.interpolate||t.interpolate}),this.on,this.once,this.un,this.loader=t.loader||null,this.resolutions_=void 0!==t.resolutions?t.resolutions:null,this.reprojectedImage_=null,this.reprojectedRevision_=0,this.image=null,this.wantedExtent_,this.wantedResolution_,this.static_=!!t.loader&&0===t.loader.length,this.wantedProjection_=null}getResolutions(){return this.resolutions_}setResolutions(t){this.resolutions_=t}findNearestResolution(t){const e=this.getResolutions();return e&&(t=e[(0,Or.FT)(e,t,0)]),t}getImage(t,e,i,n){const r=this.getProjection();if(!r||!n||(0,zn.tI)(r,n))return r&&(n=r),this.getImageInternal(t,e,i,n);if(this.reprojectedImage_){if(this.reprojectedRevision_==this.getRevision()&&(0,zn.tI)(this.reprojectedImage_.getProjection(),n)&&this.reprojectedImage_.getResolution()==e&&(0,jn.aI)(this.reprojectedImage_.getExtent(),t))return this.reprojectedImage_;this.reprojectedImage_.dispose(),this.reprojectedImage_=null}return this.reprojectedImage_=new Pr(r,n,t,e,i,((t,e,i)=>this.getImageInternal(t,e,i,r)),this.getInterpolate()),this.reprojectedRevision_=this.getRevision(),this.reprojectedImage_}getImageInternal(t,e,i,n){if(this.loader){const r=function(t,e,i,n){const r=e/i,s=(0,jn.q1)(t),o=(0,Fr.mk)((0,jn.RG)(t)/r,4),a=(0,Fr.mk)((0,jn.Oq)(t)/r,4),l=o+2*(0,Fr.mk)(0*o/2,4),h=a+2*(0,Fr.mk)(0*a/2,4);return(0,jn.Bg)(s,r,0,[l,h])}(t,e,i),s=this.findNearestResolution(e);if(this.image&&(this.static_||this.wantedProjection_===n&&(this.wantedExtent_&&(0,jn.ms)(this.wantedExtent_,r)||(0,jn.ms)(this.image.getExtent(),r))&&(this.wantedResolution_&&Ir(this.wantedResolution_)===s||Ir(this.image.getResolution())===s)))return this.image;this.wantedProjection_=n,this.wantedExtent_=r,this.wantedResolution_=s,this.image=new Ar.Ay(r,s,i,this.loader),this.image.addEventListener(wr.A.CHANGE,this.handleImageChange.bind(this))}return this.image}handleImageChange(t){const e=t.target;let i;switch(e.getState()){case Fn.A.LOADING:this.loading=!0,i="imageloadstart";break;case Fn.A.LOADED:this.loading=!1,i="imageloadend";break;case Fn.A.ERROR:this.loading=!1,i="imageloaderror";break;default:return}this.hasListener(i)&&this.dispatchEvent(new Dr(i,e))}}const zr=jr;var Nr=i(5360);class Gr extends kn.A{constructor(t){t=t||{};const e=Object.assign({},t),i=t.cacheSize;delete t.cacheSize,delete e.preload,delete e.useInterimTilesOnError,super(e),this.on,this.once,this.un,this.cacheSize_=i,this.setPreload(void 0!==t.preload?t.preload:0),this.setUseInterimTilesOnError(void 0===t.useInterimTilesOnError||t.useInterimTilesOnError)}getCacheSize(){return this.cacheSize_}getPreload(){return this.get(Nr.A.PRELOAD)}setPreload(t){this.set(Nr.A.PRELOAD,t)}getUseInterimTilesOnError(){return this.get(Nr.A.USE_INTERIM_TILES_ON_ERROR)}setUseInterimTilesOnError(t){this.set(Nr.A.USE_INTERIM_TILES_ON_ERROR,t)}getData(t){return super.getData(t)}}const qr=Gr;var Wr=i(441);const Yr=class extends qr{constructor(t){super(t)}createRenderer(){return new Wr.A(this,{cacheSize:this.getCacheSize()})}};var Xr=i(6813),Vr=i(4969),Kr=i(186);class Ur extends Vr.A{clear(){for(;this.getCount()>0;)this.pop().release();super.clear()}expireCache(t){for(;this.canExpireCache()&&!(this.peekLast().getKey()in t);)this.pop().release()}pruneExceptNewestZ(){if(0===this.getCount())return;const t=this.peekFirstKey(),e=(0,Kr.K)(t)[0];this.forEach((t=>{t.tileCoord[0]!==e&&(this.remove((0,Kr.i7)(t.tileCoord)),t.release())}))}}const Br=Ur;var Zr=i(588),Hr=i(1110),$r=i(7115),Jr=i(4350),Qr=i(6782);const ts=[0,0,0],es=class{constructor(t){let e;if(this.minZoom=void 0!==t.minZoom?t.minZoom:0,this.resolutions_=t.resolutions,(0,Zr.v)((0,Or.WC)(this.resolutions_,((t,e)=>e-t),!0),"`resolutions` must be sorted in descending order"),!t.origins)for(let t=0,i=this.resolutions_.length-1;t{const n=new Hr.A(Math.min(0,t[0]),Math.max(t[0]-1,-1),Math.min(0,t[1]),Math.max(t[1]-1,-1));if(i){const t=this.getTileRangeForExtentAndZ(i,e);n.minX=Math.max(t.minX,n.minX),n.maxX=Math.min(t.maxX,n.maxX),n.minY=Math.max(t.minY,n.minY),n.maxY=Math.min(t.maxY,n.maxY)}return n})):i&&this.calculateTileRanges_(i)}forEachTileCoord(t,e,i){const n=this.getTileRangeForExtentAndZ(t,e);for(let t=n.minX,r=n.maxX;t<=r;++t)for(let r=n.minY,s=n.maxY;r<=s;++r)i([e,t,r])}forEachTileCoordParentTileRange(t,e,i,n){let r,s,o,a=null,l=t[0]-1;for(2===this.zoomFactor_?(s=t[1],o=t[2]):a=this.getTileCoordExtent(t,n);l>=this.minZoom;){if(void 0!==s&&void 0!==o?(s=Math.floor(s/2),o=Math.floor(o/2),r=(0,Hr.N)(s,s,o,o,i)):r=this.getTileRangeForExtentAndZ(a,l,i),e(l,r))return!0;--l}return!1}getExtent(){return this.extent_}getMaxZoom(){return this.maxZoom}getMinZoom(){return this.minZoom}getOrigin(t){return this.origin_?this.origin_:this.origins_[t]}getResolution(t){return this.resolutions_[t]}getResolutions(){return this.resolutions_}getTileCoordChildTileRange(t,e,i){if(t[0]this.maxZoom||e0?n:Math.max(s/i[0],r/i[1]);const o=e+1,a=new Array(o);for(let t=0;tthis.maxQueueLength_;)this.queue_.shift().callback(null,null)}dispatch_(){if(this.running_||0===this.queue_.length)return;const t=this.queue_.shift();this.job_=t;const e=t.inputs[0].width,i=t.inputs[0].height,n=t.inputs.map((function(t){return t.data.buffer})),r=this.workers_.length;if(this.running_=r,1===r)return void this.workers_[0].postMessage({buffers:n,meta:t.meta,imageOps:this.imageOps_,width:e,height:i},n);const s=t.inputs[0].data.length,o=4*Math.ceil(s/4/r);for(let s=0;sthis.getTileInternal(t,e,i,n,s)),this.reprojectionErrorThreshold_,this.renderReprojectionEdges_,this.tileOptions);return f.key=c,l?o.replace(h,f):o.set(h,f),f}getTileInternal(t,e,i,n,r){const s=(0,Kr.dp)(t,e,i),o=this.getKey();if(!this.tileCache.containsKey(s)){const a=this.createTile_(t,e,i,n,r,o);return this.tileCache.set(s,a),a}let a=this.tileCache.get(s);return a.key!=o&&(a=this.createTile_(t,e,i,n,r,o),this.tileCache.replace(s,a)),a}setRenderReprojectionEdges(t){if(this.renderReprojectionEdges_!=t){this.renderReprojectionEdges_=t;for(const t in this.tileCacheForProjection)this.tileCacheForProjection[t].clear();this.changed()}}setTileGridForProjection(t,e){const i=(0,zn.Jt)(t);if(i){const t=(0,Ii.v6)(i);t in this.tileGridForProjection||(this.tileGridForProjection[t]=e)}}clear(){super.clear();for(const t in this.tileCacheForProjection)this.tileCacheForProjection[t].clear()}};Error,Error;const Ms=class extends ks{constructor(t){if(super({attributions:t.attributions,cacheSize:t.cacheSize,crossOrigin:t.crossOrigin,interpolate:t.interpolate,projection:(0,zn.Jt)("EPSG:3857"),reprojectionErrorThreshold:t.reprojectionErrorThreshold,state:"loading",tileLoadFunction:t.tileLoadFunction,wrapX:void 0===t.wrapX||t.wrapX,transition:t.transition,zDirection:t.zDirection}),this.tileJSON_=null,this.tileSize_=t.tileSize,t.url)if(t.jsonp)!function(t,e,i,n){const r=document.createElement("script"),s="olc_"+(0,Ii.v6)(e);function o(){delete window[s],r.parentNode.removeChild(r)}r.async=!0,r.src=t+(t.includes("?")?"&":"?")+"callback="+s;const a=setTimeout((function(){o(),i&&i()}),1e4);window[s]=function(t){clearTimeout(a),o(),e(t)},document.head.appendChild(r)}(t.url,this.handleTileJSONResponse.bind(this),this.handleTileJSONError.bind(this));else{const e=new XMLHttpRequest;e.addEventListener("load",this.onXHRLoad_.bind(this)),e.addEventListener("error",this.onXHRError_.bind(this)),e.open("GET",t.url),e.send()}else{if(!t.tileJSON)throw new Error("Either `url` or `tileJSON` options must be provided");this.handleTileJSONResponse(t.tileJSON)}}onXHRLoad_(t){const e=t.target;if(!e.status||e.status>=200&&e.status<300){let t;try{t=JSON.parse(e.responseText)}catch(t){return void this.handleTileJSONError()}this.handleTileJSONResponse(t)}else this.handleTileJSONError()}onXHRError_(t){this.handleTileJSONError()}getTileJSON(){return this.tileJSON_}handleTileJSONResponse(t){const e=(0,zn.Jt)("EPSG:4326"),i=this.getProjection();let n;if(void 0!==t.bounds){const r=(0,zn.FO)(e,i);n=(0,jn.NW)(t.bounds,r)}const r=ss(i),s=t.minzoom||0,o=ns({extent:r,maxZoom:t.maxzoom||22,minZoom:s,tileSize:this.tileSize_});if(this.tileGrid=o,this.tileUrlFunction=Ss(t.tiles,o),t.attribution&&!this.getAttributions()){const e=void 0!==n?n:r;this.setAttributions((function(i){return(0,jn.HY)(e,i.extent)?[t.attribution]:null}))}this.tileJSON_=t,this.setState("ready")}handleTileJSONError(){this.setState("error")}};var Ps=i(2757),Ls=i(8738),Fs=i(8063);const Os=[];class Ds extends Si.A{constructor(t,e,i,n){super(t,e,{transition:0}),this.context_=null,this.executorGroups=[],this.loadingSourceTiles=0,this.hitDetectionImageData={},this.replayState_={},this.sourceTiles=[],this.errorTileKeys={},this.wantedResolution,this.getSourceTiles=n.bind(void 0,this),this.wrappedTileCoord=i}getContext(){return this.context_||(this.context_=(0,hs.Y)(1,1,Os)),this.context_}hasContext(){return!!this.context_}getImage(){return this.hasContext()?this.getContext().canvas:null}getReplayState(t){const e=(0,Ii.v6)(t);return e in this.replayState_||(this.replayState_[e]={dirty:!1,renderedRenderOrder:null,renderedResolution:NaN,renderedRevision:-1,renderedTileResolution:NaN,renderedTileRevision:-1,renderedTileZ:-1}),this.replayState_[e]}load(){this.getSourceTiles()}release(){(0,hs.Yg)(this.context_),Os.push(this.context_.canvas),this.context_=null,super.release()}}const js=Ds;var zs=i(3530),Ns=i(1142);const Gs=class extends Rs{constructor(t){const e=t.projection||"EPSG:3857",i=t.extent||ss(e),n=t.tileGrid||ns({extent:i,maxResolution:t.maxResolution,maxZoom:void 0!==t.maxZoom?t.maxZoom:22,minZoom:t.minZoom,tileSize:t.tileSize||512});super({attributions:t.attributions,attributionsCollapsible:t.attributionsCollapsible,cacheSize:t.cacheSize,interpolate:!0,projection:e,state:t.state,tileGrid:n,tileLoadFunction:t.tileLoadFunction?t.tileLoadFunction:qs,tileUrlFunction:t.tileUrlFunction,url:t.url,urls:t.urls,wrapX:void 0===t.wrapX||t.wrapX,transition:t.transition,zDirection:void 0===t.zDirection?1:t.zDirection}),this.format_=t.format?t.format:null,this.sourceTileCache_=new Br(128),this.overlaps_=null==t.overlaps||t.overlaps,this.tileClass=t.tileClass?t.tileClass:Ri,this.tileGrids_={}}getOverlaps(){return this.overlaps_}clear(){this.sourceTileCache_.clear()}expireCache(t,e){const i=this.getTileCacheForProjection(t),n=Object.keys(e).reduce(((t,e)=>{const n=(0,Kr.gr)(e),r=i.peek(n);if(r){const e=r.sourceTiles;for(let i=0,n=e.length;i{const r=this.tileUrlFunction(n,t,e),s=this.sourceTileCache_.containsKey(r)?this.sourceTileCache_.get(r):new this.tileClass(n,r?Ci.A.IDLE:Ci.A.EMPTY,r,this.format_,this.tileLoadFunction);i.sourceTiles.push(s);const o=s.getState();if(o{this.handleTileChange(e);const n=s.getState();if(n===Ci.A.LOADED||n===Ci.A.ERROR){const e=s.getKey();e in i.errorTileKeys?s.getState()===Ci.A.LOADED&&delete i.errorTileKeys[e]:i.loadingSourceTiles--,n===Ci.A.ERROR?i.errorTileKeys[e]=!0:s.removeEventListener(wr.A.CHANGE,t),0===i.loadingSourceTiles&&i.setState((0,zs.p)(i.errorTileKeys)?Ci.A.LOADED:Ci.A.ERROR)}};s.addEventListener(wr.A.CHANGE,t),i.loadingSourceTiles++}o===Ci.A.IDLE&&(s.extent=l.getTileCoordExtent(n),s.projection=e,s.resolution=l.getResolution(n[0]),this.sourceTileCache_.set(r,s),s.load())})),i.loadingSourceTiles||i.setState(i.sourceTiles.some((t=>t.getState()===Ci.A.ERROR))?Ci.A.ERROR:Ci.A.LOADED)}return i.sourceTiles}getTile(t,e,i,n,r){const s=[t,e,i];let o=this.getTileCoordForTileUrlFunction(s,r);const a=this.getTileGrid().getExtent(),l=this.getTileGridForProjection(r);if(o&&a){const e=l.getTileCoordExtent(o);(0,jn.r)(e,-l.getResolution(t),e),(0,jn.HY)(a,e)||(o=null)}let h=!0;if(null!==o){const e=this.tileGrid,i=l.getResolution(t),s=e.getZForResolution(i,1),a=l.getTileCoordExtent(o);(0,jn.r)(a,-i,a),e.forEachTileCoord(a,s,(t=>{h=h&&!this.tileUrlFunction(t,n,r)}))}const c=new js(s,h?Ci.A.EMPTY:Ci.A.IDLE,o,this.getSourceTiles.bind(this,n,r));return c.key=this.getKey(),c}getTileGridForProjection(t){const e=t.getCode();let i=this.tileGrids_[e];if(!i){const t=this.tileGrid,n=t.getResolutions().slice(),r=n.map((function(e,i){return t.getOrigin(i)})),s=n.map((function(e,i){return t.getTileSize(i)})),o=$r.L+1;for(let t=n.length;td?u-L+d:d-L,P=Math.atan(Math.sqrt(k*k+M*M)),W=m*Math.cos(P)+g*Math.sin(P)*Math.cos(f-L),F=Math.cos(P),O=255*W,N=Math.min(Math.max(2*e.sunEl,0),1),G=1.875-1.75*e.opacity,q=.5!==e.opacity?d*((Math.pow(G,P)-1)/(Math.pow(G,d)-1)):P,j={r:(1-F)*v.r*N*255,g:(1-F)*v.g*N*255,b:(1-F)*v.b*N*255,a:(1-F)*v.a*N*255},D=Math.abs(((L+f)/Math.PI+.5)%2-1),z={r:(y.r*(1-D)+_.r*D)*O,g:(y.g*(1-D)+_.g*D)*O,b:(y.b*(1-D)+_.b*D)*O,a:(y.a*(1-D)+_.a*D)*O},T=4*(w*n+b),o[T]=j.r*(1-D)+z.r,o[T+1]=j.g*(1-D)+z.g,o[T+2]=j.b*(1-D)+z.b,o[T+3]=s[T+3]*e.opacity*N*Math.sin(q);return new ImageData(o,n,r)}function Ks(t,e=512){return t.getExtent()?ns({extent:t.getExtent(),tileSize:e,maxZoom:22}).getResolutions():qi}function Us(t,e){return e.accessToken||(e=Object.assign({},e),new URL(t).searchParams.forEach(((t,i)=>{e.accessToken=t,e.accessTokenParam=i}))),e}function Bs(t,e,i="",n={},r=void 0){let s,o,a,l,h=!0;return"string"==typeof i||Array.isArray(i)?l=i:(a=i,l=a.source||a.layers,n=a),"string"==typeof n?(s=n,a={}):(s=n.styleUrl,a=n),!1===a.updateSource&&(h=!1),r||(r=a.resolutions),s||"string"!=typeof e||e.trim().startsWith("{")||(s=e),s&&(s=s.startsWith("data:")?location.href:Pi(s,a.accessToken),a=Us(s,a)),new Promise((function(i,n){Ui(e,a).then((function(e){if(8!=e.version)return n(new Error("glStyle version 8 required."));if(!(t instanceof Ps.A||t instanceof Fs.A))return n(new Error("Can only apply to VectorLayer or VectorTileLayer"));const c=t instanceof Fs.A?"vector":"geojson";if(l?o=Array.isArray(l)?e.layers.find((function(t){return t.id===l[0]})).source:l:(o=Object.keys(e.sources).find((function(t){return e.sources[t].type===c})),l=o),!o)return n(new Error(`No ${c} source found in the glStyle.`));function u(){if(!h)return Promise.resolve();if(t instanceof Fs.A)return eo(e.sources[o],s,a).then((function(e){const i=t.getSource();i?e!==i&&(i.setTileUrlFunction(e.getTileUrlFunction()),"function"==typeof i.setUrls&&"function"==typeof e.getUrls&&i.setUrls(e.getUrls()),i.format_||(i.format_=e.format_),i.getAttributions()||i.setAttributions(e.getAttributions()),i.getTileLoadFunction()===qs&&i.setTileLoadFunction(e.getTileLoadFunction()),(0,zn.tI)(i.getProjection(),e.getProjection())&&(i.tileGrid=e.getTileGrid())):t.setSource(e);const n=t.getSource().getTileGrid();!isFinite(t.getMaxResolution())&&!isFinite(t.getMinZoom())&&n.getMinZoom()>0&&t.setMaxResolution(Xi(Math.max(0,n.getMinZoom()-1e-12),n.getResolutions()))}));const i=e.sources[o];let n=t.getSource();n&&n.get("mapbox-source")===i||(n=ro(i,s,a));const r=t.getSource();return r?n!==r&&(r.getAttributions()||r.setAttributions(n.getAttributions()),r.format_||(r.format_=n.getFormat()),r.url_=n.getUrl()):t.setSource(n),Promise.resolve()}let d,p,f,g;function m(){if(g||e.sprite&&!p)g?(t.setStyle(g),u().then(i).catch(n)):n(new Error("Something went wrong trying to apply style."));else{if(a.projection&&!r){const t=(0,zn.Jt)(a.projection).getUnits();"m"!==t&&(r=qi.map((e=>e/Ys.I[t])))}g=Rn(t,e,l,r,p,f,((t,e=a.webfonts)=>function(t,e="https://cdn.jsdelivr.net/npm/@fontsource/{font-family}/{fontweight}{-fontstyle}.css"){const i=t.toString();if(i in un)return un[i];const n=[];for(let e=0,i=t.length;e=1.5?.5:1;const i=.5==d?"@2x":"";let r=t.origin+t.pathname+i+".json"+t.search;new Promise((function(e,i){Ki("Sprite",r,a).then(e).catch((function(n){r=t.origin+t.pathname+".json"+t.search,Ki("Sprite",r,a).then(e).catch(i)}))})).then((function(e){if(void 0===e&&n(new Error("No sprites found.")),p=e,f=t.origin+t.pathname+i+".png"+t.search,a.transformRequest){const t=a.transformRequest(f,"SpriteImage")||f;(t instanceof Request||t instanceof Promise)&&(f=t)}m()})).catch((function(t){n(new Error(`Sprites cannot be loaded: ${r}: ${t.message}`))}))}else m()})).catch(n)}))}const Zs={};function Hs(t,e,i={}){return Ui(e,i).then((function(e){!function(t,e,i){e.layers.some((function(e){if("background"===e.type){if(t instanceof kn.A)return t.setBackground((function(t){return Qs(e,t,i,{})})),!0;if(t instanceof vr.A||t instanceof Wn.A)return t.getLayers().insertAt(0,to(e,i,{})),!0}}))}(t,e,i)}))}function $s(t,e){let i;return t.some((function(t){if(t.id==e)return i=t.source,!0})),i}function Js(t,e,i){const n=new Ms({tileJSON:e,tileSize:t.tileSize||e.tileSize||512}),r=n.getTileJSON(),s=n.getTileGrid(),o=(0,zn.Jt)(i.projection||"EPSG:3857"),a=function(t,e){const i=t.bounds;if(i){const t=(0,zn.Rb)([i[0],i[1]],e),n=(0,zn.Rb)([i[2],i[3]],e);return[t[0],t[1],n[0],n[1]]}return(0,zn.Jt)(e).getExtent()}(r,o),l=o.getExtent(),h=r.minzoom||0,c=r.maxzoom||22,u={attributions:n.getAttributions(),projection:o,tileGrid:new es({origin:l?(0,jn.Py)(l):s.getOrigin(0),extent:a||s.getExtent(),minZoom:h,resolutions:Ks(o,e.tileSize).slice(0,c+1),tileSize:s.getTileSize(0)})};return Array.isArray(r.tiles)?u.urls=r.tiles:u.url=r.tiles,u}function Qs(t,e,i,n){const r={id:t.id,type:t.type},s=t.layout||{},o=t.paint||{};r.paint=o;const a=Yi(e,i.resolutions||qi);let l;const h=vn(r,"paint","background-color",a,Zs,n);return void 0!==o["background-opacity"]&&(l=vn(r,"paint","background-opacity",a,Zs,n)),"none"==s.visibility?void 0:An(h,l)}function to(t,e,i){const n=document.createElement("div");return n.className="ol-mapbox-style-background",n.style.position="absolute",n.style.width="100%",n.style.height="100%",new kn.A({source:new Lr.A({}),render(r){const s=Qs(t,r.viewState.resolution,e,i);return n.style.backgroundColor=s,n}})}function eo(t,e,i){return new Promise((function(n,r){Zi(t,e,i).then((function({tileJson:e,tileLoadFunction:r}){const s=Js(t,e,i);s.tileLoadFunction=r,s.format=new _r,n(new Gs(s))})).catch(r)}))}function io(t){return`{bbox-${(t?t.getCode():"EPSG:3857").toLowerCase().replace(/[^a-z0-9]/g,"-")}}`}function no(t,e,i){const n=new Yr;return function(t,e,i){return new Promise((function(n,r){Zi(t,e,i).then((function({tileJson:e,tileLoadFunction:r}){const s=new Ms({interpolate:void 0===i.interpolate||i.interpolate,transition:0,crossOrigin:"anonymous",tileJSON:e});s.tileGrid=Js(t,e,i).tileGrid,i.projection&&(s.projection=(0,zn.Jt)(i.projection));const o=s.getTileUrlFunction();r&&s.setTileLoadFunction(r),s.setTileUrlFunction((function(t,e,i){const n=io(i);let r=o(t,e,i);if(-1!=r.indexOf(n)){const e=s.getTileGrid().getTileCoordExtent(t);r=r.replace(n,e.toString())}return r})),s.set("mapbox-source",t),n(s)})).catch((function(t){r(t)}))}))}(t,e,i).then((function(t){n.setSource(t)})).catch((function(){n.setSource(void 0)})),n}function ro(t,e,i){const n=i.projection?new In.A({dataProjection:i.projection}):new In.A,r=t.data,s={};if("string"==typeof r){const[s]=Fi(r,i.accessToken,i.accessTokenParam||"access_token",e||location.href);if(/\{bbox-[0-9a-z-]+\}/.test(s)){const e=(t,e,i)=>{const n=io(i);return s.replace(n,`${t.join(",")}`)},r=new Ls.A({attributions:t.attribution,format:n,loader:(t,n,s,o,a)=>{Ki("GeoJSON","function"==typeof e?e(t,n,s):e,i).then((t=>{const e=r.getFormat().readFeatures(t,{featureProjection:s});r.addFeatures(e),o(e)})).catch((e=>{r.removeLoadedExtent(t),a()}))},strategy:Xs.Qk});return r.set("mapbox-source",t),r}const o=new Ls.A({attributions:t.attribution,format:n,url:s,loader:(t,e,n,r,a)=>{Ki("GeoJSON",s,i).then((t=>{const e=o.getFormat().readFeatures(t,{featureProjection:n});o.addFeatures(e),r(e)})).catch((e=>{o.removeLoadedExtent(t),a()}))}});return o}s.features=n.readFeatures(r,{featureProjection:(0,zn.Tf)()||"EPSG:3857"});const o=new Ls.A(Object.assign({attributions:t.attribution,format:n},s));return o.set("mapbox-source",t),o}function so(t,e,i,n){const r=Ni(t),s=t.layers,o=i.type,a=i.source||$s(s,i.ref),l=t.sources[a];let h;if("background"==o)h=to(i,n,r);else if("vector"==l.type)h=function(t,e,i){const n=new Fs.A({declutter:!0,visible:!1});return eo(t,e,i).then((function(e){e.set("mapbox-source",t),n.setSource(e)})).catch((function(t){n.setSource(void 0)})),n}(l,e,n);else if("raster"==l.type)h=no(l,e,n),h.setVisible(!i.layout||"none"!==i.layout.visibility),h.on("prerender",function(t,e,i){let n=null;return function(r){t.paint&&"raster-opacity"in t.paint&&r.frameState.viewState.zoom!==n&&(n=r.frameState.viewState.zoom,delete i[t.id],function(t,e,i,n){const r=vn(t,"paint","raster-opacity",i,Zs,n);e.setOpacity(r)}(t,e,n,i))}}(i,h,r));else if("geojson"==l.type)h=function(t,e,i){return new Ps.A({declutter:!0,source:ro(t,e,i),visible:!1})}(l,e,n);else if("raster-dem"==l.type&&"hillshade"==i.type){const t=function(t,e,i){const n=no(t,e,i);return new qn({source:new _s({operationType:"image",operation:Vs,sources:[n]})})}(l,e,n);h=t,t.getSource().on("beforeoperations",(function(t){const e=t.data;e.resolution=(0,zn.hO)(n.projection||"EPSG:3857",t.resolution,(0,jn.q1)(t.extent),"m");const s=Yi(t.resolution,n.resolutions||qi);e.encoding=l.encoding,e.vert=5*vn(i,"paint","hillshade-exaggeration",s,Zs,r),e.sunAz=vn(i,"paint","hillshade-illumination-direction",s,Zs,r),e.sunEl=35,e.opacity=.3,e.highlightColor=vn(i,"paint","hillshade-highlight-color",s,Zs,r),e.shadowColor=vn(i,"paint","hillshade-shadow-color",s,Zs,r),e.accentColor=vn(i,"paint","hillshade-accent-color",s,Zs,r)})),h.setVisible(!i.layout||"none"!==i.layout.visibility)}const c=a;return h&&h.set("mapbox-source",c),h}function oo(t,e,i,n){const r=[];let s=null;if(e instanceof vr.A){if(s=e.getView(),!s.isDef()&&!s.getRotation()&&!s.getResolutions()){const t=n.projection?(0,zn.Jt)(n.projection):s.getProjection();s=new Ws.Ay(Object.assign(s.getProperties(),{maxResolution:qi[0]/Ys.I[t.getUnits()],projection:n.projection||s.getProjection()})),e.setView(s)}"center"in t&&!s.getCenter()&&s.setCenter((0,zn.Rb)(t.center,s.getProjection())),"zoom"in t&&void 0===s.getZoom()&&s.setResolution(qi[0]/Ys.I[s.getProjection().getUnits()]/Math.pow(2,t.zoom)),s.getCenter()&&void 0!==s.getZoom()||s.fit(s.getProjection().getExtent(),{nearest:!0,size:e.getSize()})}e.set("mapbox-style",t),e.set("mapbox-metadata",{styleUrl:i,options:n});const o=t.layers;let a,l,h,c=[];for(let s=0,u=o.length;s0||i>0)&&t.setMaxResolution(Math.min(Xi(Math.max(0,o-1e-12),qi),Xi(Math.max(0,i-1e-12),e.getResolutions()))),a<24&&t.setMinResolution(Xi(a,qi))}}else o>0&&t.setMaxResolution(Xi(Math.max(0,o-1e-12),qi));c instanceof Ls.A||c instanceof Gs?Bs(t,i,e,Object.assign({styleUrl:n},s)).then((function(){!function(t,e){function i(){const i=e.get("mapbox-style");if(!i)return;const n=wi(i.layers),r=t.get("mapbox-layers"),s=n.filter((function(t){return r.includes(t.id)})).some((function(t){return!t.layout||!t.layout.visibility||"visible"===t.layout.visibility}));t.get("visible")!==s&&t.setVisible(s)}t.on("change",i),i()}(t,r),l()})).catch(h):l()}else h(new Error("Error accessing data for source "+t.get("mapbox-source")))};t.set("mapbox-layers",e);const u=r.getLayers();-1===u.getArray().indexOf(t)&&u.push(t),t.getSource()?c():t.once("change:source",c)}))}function ho(t,e,i){const n="getLayers"in t?function(t,e){const i=[],n=t.getLayers().getArray();for(let t=0,r=n.length;t{if(!i){var o=1/0;for(c=0;c=s)&&Object.keys(n.O).every((t=>n.O[t](i[l])))?i.splice(l--,1):(a=!1,s0&&t[c-1][2]>s;c--)t[c]=t[c-1];t[c]=[i,r,s]},n.d=(t,e)=>{for(var i in e)n.o(e,i)&&!n.o(t,i)&&Object.defineProperty(t,i,{enumerable:!0,get:e[i]})},n.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),n.r=t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},(()=>{var t={76:0};n.O.j=e=>0===t[e];var e=(e,i)=>{var r,s,[o,a,l]=i,h=0;if(o.some((e=>0!==t[e]))){for(r in a)n.o(a,r)&&(n.m[r]=a[r]);if(l)var c=l(n)}for(e&&e(i);h {\n\tif(chunkIds) {\n\t\tpriority = priority || 0;\n\t\tfor(var i = deferred.length; i > 0 && deferred[i - 1][2] > priority; i--) deferred[i] = deferred[i - 1];\n\t\tdeferred[i] = [chunkIds, fn, priority];\n\t\treturn;\n\t}\n\tvar notFulfilled = Infinity;\n\tfor (var i = 0; i < deferred.length; i++) {\n\t\tvar [chunkIds, fn, priority] = deferred[i];\n\t\tvar fulfilled = true;\n\t\tfor (var j = 0; j < chunkIds.length; j++) {\n\t\t\tif ((priority & 1 === 0 || notFulfilled >= priority) && Object.keys(__webpack_require__.O).every((key) => (__webpack_require__.O[key](chunkIds[j])))) {\n\t\t\t\tchunkIds.splice(j--, 1);\n\t\t\t} else {\n\t\t\t\tfulfilled = false;\n\t\t\t\tif(priority < notFulfilled) notFulfilled = priority;\n\t\t\t}\n\t\t}\n\t\tif(fulfilled) {\n\t\t\tdeferred.splice(i--, 1)\n\t\t\tvar r = fn();\n\t\t\tif (r !== undefined) result = r;\n\t\t}\n\t}\n\treturn result;\n};","/*\n * Copyright (C) 2008 Apple Inc. All Rights Reserved.\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions\n * are met:\n * 1. Redistributions of source code must retain the above copyright\n * notice, this list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright\n * notice, this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n *\n * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY\n * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR\n * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR\n * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,\n * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,\n * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR\n * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY\n * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n *\n * Ported from Webkit\n * http://svn.webkit.org/repository/webkit/trunk/Source/WebCore/platform/graphics/UnitBezier.h\n */\n\nmodule.exports = UnitBezier;\n\nfunction UnitBezier(p1x, p1y, p2x, p2y) {\n // Calculate the polynomial coefficients, implicit first and last control points are (0,0) and (1,1).\n this.cx = 3.0 * p1x;\n this.bx = 3.0 * (p2x - p1x) - this.cx;\n this.ax = 1.0 - this.cx - this.bx;\n\n this.cy = 3.0 * p1y;\n this.by = 3.0 * (p2y - p1y) - this.cy;\n this.ay = 1.0 - this.cy - this.by;\n\n this.p1x = p1x;\n this.p1y = p2y;\n this.p2x = p2x;\n this.p2y = p2y;\n}\n\nUnitBezier.prototype.sampleCurveX = function(t) {\n // `ax t^3 + bx t^2 + cx t' expanded using Horner's rule.\n return ((this.ax * t + this.bx) * t + this.cx) * t;\n};\n\nUnitBezier.prototype.sampleCurveY = function(t) {\n return ((this.ay * t + this.by) * t + this.cy) * t;\n};\n\nUnitBezier.prototype.sampleCurveDerivativeX = function(t) {\n return (3.0 * this.ax * t + 2.0 * this.bx) * t + this.cx;\n};\n\nUnitBezier.prototype.solveCurveX = function(x, epsilon) {\n if (typeof epsilon === 'undefined') epsilon = 1e-6;\n\n var t0, t1, t2, x2, i;\n\n // First try a few iterations of Newton's method -- normally very fast.\n for (t2 = x, i = 0; i < 8; i++) {\n\n x2 = this.sampleCurveX(t2) - x;\n if (Math.abs(x2) < epsilon) return t2;\n\n var d2 = this.sampleCurveDerivativeX(t2);\n if (Math.abs(d2) < 1e-6) break;\n\n t2 = t2 - x2 / d2;\n }\n\n // Fall back to the bisection method for reliability.\n t0 = 0.0;\n t1 = 1.0;\n t2 = x;\n\n if (t2 < t0) return t0;\n if (t2 > t1) return t1;\n\n while (t0 < t1) {\n\n x2 = this.sampleCurveX(t2);\n if (Math.abs(x2 - x) < epsilon) return t2;\n\n if (x > x2) {\n t0 = t2;\n } else {\n t1 = t2;\n }\n\n t2 = (t1 - t0) * 0.5 + t0;\n }\n\n // Failure.\n return t2;\n};\n\nUnitBezier.prototype.solve = function(x, epsilon) {\n return this.sampleCurveY(this.solveCurveX(x, epsilon));\n};\n","// (c) Dean McNamee , 2012.\n//\n// https://github.com/deanm/css-color-parser-js\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS\n// IN THE SOFTWARE.\n\n// http://www.w3.org/TR/css3-color/\nvar kCSSColorTable = {\n \"transparent\": [0,0,0,0], \"aliceblue\": [240,248,255,1],\n \"antiquewhite\": [250,235,215,1], \"aqua\": [0,255,255,1],\n \"aquamarine\": [127,255,212,1], \"azure\": [240,255,255,1],\n \"beige\": [245,245,220,1], \"bisque\": [255,228,196,1],\n \"black\": [0,0,0,1], \"blanchedalmond\": [255,235,205,1],\n \"blue\": [0,0,255,1], \"blueviolet\": [138,43,226,1],\n \"brown\": [165,42,42,1], \"burlywood\": [222,184,135,1],\n \"cadetblue\": [95,158,160,1], \"chartreuse\": [127,255,0,1],\n \"chocolate\": [210,105,30,1], \"coral\": [255,127,80,1],\n \"cornflowerblue\": [100,149,237,1], \"cornsilk\": [255,248,220,1],\n \"crimson\": [220,20,60,1], \"cyan\": [0,255,255,1],\n \"darkblue\": [0,0,139,1], \"darkcyan\": [0,139,139,1],\n \"darkgoldenrod\": [184,134,11,1], \"darkgray\": [169,169,169,1],\n \"darkgreen\": [0,100,0,1], \"darkgrey\": [169,169,169,1],\n \"darkkhaki\": [189,183,107,1], \"darkmagenta\": [139,0,139,1],\n \"darkolivegreen\": [85,107,47,1], \"darkorange\": [255,140,0,1],\n \"darkorchid\": [153,50,204,1], \"darkred\": [139,0,0,1],\n \"darksalmon\": [233,150,122,1], \"darkseagreen\": [143,188,143,1],\n \"darkslateblue\": [72,61,139,1], \"darkslategray\": [47,79,79,1],\n \"darkslategrey\": [47,79,79,1], \"darkturquoise\": [0,206,209,1],\n \"darkviolet\": [148,0,211,1], \"deeppink\": [255,20,147,1],\n \"deepskyblue\": [0,191,255,1], \"dimgray\": [105,105,105,1],\n \"dimgrey\": [105,105,105,1], \"dodgerblue\": [30,144,255,1],\n \"firebrick\": [178,34,34,1], \"floralwhite\": [255,250,240,1],\n \"forestgreen\": [34,139,34,1], \"fuchsia\": [255,0,255,1],\n \"gainsboro\": [220,220,220,1], \"ghostwhite\": [248,248,255,1],\n \"gold\": [255,215,0,1], \"goldenrod\": [218,165,32,1],\n \"gray\": [128,128,128,1], \"green\": [0,128,0,1],\n \"greenyellow\": [173,255,47,1], \"grey\": [128,128,128,1],\n \"honeydew\": [240,255,240,1], \"hotpink\": [255,105,180,1],\n \"indianred\": [205,92,92,1], \"indigo\": [75,0,130,1],\n \"ivory\": [255,255,240,1], \"khaki\": [240,230,140,1],\n \"lavender\": [230,230,250,1], \"lavenderblush\": [255,240,245,1],\n \"lawngreen\": [124,252,0,1], \"lemonchiffon\": [255,250,205,1],\n \"lightblue\": [173,216,230,1], \"lightcoral\": [240,128,128,1],\n \"lightcyan\": [224,255,255,1], \"lightgoldenrodyellow\": [250,250,210,1],\n \"lightgray\": [211,211,211,1], \"lightgreen\": [144,238,144,1],\n \"lightgrey\": [211,211,211,1], \"lightpink\": [255,182,193,1],\n \"lightsalmon\": [255,160,122,1], \"lightseagreen\": [32,178,170,1],\n \"lightskyblue\": [135,206,250,1], \"lightslategray\": [119,136,153,1],\n \"lightslategrey\": [119,136,153,1], \"lightsteelblue\": [176,196,222,1],\n \"lightyellow\": [255,255,224,1], \"lime\": [0,255,0,1],\n \"limegreen\": [50,205,50,1], \"linen\": [250,240,230,1],\n \"magenta\": [255,0,255,1], \"maroon\": [128,0,0,1],\n \"mediumaquamarine\": [102,205,170,1], \"mediumblue\": [0,0,205,1],\n \"mediumorchid\": [186,85,211,1], \"mediumpurple\": [147,112,219,1],\n \"mediumseagreen\": [60,179,113,1], \"mediumslateblue\": [123,104,238,1],\n \"mediumspringgreen\": [0,250,154,1], \"mediumturquoise\": [72,209,204,1],\n \"mediumvioletred\": [199,21,133,1], \"midnightblue\": [25,25,112,1],\n \"mintcream\": [245,255,250,1], \"mistyrose\": [255,228,225,1],\n \"moccasin\": [255,228,181,1], \"navajowhite\": [255,222,173,1],\n \"navy\": [0,0,128,1], \"oldlace\": [253,245,230,1],\n \"olive\": [128,128,0,1], \"olivedrab\": [107,142,35,1],\n \"orange\": [255,165,0,1], \"orangered\": [255,69,0,1],\n \"orchid\": [218,112,214,1], \"palegoldenrod\": [238,232,170,1],\n \"palegreen\": [152,251,152,1], \"paleturquoise\": [175,238,238,1],\n \"palevioletred\": [219,112,147,1], \"papayawhip\": [255,239,213,1],\n \"peachpuff\": [255,218,185,1], \"peru\": [205,133,63,1],\n \"pink\": [255,192,203,1], \"plum\": [221,160,221,1],\n \"powderblue\": [176,224,230,1], \"purple\": [128,0,128,1],\n \"rebeccapurple\": [102,51,153,1],\n \"red\": [255,0,0,1], \"rosybrown\": [188,143,143,1],\n \"royalblue\": [65,105,225,1], \"saddlebrown\": [139,69,19,1],\n \"salmon\": [250,128,114,1], \"sandybrown\": [244,164,96,1],\n \"seagreen\": [46,139,87,1], \"seashell\": [255,245,238,1],\n \"sienna\": [160,82,45,1], \"silver\": [192,192,192,1],\n \"skyblue\": [135,206,235,1], \"slateblue\": [106,90,205,1],\n \"slategray\": [112,128,144,1], \"slategrey\": [112,128,144,1],\n \"snow\": [255,250,250,1], \"springgreen\": [0,255,127,1],\n \"steelblue\": [70,130,180,1], \"tan\": [210,180,140,1],\n \"teal\": [0,128,128,1], \"thistle\": [216,191,216,1],\n \"tomato\": [255,99,71,1], \"turquoise\": [64,224,208,1],\n \"violet\": [238,130,238,1], \"wheat\": [245,222,179,1],\n \"white\": [255,255,255,1], \"whitesmoke\": [245,245,245,1],\n \"yellow\": [255,255,0,1], \"yellowgreen\": [154,205,50,1]}\n\nfunction clamp_css_byte(i) { // Clamp to integer 0 .. 255.\n i = Math.round(i); // Seems to be what Chrome does (vs truncation).\n return i < 0 ? 0 : i > 255 ? 255 : i;\n}\n\nfunction clamp_css_float(f) { // Clamp to float 0.0 .. 1.0.\n return f < 0 ? 0 : f > 1 ? 1 : f;\n}\n\nfunction parse_css_int(str) { // int or percentage.\n if (str[str.length - 1] === '%')\n return clamp_css_byte(parseFloat(str) / 100 * 255);\n return clamp_css_byte(parseInt(str));\n}\n\nfunction parse_css_float(str) { // float or percentage.\n if (str[str.length - 1] === '%')\n return clamp_css_float(parseFloat(str) / 100);\n return clamp_css_float(parseFloat(str));\n}\n\nfunction css_hue_to_rgb(m1, m2, h) {\n if (h < 0) h += 1;\n else if (h > 1) h -= 1;\n\n if (h * 6 < 1) return m1 + (m2 - m1) * h * 6;\n if (h * 2 < 1) return m2;\n if (h * 3 < 2) return m1 + (m2 - m1) * (2/3 - h) * 6;\n return m1;\n}\n\nfunction parseCSSColor(css_str) {\n // Remove all whitespace, not compliant, but should just be more accepting.\n var str = css_str.replace(/ /g, '').toLowerCase();\n\n // Color keywords (and transparent) lookup.\n if (str in kCSSColorTable) return kCSSColorTable[str].slice(); // dup.\n\n // #abc and #abc123 syntax.\n if (str[0] === '#') {\n if (str.length === 4) {\n var iv = parseInt(str.substr(1), 16); // TODO(deanm): Stricter parsing.\n if (!(iv >= 0 && iv <= 0xfff)) return null; // Covers NaN.\n return [((iv & 0xf00) >> 4) | ((iv & 0xf00) >> 8),\n (iv & 0xf0) | ((iv & 0xf0) >> 4),\n (iv & 0xf) | ((iv & 0xf) << 4),\n 1];\n } else if (str.length === 7) {\n var iv = parseInt(str.substr(1), 16); // TODO(deanm): Stricter parsing.\n if (!(iv >= 0 && iv <= 0xffffff)) return null; // Covers NaN.\n return [(iv & 0xff0000) >> 16,\n (iv & 0xff00) >> 8,\n iv & 0xff,\n 1];\n }\n\n return null;\n }\n\n var op = str.indexOf('('), ep = str.indexOf(')');\n if (op !== -1 && ep + 1 === str.length) {\n var fname = str.substr(0, op);\n var params = str.substr(op+1, ep-(op+1)).split(',');\n var alpha = 1; // To allow case fallthrough.\n switch (fname) {\n case 'rgba':\n if (params.length !== 4) return null;\n alpha = parse_css_float(params.pop());\n // Fall through.\n case 'rgb':\n if (params.length !== 3) return null;\n return [parse_css_int(params[0]),\n parse_css_int(params[1]),\n parse_css_int(params[2]),\n alpha];\n case 'hsla':\n if (params.length !== 4) return null;\n alpha = parse_css_float(params.pop());\n // Fall through.\n case 'hsl':\n if (params.length !== 3) return null;\n var h = (((parseFloat(params[0]) % 360) + 360) % 360) / 360; // 0 .. 1\n // NOTE(deanm): According to the CSS spec s/l should only be\n // percentages, but we don't bother and let float or percentage.\n var s = parse_css_float(params[1]);\n var l = parse_css_float(params[2]);\n var m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n var m1 = l * 2 - m2;\n return [clamp_css_byte(css_hue_to_rgb(m1, m2, h+1/3) * 255),\n clamp_css_byte(css_hue_to_rgb(m1, m2, h) * 255),\n clamp_css_byte(css_hue_to_rgb(m1, m2, h-1/3) * 255),\n alpha];\n default:\n return null;\n }\n }\n\n return null;\n}\n\ntry { exports.parseCSSColor = parseCSSColor } catch(e) { }\n","var fontWeights = {\n thin: 100,\n hairline: 100,\n 'ultra-light': 200,\n 'extra-light': 200,\n light: 300,\n book: 300,\n regular: 400,\n normal: 400,\n plain: 400,\n roman: 400,\n standard: 400,\n medium: 500,\n 'semi-bold': 600,\n 'demi-bold': 600,\n bold: 700,\n 'extra-bold': 800,\n 'ultra-bold': 800,\n heavy: 900,\n black: 900,\n 'heavy-black': 900,\n fat: 900,\n poster: 900,\n 'ultra-black': 950,\n 'extra-black': 950\n};\nvar sp = ' ';\nvar italicRE = /(italic|oblique)$/i;\n\nvar fontCache = {};\n\nmodule.exports = function(fonts, size, lineHeight) {\n var cssData = fontCache[fonts];\n if (!cssData) {\n if (!Array.isArray(fonts)) {\n fonts = [fonts];\n }\n var weight = 400;\n var style = 'normal';\n var fontFamilies = [];\n var haveWeight, haveStyle;\n for (var i = 0, ii = fonts.length; i < ii; ++i) {\n var font = fonts[i];\n var parts = font.split(' ');\n var maybeWeight = parts[parts.length - 1].toLowerCase();\n if (maybeWeight == 'normal' || maybeWeight == 'italic' || maybeWeight == 'oblique') {\n style = haveStyle ? style : maybeWeight;\n haveStyle = true;\n parts.pop();\n maybeWeight = parts[parts.length - 1].toLowerCase();\n } else if (italicRE.test(maybeWeight)) {\n maybeWeight = maybeWeight.replace(italicRE, '');\n style = haveStyle ? style : parts[parts.length - 1].replace(maybeWeight, '');\n haveStyle = true;\n }\n for (var w in fontWeights) {\n var previousPart = parts.length > 1 ? parts[parts.length - 2].toLowerCase() : '';\n if (maybeWeight == w || maybeWeight == w.replace('-', '') || previousPart + '-' + maybeWeight == w) {\n weight = haveWeight ? weight : fontWeights[w];\n parts.pop();\n if (previousPart && w.startsWith(previousPart)) {\n parts.pop();\n }\n break;\n }\n }\n if (!haveWeight && typeof maybeWeight == 'number') {\n weight = maybeWeight;\n haveWeight = true;\n }\n var fontFamily = parts.join(sp)\n .replace('Klokantech Noto Sans', 'Noto Sans');\n if (fontFamily.indexOf(sp) !== -1) {\n fontFamily = '\"' + fontFamily + '\"';\n }\n fontFamilies.push(fontFamily);\n }\n // CSS font property: font-style font-weight font-size/line-height font-family\n cssData = fontCache[fonts] = [style, weight, fontFamilies];\n }\n return cssData[0] + sp + cssData[1] + sp + size + 'px' + (lineHeight ? '/' + lineHeight : '') + sp + cssData[2];\n};\n","module.exports = assert\n\nclass AssertionError extends Error {}\nAssertionError.prototype.name = 'AssertionError'\n\n/**\n * Minimal assert function\n * @param {any} t Value to check if falsy\n * @param {string=} m Optional assertion error message\n * @throws {AssertionError}\n */\nfunction assert (t, m) {\n if (!t) {\n var err = new AssertionError(m)\n if (Error.captureStackTrace) Error.captureStackTrace(err, assert)\n throw err\n }\n}\n","/**\n * @module ol/Collection\n */\nimport BaseObject from './Object.js';\nimport CollectionEventType from './CollectionEventType.js';\nimport Event from './events/Event.js';\n\n/**\n * @enum {string}\n * @private\n */\nconst Property = {\n LENGTH: 'length',\n};\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/Collection~Collection} instances are instances of this\n * type.\n * @template T\n */\nexport class CollectionEvent extends Event {\n /**\n * @param {import(\"./CollectionEventType.js\").default} type Type.\n * @param {T} element Element.\n * @param {number} index The index of the added or removed element.\n */\n constructor(type, element, index) {\n super(type);\n\n /**\n * The element that is added to or removed from the collection.\n * @type {T}\n * @api\n */\n this.element = element;\n\n /**\n * The index of the added or removed element.\n * @type {number}\n * @api\n */\n this.index = index;\n }\n}\n\n/***\n * @template T\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature &\n * import(\"./Observable\").OnSignature &\n * import(\"./Observable\").OnSignature<'add'|'remove', CollectionEvent, Return> &\n * import(\"./Observable\").CombinedOnSignature} CollectionOnSignature\n */\n\n/**\n * @typedef {Object} Options\n * @property {boolean} [unique=false] Disallow the same item from being added to\n * the collection twice.\n */\n\n/**\n * @classdesc\n * An expanded version of standard JS Array, adding convenience methods for\n * manipulation. Add and remove changes to the Collection trigger a Collection\n * event. Note that this does not cover changes to the objects _within_ the\n * Collection; they trigger events on the appropriate object, not on the\n * Collection as a whole.\n *\n * @fires CollectionEvent\n *\n * @template T\n * @api\n */\nclass Collection extends BaseObject {\n /**\n * @param {Array} [array] Array.\n * @param {Options} [options] Collection options.\n */\n constructor(array, options) {\n super();\n\n /***\n * @type {CollectionOnSignature}\n */\n this.on;\n\n /***\n * @type {CollectionOnSignature}\n */\n this.once;\n\n /***\n * @type {CollectionOnSignature}\n */\n this.un;\n\n options = options || {};\n\n /**\n * @private\n * @type {boolean}\n */\n this.unique_ = !!options.unique;\n\n /**\n * @private\n * @type {!Array}\n */\n this.array_ = array ? array : [];\n\n if (this.unique_) {\n for (let i = 0, ii = this.array_.length; i < ii; ++i) {\n this.assertUnique_(this.array_[i], i);\n }\n }\n\n this.updateLength_();\n }\n\n /**\n * Remove all elements from the collection.\n * @api\n */\n clear() {\n while (this.getLength() > 0) {\n this.pop();\n }\n }\n\n /**\n * Add elements to the collection. This pushes each item in the provided array\n * to the end of the collection.\n * @param {!Array} arr Array.\n * @return {Collection} This collection.\n * @api\n */\n extend(arr) {\n for (let i = 0, ii = arr.length; i < ii; ++i) {\n this.push(arr[i]);\n }\n return this;\n }\n\n /**\n * Iterate over each element, calling the provided callback.\n * @param {function(T, number, Array): *} f The function to call\n * for every element. This function takes 3 arguments (the element, the\n * index and the array). The return value is ignored.\n * @api\n */\n forEach(f) {\n const array = this.array_;\n for (let i = 0, ii = array.length; i < ii; ++i) {\n f(array[i], i, array);\n }\n }\n\n /**\n * Get a reference to the underlying Array object. Warning: if the array\n * is mutated, no events will be dispatched by the collection, and the\n * collection's \"length\" property won't be in sync with the actual length\n * of the array.\n * @return {!Array} Array.\n * @api\n */\n getArray() {\n return this.array_;\n }\n\n /**\n * Get the element at the provided index.\n * @param {number} index Index.\n * @return {T} Element.\n * @api\n */\n item(index) {\n return this.array_[index];\n }\n\n /**\n * Get the length of this collection.\n * @return {number} The length of the array.\n * @observable\n * @api\n */\n getLength() {\n return this.get(Property.LENGTH);\n }\n\n /**\n * Insert an element at the provided index.\n * @param {number} index Index.\n * @param {T} elem Element.\n * @api\n */\n insertAt(index, elem) {\n if (index < 0 || index > this.getLength()) {\n throw new Error('Index out of bounds: ' + index);\n }\n if (this.unique_) {\n this.assertUnique_(elem);\n }\n this.array_.splice(index, 0, elem);\n this.updateLength_();\n this.dispatchEvent(\n new CollectionEvent(CollectionEventType.ADD, elem, index),\n );\n }\n\n /**\n * Remove the last element of the collection and return it.\n * Return `undefined` if the collection is empty.\n * @return {T|undefined} Element.\n * @api\n */\n pop() {\n return this.removeAt(this.getLength() - 1);\n }\n\n /**\n * Insert the provided element at the end of the collection.\n * @param {T} elem Element.\n * @return {number} New length of the collection.\n * @api\n */\n push(elem) {\n if (this.unique_) {\n this.assertUnique_(elem);\n }\n const n = this.getLength();\n this.insertAt(n, elem);\n return this.getLength();\n }\n\n /**\n * Remove the first occurrence of an element from the collection.\n * @param {T} elem Element.\n * @return {T|undefined} The removed element or undefined if none found.\n * @api\n */\n remove(elem) {\n const arr = this.array_;\n for (let i = 0, ii = arr.length; i < ii; ++i) {\n if (arr[i] === elem) {\n return this.removeAt(i);\n }\n }\n return undefined;\n }\n\n /**\n * Remove the element at the provided index and return it.\n * Return `undefined` if the collection does not contain this index.\n * @param {number} index Index.\n * @return {T|undefined} Value.\n * @api\n */\n removeAt(index) {\n if (index < 0 || index >= this.getLength()) {\n return undefined;\n }\n const prev = this.array_[index];\n this.array_.splice(index, 1);\n this.updateLength_();\n this.dispatchEvent(\n /** @type {CollectionEvent} */ (\n new CollectionEvent(CollectionEventType.REMOVE, prev, index)\n ),\n );\n return prev;\n }\n\n /**\n * Set the element at the provided index.\n * @param {number} index Index.\n * @param {T} elem Element.\n * @api\n */\n setAt(index, elem) {\n const n = this.getLength();\n if (index >= n) {\n this.insertAt(index, elem);\n return;\n }\n if (index < 0) {\n throw new Error('Index out of bounds: ' + index);\n }\n if (this.unique_) {\n this.assertUnique_(elem, index);\n }\n const prev = this.array_[index];\n this.array_[index] = elem;\n this.dispatchEvent(\n /** @type {CollectionEvent} */ (\n new CollectionEvent(CollectionEventType.REMOVE, prev, index)\n ),\n );\n this.dispatchEvent(\n /** @type {CollectionEvent} */ (\n new CollectionEvent(CollectionEventType.ADD, elem, index)\n ),\n );\n }\n\n /**\n * @private\n */\n updateLength_() {\n this.set(Property.LENGTH, this.array_.length);\n }\n\n /**\n * @private\n * @param {T} elem Element.\n * @param {number} [except] Optional index to ignore.\n */\n assertUnique_(elem, except) {\n for (let i = 0, ii = this.array_.length; i < ii; ++i) {\n if (this.array_[i] === elem && i !== except) {\n throw new Error('Duplicate item added to a unique collection');\n }\n }\n }\n}\n\nexport default Collection;\n","/**\n * @module ol/CollectionEventType\n */\n\n/**\n * @enum {string}\n */\nexport default {\n /**\n * Triggered when an item is added to the collection.\n * @event module:ol/Collection.CollectionEvent#add\n * @api\n */\n ADD: 'add',\n /**\n * Triggered when an item is removed from the collection.\n * @event module:ol/Collection.CollectionEvent#remove\n * @api\n */\n REMOVE: 'remove',\n};\n","/**\n * @module ol/Disposable\n */\n\n/**\n * @classdesc\n * Objects that need to clean up after themselves.\n */\nclass Disposable {\n constructor() {\n /**\n * The object has already been disposed.\n * @type {boolean}\n * @protected\n */\n this.disposed = false;\n }\n\n /**\n * Clean up.\n */\n dispose() {\n if (!this.disposed) {\n this.disposed = true;\n this.disposeInternal();\n }\n }\n\n /**\n * Extension point for disposable objects.\n * @protected\n */\n disposeInternal() {}\n}\n\nexport default Disposable;\n","/**\n * @module ol/Feature\n */\nimport BaseObject from './Object.js';\nimport EventType from './events/EventType.js';\nimport {assert} from './asserts.js';\nimport {listen, unlistenByKey} from './events.js';\n\n/**\n * @typedef {typeof Feature|typeof import(\"./render/Feature.js\").default} FeatureClass\n */\n\n/**\n * @typedef {Feature|import(\"./render/Feature.js\").default} FeatureLike\n */\n\n/***\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature &\n * import(\"./Observable\").OnSignature &\n * import(\"./Observable\").CombinedOnSignature} FeatureOnSignature\n */\n\n/***\n * @template {import(\"./geom/Geometry.js\").default} [Geometry=import(\"./geom/Geometry.js\").default]\n * @typedef {Object & { geometry?: Geometry }} ObjectWithGeometry\n */\n\n/**\n * @classdesc\n * A vector object for geographic features with a geometry and other\n * attribute properties, similar to the features in vector file formats like\n * GeoJSON.\n *\n * Features can be styled individually with `setStyle`; otherwise they use the\n * style of their vector layer.\n *\n * Note that attribute properties are set as {@link module:ol/Object~BaseObject} properties on\n * the feature object, so they are observable, and have get/set accessors.\n *\n * Typically, a feature has a single geometry property. You can set the\n * geometry using the `setGeometry` method and get it with `getGeometry`.\n * It is possible to store more than one geometry on a feature using attribute\n * properties. By default, the geometry used for rendering is identified by\n * the property name `geometry`. If you want to use another geometry property\n * for rendering, use the `setGeometryName` method to change the attribute\n * property associated with the geometry for the feature. For example:\n *\n * ```js\n *\n * import Feature from 'ol/Feature.js';\n * import Polygon from 'ol/geom/Polygon.js';\n * import Point from 'ol/geom/Point.js';\n *\n * const feature = new Feature({\n * geometry: new Polygon(polyCoords),\n * labelPoint: new Point(labelCoords),\n * name: 'My Polygon',\n * });\n *\n * // get the polygon geometry\n * const poly = feature.getGeometry();\n *\n * // Render the feature as a point using the coordinates from labelPoint\n * feature.setGeometryName('labelPoint');\n *\n * // get the point geometry\n * const point = feature.getGeometry();\n * ```\n *\n * @api\n * @template {import(\"./geom/Geometry.js\").default} [Geometry=import(\"./geom/Geometry.js\").default]\n */\nclass Feature extends BaseObject {\n /**\n * @param {Geometry|ObjectWithGeometry} [geometryOrProperties]\n * You may pass a Geometry object directly, or an object literal containing\n * properties. If you pass an object literal, you may include a Geometry\n * associated with a `geometry` key.\n */\n constructor(geometryOrProperties) {\n super();\n\n /***\n * @type {FeatureOnSignature}\n */\n this.on;\n\n /***\n * @type {FeatureOnSignature}\n */\n this.once;\n\n /***\n * @type {FeatureOnSignature}\n */\n this.un;\n\n /**\n * @private\n * @type {number|string|undefined}\n */\n this.id_ = undefined;\n\n /**\n * @type {string}\n * @private\n */\n this.geometryName_ = 'geometry';\n\n /**\n * User provided style.\n * @private\n * @type {import(\"./style/Style.js\").StyleLike}\n */\n this.style_ = null;\n\n /**\n * @private\n * @type {import(\"./style/Style.js\").StyleFunction|undefined}\n */\n this.styleFunction_ = undefined;\n\n /**\n * @private\n * @type {?import(\"./events.js\").EventsKey}\n */\n this.geometryChangeKey_ = null;\n\n this.addChangeListener(this.geometryName_, this.handleGeometryChanged_);\n\n if (geometryOrProperties) {\n if (\n typeof (\n /** @type {?} */ (geometryOrProperties).getSimplifiedGeometry\n ) === 'function'\n ) {\n const geometry = /** @type {Geometry} */ (geometryOrProperties);\n this.setGeometry(geometry);\n } else {\n /** @type {Object} */\n const properties = geometryOrProperties;\n this.setProperties(properties);\n }\n }\n }\n\n /**\n * Clone this feature. If the original feature has a geometry it\n * is also cloned. The feature id is not set in the clone.\n * @return {Feature} The clone.\n * @api\n */\n clone() {\n const clone = /** @type {Feature} */ (\n new Feature(this.hasProperties() ? this.getProperties() : null)\n );\n clone.setGeometryName(this.getGeometryName());\n const geometry = this.getGeometry();\n if (geometry) {\n clone.setGeometry(/** @type {Geometry} */ (geometry.clone()));\n }\n const style = this.getStyle();\n if (style) {\n clone.setStyle(style);\n }\n return clone;\n }\n\n /**\n * Get the feature's default geometry. A feature may have any number of named\n * geometries. The \"default\" geometry (the one that is rendered by default) is\n * set when calling {@link module:ol/Feature~Feature#setGeometry}.\n * @return {Geometry|undefined} The default geometry for the feature.\n * @api\n * @observable\n */\n getGeometry() {\n return /** @type {Geometry|undefined} */ (this.get(this.geometryName_));\n }\n\n /**\n * Get the feature identifier. This is a stable identifier for the feature and\n * is either set when reading data from a remote source or set explicitly by\n * calling {@link module:ol/Feature~Feature#setId}.\n * @return {number|string|undefined} Id.\n * @api\n */\n getId() {\n return this.id_;\n }\n\n /**\n * Get the name of the feature's default geometry. By default, the default\n * geometry is named `geometry`.\n * @return {string} Get the property name associated with the default geometry\n * for this feature.\n * @api\n */\n getGeometryName() {\n return this.geometryName_;\n }\n\n /**\n * Get the feature's style. Will return what was provided to the\n * {@link module:ol/Feature~Feature#setStyle} method.\n * @return {import(\"./style/Style.js\").StyleLike|undefined} The feature style.\n * @api\n */\n getStyle() {\n return this.style_;\n }\n\n /**\n * Get the feature's style function.\n * @return {import(\"./style/Style.js\").StyleFunction|undefined} Return a function\n * representing the current style of this feature.\n * @api\n */\n getStyleFunction() {\n return this.styleFunction_;\n }\n\n /**\n * @private\n */\n handleGeometryChange_() {\n this.changed();\n }\n\n /**\n * @private\n */\n handleGeometryChanged_() {\n if (this.geometryChangeKey_) {\n unlistenByKey(this.geometryChangeKey_);\n this.geometryChangeKey_ = null;\n }\n const geometry = this.getGeometry();\n if (geometry) {\n this.geometryChangeKey_ = listen(\n geometry,\n EventType.CHANGE,\n this.handleGeometryChange_,\n this,\n );\n }\n this.changed();\n }\n\n /**\n * Set the default geometry for the feature. This will update the property\n * with the name returned by {@link module:ol/Feature~Feature#getGeometryName}.\n * @param {Geometry|undefined} geometry The new geometry.\n * @api\n * @observable\n */\n setGeometry(geometry) {\n this.set(this.geometryName_, geometry);\n }\n\n /**\n * Set the style for the feature to override the layer style. This can be a\n * single style object, an array of styles, or a function that takes a\n * resolution and returns an array of styles. To unset the feature style, call\n * `setStyle()` without arguments or a falsey value.\n * @param {import(\"./style/Style.js\").StyleLike} [style] Style for this feature.\n * @api\n * @fires module:ol/events/Event~BaseEvent#event:change\n */\n setStyle(style) {\n this.style_ = style;\n this.styleFunction_ = !style ? undefined : createStyleFunction(style);\n this.changed();\n }\n\n /**\n * Set the feature id. The feature id is considered stable and may be used when\n * requesting features or comparing identifiers returned from a remote source.\n * The feature id can be used with the\n * {@link module:ol/source/Vector~VectorSource#getFeatureById} method.\n * @param {number|string|undefined} id The feature id.\n * @api\n * @fires module:ol/events/Event~BaseEvent#event:change\n */\n setId(id) {\n this.id_ = id;\n this.changed();\n }\n\n /**\n * Set the property name to be used when getting the feature's default geometry.\n * When calling {@link module:ol/Feature~Feature#getGeometry}, the value of the property with\n * this name will be returned.\n * @param {string} name The property name of the default geometry.\n * @api\n */\n setGeometryName(name) {\n this.removeChangeListener(this.geometryName_, this.handleGeometryChanged_);\n this.geometryName_ = name;\n this.addChangeListener(this.geometryName_, this.handleGeometryChanged_);\n this.handleGeometryChanged_();\n }\n}\n\n/**\n * Convert the provided object into a feature style function. Functions passed\n * through unchanged. Arrays of Style or single style objects wrapped\n * in a new feature style function.\n * @param {!import(\"./style/Style.js\").StyleFunction|!Array|!import(\"./style/Style.js\").default} obj\n * A feature style function, a single style, or an array of styles.\n * @return {import(\"./style/Style.js\").StyleFunction} A style function.\n */\nexport function createStyleFunction(obj) {\n if (typeof obj === 'function') {\n return obj;\n }\n /**\n * @type {Array}\n */\n let styles;\n if (Array.isArray(obj)) {\n styles = obj;\n } else {\n assert(\n typeof (/** @type {?} */ (obj).getZIndex) === 'function',\n 'Expected an `ol/style/Style` or an array of `ol/style/Style.js`',\n );\n const style = /** @type {import(\"./style/Style.js\").default} */ (obj);\n styles = [style];\n }\n return function () {\n return styles;\n };\n}\nexport default Feature;\n","/**\n * @module ol/Image\n */\nimport EventTarget from './events/Target.js';\nimport EventType from './events/EventType.js';\nimport ImageState from './ImageState.js';\nimport {CREATE_IMAGE_BITMAP, IMAGE_DECODE} from './has.js';\nimport {listenOnce, unlistenByKey} from './events.js';\nimport {toPromise} from './functions.js';\n\n/**\n * A function that takes an {@link module:ol/Image~ImageWrapper} for the image and a\n * `{string}` for the src as arguments. It is supposed to make it so the\n * underlying image {@link module:ol/Image~ImageWrapper#getImage} is assigned the\n * content specified by the src. If not specified, the default is\n *\n * function(image, src) {\n * image.getImage().src = src;\n * }\n *\n * Providing a custom `imageLoadFunction` can be useful to load images with\n * post requests or - in general - through XHR requests, where the src of the\n * image element would be set to a data URI when the content is loaded.\n *\n * @typedef {function(import(\"./Image.js\").default, string): void} LoadFunction\n * @api\n */\n\n/**\n * @typedef {Object} ImageObject\n * @property {import(\"./extent.js\").Extent} [extent] Extent, if different from the requested one.\n * @property {import(\"./resolution.js\").ResolutionLike} [resolution] Resolution, if different from the requested one.\n * When x and y resolution are different, use the array type (`[xResolution, yResolution]`).\n * @property {number} [pixelRatio] Pixel ratio, if different from the requested one.\n * @property {import('./DataTile.js').ImageLike} image Image.\n */\n\n/**\n * Loader function used for image sources. Receives extent, resolution and pixel ratio as arguments.\n * For images that cover any extent and resolution (static images), the loader function should not accept\n * any arguments. The function returns an {@link import(\"./DataTile.js\").ImageLike image}, an\n * {@link import(\"./Image.js\").ImageObject image object}, or a promise for the same.\n * For loaders that generate images, the promise should not resolve until the image is loaded.\n * If the returned image does not match the extent, resolution or pixel ratio passed to the loader,\n * it has to return an {@link import(\"./Image.js\").ImageObject image object} with the `image` and the\n * correct `extent`, `resolution` and `pixelRatio`.\n *\n * @typedef {function(import(\"./extent.js\").Extent, number, number, (function(HTMLImageElement, string): void)=): import(\"./DataTile.js\").ImageLike|ImageObject|Promise} Loader\n * @api\n */\n\n/**\n * Loader function used for image sources. Receives extent, resolution and pixel ratio as arguments.\n * The function returns a promise for an {@link import(\"./Image.js\").ImageObject image object}.\n *\n * @typedef {function(import(\"./extent.js\").Extent, number, number, (function(HTMLImageElement, string): void)=): import(\"./DataTile.js\").ImageLike|ImageObject|Promise} ImageObjectPromiseLoader\n */\n\nclass ImageWrapper extends EventTarget {\n /**\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number|Array|undefined} resolution Resolution. If provided as array, x and y\n * resolution will be assumed.\n * @param {number} pixelRatio Pixel ratio.\n * @param {import(\"./ImageState.js\").default|import(\"./Image.js\").Loader} stateOrLoader State.\n */\n constructor(extent, resolution, pixelRatio, stateOrLoader) {\n super();\n\n /**\n * @protected\n * @type {import(\"./extent.js\").Extent}\n */\n this.extent = extent;\n\n /**\n * @private\n * @type {number}\n */\n this.pixelRatio_ = pixelRatio;\n\n /**\n * @protected\n * @type {number|Array|undefined}\n */\n this.resolution = resolution;\n\n /**\n * @protected\n * @type {import(\"./ImageState.js\").default}\n */\n this.state =\n typeof stateOrLoader === 'function' ? ImageState.IDLE : stateOrLoader;\n\n /**\n * @private\n * @type {import('./DataTile.js').ImageLike|null}\n */\n this.image_ = null;\n\n /**\n * @protected\n * @type {import(\"./Image.js\").Loader}\n */\n this.loader = typeof stateOrLoader === 'function' ? stateOrLoader : null;\n }\n\n /**\n * @protected\n */\n changed() {\n this.dispatchEvent(EventType.CHANGE);\n }\n\n /**\n * @return {import(\"./extent.js\").Extent} Extent.\n */\n getExtent() {\n return this.extent;\n }\n\n /**\n * @return {import('./DataTile.js').ImageLike} Image.\n */\n getImage() {\n return this.image_;\n }\n\n /**\n * @return {number} PixelRatio.\n */\n getPixelRatio() {\n return this.pixelRatio_;\n }\n\n /**\n * @return {number|Array} Resolution.\n */\n getResolution() {\n return /** @type {number} */ (this.resolution);\n }\n\n /**\n * @return {import(\"./ImageState.js\").default} State.\n */\n getState() {\n return this.state;\n }\n\n /**\n * Load not yet loaded URI.\n */\n load() {\n if (this.state == ImageState.IDLE) {\n if (this.loader) {\n this.state = ImageState.LOADING;\n this.changed();\n const resolution = this.getResolution();\n const requestResolution = Array.isArray(resolution)\n ? resolution[0]\n : resolution;\n toPromise(() =>\n this.loader(\n this.getExtent(),\n requestResolution,\n this.getPixelRatio(),\n ),\n )\n .then((image) => {\n if ('image' in image) {\n this.image_ = image.image;\n }\n if ('extent' in image) {\n this.extent = image.extent;\n }\n if ('resolution' in image) {\n this.resolution = image.resolution;\n }\n if ('pixelRatio' in image) {\n this.pixelRatio_ = image.pixelRatio;\n }\n if (\n image instanceof HTMLImageElement ||\n image instanceof ImageBitmap ||\n image instanceof HTMLCanvasElement ||\n image instanceof HTMLVideoElement\n ) {\n this.image_ = image;\n }\n this.state = ImageState.LOADED;\n })\n .catch((error) => {\n this.state = ImageState.ERROR;\n console.error(error); // eslint-disable-line no-console\n })\n .finally(() => this.changed());\n }\n }\n }\n\n /**\n * @param {import('./DataTile.js').ImageLike} image The image.\n */\n setImage(image) {\n this.image_ = image;\n }\n\n /**\n * @param {number|Array} resolution Resolution.\n */\n setResolution(resolution) {\n this.resolution = resolution;\n }\n}\n\n/**\n * @param {import('./DataTile.js').ImageLike} image Image element.\n * @param {function():any} loadHandler Load callback function.\n * @param {function():any} errorHandler Error callback function.\n * @return {function():void} Callback to stop listening.\n */\nexport function listenImage(image, loadHandler, errorHandler) {\n const img = /** @type {HTMLImageElement} */ (image);\n let listening = true;\n let decoding = false;\n let loaded = false;\n\n const listenerKeys = [\n listenOnce(img, EventType.LOAD, function () {\n loaded = true;\n if (!decoding) {\n loadHandler();\n }\n }),\n ];\n\n if (img.src && IMAGE_DECODE) {\n decoding = true;\n img\n .decode()\n .then(function () {\n if (listening) {\n loadHandler();\n }\n })\n .catch(function (error) {\n if (listening) {\n if (loaded) {\n loadHandler();\n } else {\n errorHandler();\n }\n }\n });\n } else {\n listenerKeys.push(listenOnce(img, EventType.ERROR, errorHandler));\n }\n\n return function unlisten() {\n listening = false;\n listenerKeys.forEach(unlistenByKey);\n };\n}\n\n/**\n * Loads an image.\n * @param {HTMLImageElement} image Image, not yet loaded.\n * @param {string} [src] `src` attribute of the image. Optional, not required if already present.\n * @return {Promise} Promise resolving to an `HTMLImageElement`.\n * @api\n */\nexport function load(image, src) {\n return new Promise((resolve, reject) => {\n function handleLoad() {\n unlisten();\n resolve(image);\n }\n function handleError() {\n unlisten();\n reject(new Error('Image load error'));\n }\n function unlisten() {\n image.removeEventListener('load', handleLoad);\n image.removeEventListener('error', handleError);\n }\n image.addEventListener('load', handleLoad);\n image.addEventListener('error', handleError);\n if (src) {\n image.src = src;\n }\n });\n}\n\n/**\n * @param {HTMLImageElement} image Image, not yet loaded.\n * @param {string} [src] `src` attribute of the image. Optional, not required if already present.\n * @return {Promise} Promise resolving to an `HTMLImageElement`.\n */\nexport function decodeFallback(image, src) {\n if (src) {\n image.src = src;\n }\n return image.src && IMAGE_DECODE\n ? new Promise((resolve, reject) =>\n image\n .decode()\n .then(() => resolve(image))\n .catch((e) =>\n image.complete && image.width ? resolve(image) : reject(e),\n ),\n )\n : load(image);\n}\n\n/**\n * Loads an image and decodes it to an `ImageBitmap` if `createImageBitmap()` is supported. Returns\n * the loaded image otherwise.\n * @param {HTMLImageElement} image Image, not yet loaded.\n * @param {string} [src] `src` attribute of the image. Optional, not required if already present.\n * @return {Promise} Promise resolving to an `ImageBitmap` or an\n * `HTMLImageElement` if `createImageBitmap()` is not supported.\n * @api\n */\nexport function decode(image, src) {\n if (src) {\n image.src = src;\n }\n return image.src && IMAGE_DECODE && CREATE_IMAGE_BITMAP\n ? image\n .decode()\n .then(() => createImageBitmap(image))\n .catch((e) => {\n if (image.complete && image.width) {\n return image;\n }\n throw e;\n })\n : decodeFallback(image);\n}\n\nexport default ImageWrapper;\n","/**\n * @module ol/ImageState\n */\n\n/**\n * @enum {number}\n */\nexport default {\n IDLE: 0,\n LOADING: 1,\n LOADED: 2,\n ERROR: 3,\n EMPTY: 4,\n};\n","/**\n * @module ol/ImageTile\n */\nimport Tile from './Tile.js';\nimport TileState from './TileState.js';\nimport {createCanvasContext2D} from './dom.js';\nimport {listenImage} from './Image.js';\n\nclass ImageTile extends Tile {\n /**\n * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @param {import(\"./TileState.js\").default} state State.\n * @param {string} src Image source URI.\n * @param {?string} crossOrigin Cross origin.\n * @param {import(\"./Tile.js\").LoadFunction} tileLoadFunction Tile load function.\n * @param {import(\"./Tile.js\").Options} [options] Tile options.\n */\n constructor(tileCoord, state, src, crossOrigin, tileLoadFunction, options) {\n super(tileCoord, state, options);\n\n /**\n * @private\n * @type {?string}\n */\n this.crossOrigin_ = crossOrigin;\n\n /**\n * Image URI\n *\n * @private\n * @type {string}\n */\n this.src_ = src;\n\n this.key = src;\n\n /**\n * @private\n * @type {HTMLImageElement|HTMLCanvasElement}\n */\n this.image_ = new Image();\n if (crossOrigin !== null) {\n this.image_.crossOrigin = crossOrigin;\n }\n\n /**\n * @private\n * @type {?function():void}\n */\n this.unlisten_ = null;\n\n /**\n * @private\n * @type {import(\"./Tile.js\").LoadFunction}\n */\n this.tileLoadFunction_ = tileLoadFunction;\n }\n\n /**\n * Get the HTML image element for this tile (may be a Canvas, Image, or Video).\n * @return {HTMLCanvasElement|HTMLImageElement|HTMLVideoElement} Image.\n * @api\n */\n getImage() {\n return this.image_;\n }\n\n /**\n * Sets an HTML image element for this tile (may be a Canvas or preloaded Image).\n * @param {HTMLCanvasElement|HTMLImageElement} element Element.\n */\n setImage(element) {\n this.image_ = element;\n this.state = TileState.LOADED;\n this.unlistenImage_();\n this.changed();\n }\n\n /**\n * Tracks loading or read errors.\n *\n * @private\n */\n handleImageError_() {\n this.state = TileState.ERROR;\n this.unlistenImage_();\n this.image_ = getBlankImage();\n this.changed();\n }\n\n /**\n * Tracks successful image load.\n *\n * @private\n */\n handleImageLoad_() {\n const image = /** @type {HTMLImageElement} */ (this.image_);\n if (image.naturalWidth && image.naturalHeight) {\n this.state = TileState.LOADED;\n } else {\n this.state = TileState.EMPTY;\n }\n this.unlistenImage_();\n this.changed();\n }\n\n /**\n * Load the image or retry if loading previously failed.\n * Loading is taken care of by the tile queue, and calling this method is\n * only needed for preloading or for reloading in case of an error.\n *\n * To retry loading tiles on failed requests, use a custom `tileLoadFunction`\n * that checks for error status codes and reloads only when the status code is\n * 408, 429, 500, 502, 503 and 504, and only when not too many retries have been\n * made already:\n *\n * ```js\n * const retryCodes = [408, 429, 500, 502, 503, 504];\n * const retries = {};\n * source.setTileLoadFunction((tile, src) => {\n * const image = tile.getImage();\n * fetch(src)\n * .then((response) => {\n * if (retryCodes.includes(response.status)) {\n * retries[src] = (retries[src] || 0) + 1;\n * if (retries[src] <= 3) {\n * setTimeout(() => tile.load(), retries[src] * 1000);\n * }\n * return Promise.reject();\n * }\n * return response.blob();\n * })\n * .then((blob) => {\n * const imageUrl = URL.createObjectURL(blob);\n * image.src = imageUrl;\n * setTimeout(() => URL.revokeObjectURL(imageUrl), 5000);\n * })\n * .catch(() => tile.setState(3)); // error\n * });\n * ```\n * @api\n * @override\n */\n load() {\n if (this.state == TileState.ERROR) {\n this.state = TileState.IDLE;\n this.image_ = new Image();\n if (this.crossOrigin_ !== null) {\n this.image_.crossOrigin = this.crossOrigin_;\n }\n }\n if (this.state == TileState.IDLE) {\n this.state = TileState.LOADING;\n this.changed();\n this.tileLoadFunction_(this, this.src_);\n this.unlisten_ = listenImage(\n this.image_,\n this.handleImageLoad_.bind(this),\n this.handleImageError_.bind(this),\n );\n }\n }\n\n /**\n * Discards event handlers which listen for load completion or errors.\n *\n * @private\n */\n unlistenImage_() {\n if (this.unlisten_) {\n this.unlisten_();\n this.unlisten_ = null;\n }\n }\n}\n\n/**\n * Get a 1-pixel blank image.\n * @return {HTMLCanvasElement} Blank image.\n */\nfunction getBlankImage() {\n const ctx = createCanvasContext2D(1, 1);\n ctx.fillStyle = 'rgba(0,0,0,0)';\n ctx.fillRect(0, 0, 1, 1);\n return ctx.canvas;\n}\n\nexport default ImageTile;\n","/**\n * @module ol/renderer/Map\n */\nimport Disposable from '../Disposable.js';\nimport {TRUE} from '../functions.js';\nimport {abstract} from '../util.js';\nimport {compose as composeTransform, makeInverse} from '../transform.js';\nimport {getWidth} from '../extent.js';\nimport {shared as iconImageCache} from '../style/IconImageCache.js';\nimport {inView} from '../layer/Layer.js';\nimport {wrapX} from '../coordinate.js';\n\n/**\n * @template T\n * @typedef HitMatch\n * @property {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @property {import(\"../layer/Layer.js\").default} layer Layer.\n * @property {import(\"../geom/SimpleGeometry.js\").default} geometry Geometry.\n * @property {number} distanceSq Squared distance.\n * @property {import(\"./vector.js\").FeatureCallback} callback Callback.\n */\n\n/**\n * @abstract\n */\nclass MapRenderer extends Disposable {\n /**\n * @param {import(\"../Map.js\").default} map Map.\n */\n constructor(map) {\n super();\n\n /**\n * @private\n * @type {import(\"../Map.js\").default}\n */\n this.map_ = map;\n }\n\n /**\n * @abstract\n * @param {import(\"../render/EventType.js\").default} type Event type.\n * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n */\n dispatchRenderEvent(type, frameState) {\n abstract();\n }\n\n /**\n * @param {import(\"../Map.js\").FrameState} frameState FrameState.\n * @protected\n */\n calculateMatrices2D(frameState) {\n const viewState = frameState.viewState;\n const coordinateToPixelTransform = frameState.coordinateToPixelTransform;\n const pixelToCoordinateTransform = frameState.pixelToCoordinateTransform;\n\n composeTransform(\n coordinateToPixelTransform,\n frameState.size[0] / 2,\n frameState.size[1] / 2,\n 1 / viewState.resolution,\n -1 / viewState.resolution,\n -viewState.rotation,\n -viewState.center[0],\n -viewState.center[1],\n );\n\n makeInverse(pixelToCoordinateTransform, coordinateToPixelTransform);\n }\n\n /**\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {import(\"../Map.js\").FrameState} frameState FrameState.\n * @param {number} hitTolerance Hit tolerance in pixels.\n * @param {boolean} checkWrapped Check for wrapped geometries.\n * @param {import(\"./vector.js\").FeatureCallback} callback Feature callback.\n * @param {S} thisArg Value to use as `this` when executing `callback`.\n * @param {function(this: U, import(\"../layer/Layer.js\").default): boolean} layerFilter Layer filter\n * function, only layers which are visible and for which this function\n * returns `true` will be tested for features. By default, all visible\n * layers will be tested.\n * @param {U} thisArg2 Value to use as `this` when executing `layerFilter`.\n * @return {T|undefined} Callback result.\n * @template S,T,U\n */\n forEachFeatureAtCoordinate(\n coordinate,\n frameState,\n hitTolerance,\n checkWrapped,\n callback,\n thisArg,\n layerFilter,\n thisArg2,\n ) {\n let result;\n const viewState = frameState.viewState;\n\n /**\n * @param {boolean} managed Managed layer.\n * @param {import(\"../Feature.js\").FeatureLike} feature Feature.\n * @param {import(\"../layer/Layer.js\").default} layer Layer.\n * @param {import(\"../geom/Geometry.js\").default} geometry Geometry.\n * @return {T|undefined} Callback result.\n */\n function forEachFeatureAtCoordinate(managed, feature, layer, geometry) {\n return callback.call(thisArg, feature, managed ? layer : null, geometry);\n }\n\n const projection = viewState.projection;\n\n const translatedCoordinate = wrapX(coordinate.slice(), projection);\n const offsets = [[0, 0]];\n if (projection.canWrapX() && checkWrapped) {\n const projectionExtent = projection.getExtent();\n const worldWidth = getWidth(projectionExtent);\n offsets.push([-worldWidth, 0], [worldWidth, 0]);\n }\n\n const layerStates = frameState.layerStatesArray;\n const numLayers = layerStates.length;\n\n const matches = /** @type {Array>} */ ([]);\n const tmpCoord = [];\n for (let i = 0; i < offsets.length; i++) {\n for (let j = numLayers - 1; j >= 0; --j) {\n const layerState = layerStates[j];\n const layer = layerState.layer;\n if (\n layer.hasRenderer() &&\n inView(layerState, viewState) &&\n layerFilter.call(thisArg2, layer)\n ) {\n const layerRenderer = layer.getRenderer();\n const source = layer.getSource();\n if (layerRenderer && source) {\n const coordinates = source.getWrapX()\n ? translatedCoordinate\n : coordinate;\n const callback = forEachFeatureAtCoordinate.bind(\n null,\n layerState.managed,\n );\n tmpCoord[0] = coordinates[0] + offsets[i][0];\n tmpCoord[1] = coordinates[1] + offsets[i][1];\n result = layerRenderer.forEachFeatureAtCoordinate(\n tmpCoord,\n frameState,\n hitTolerance,\n callback,\n matches,\n );\n }\n if (result) {\n return result;\n }\n }\n }\n }\n if (matches.length === 0) {\n return undefined;\n }\n const order = 1 / matches.length;\n matches.forEach((m, i) => (m.distanceSq += i * order));\n matches.sort((a, b) => a.distanceSq - b.distanceSq);\n matches.some((m) => {\n return (result = m.callback(m.feature, m.layer, m.geometry));\n });\n return result;\n }\n\n /**\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {import(\"../Map.js\").FrameState} frameState FrameState.\n * @param {number} hitTolerance Hit tolerance in pixels.\n * @param {boolean} checkWrapped Check for wrapped geometries.\n * @param {function(this: U, import(\"../layer/Layer.js\").default): boolean} layerFilter Layer filter\n * function, only layers which are visible and for which this function\n * returns `true` will be tested for features. By default, all visible\n * layers will be tested.\n * @param {U} thisArg Value to use as `this` when executing `layerFilter`.\n * @return {boolean} Is there a feature at the given coordinate?\n * @template U\n */\n hasFeatureAtCoordinate(\n coordinate,\n frameState,\n hitTolerance,\n checkWrapped,\n layerFilter,\n thisArg,\n ) {\n const hasFeature = this.forEachFeatureAtCoordinate(\n coordinate,\n frameState,\n hitTolerance,\n checkWrapped,\n TRUE,\n this,\n layerFilter,\n thisArg,\n );\n\n return hasFeature !== undefined;\n }\n\n /**\n * @return {import(\"../Map.js\").default} Map.\n */\n getMap() {\n return this.map_;\n }\n\n /**\n * Render.\n * @abstract\n * @param {?import(\"../Map.js\").FrameState} frameState Frame state.\n */\n renderFrame(frameState) {\n abstract();\n }\n\n /**\n * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n * @protected\n */\n scheduleExpireIconCache(frameState) {\n if (iconImageCache.canExpireCache()) {\n frameState.postRenderFunctions.push(expireIconCache);\n }\n }\n}\n\n/**\n * @param {import(\"../Map.js\").default} map Map.\n * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n */\nfunction expireIconCache(map, frameState) {\n iconImageCache.expire();\n}\n\nexport default MapRenderer;\n","/**\n * @module ol/renderer/Composite\n */\nimport BaseVectorLayer from '../layer/BaseVector.js';\nimport MapRenderer from './Map.js';\nimport ObjectEventType from '../ObjectEventType.js';\nimport RenderEvent from '../render/Event.js';\nimport RenderEventType from '../render/EventType.js';\nimport {CLASS_UNSELECTABLE} from '../css.js';\nimport {checkedFonts} from '../render/canvas.js';\nimport {inView} from '../layer/Layer.js';\nimport {listen, unlistenByKey} from '../events.js';\nimport {replaceChildren} from '../dom.js';\n\n/**\n * @classdesc\n * Canvas map renderer.\n * @api\n */\nclass CompositeMapRenderer extends MapRenderer {\n /**\n * @param {import(\"../Map.js\").default} map Map.\n */\n constructor(map) {\n super(map);\n\n /**\n * @private\n * @type {import(\"../events.js\").EventsKey}\n */\n this.fontChangeListenerKey_ = listen(\n checkedFonts,\n ObjectEventType.PROPERTYCHANGE,\n map.redrawText.bind(map),\n );\n\n /**\n * @private\n * @type {HTMLDivElement}\n */\n this.element_ = document.createElement('div');\n const style = this.element_.style;\n style.position = 'absolute';\n style.width = '100%';\n style.height = '100%';\n style.zIndex = '0';\n\n this.element_.className = CLASS_UNSELECTABLE + ' ol-layers';\n\n const container = map.getViewport();\n container.insertBefore(this.element_, container.firstChild || null);\n\n /**\n * @private\n * @type {Array}\n */\n this.children_ = [];\n\n /**\n * @private\n * @type {boolean}\n */\n this.renderedVisible_ = true;\n }\n\n /**\n * @param {import(\"../render/EventType.js\").default} type Event type.\n * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n * @override\n */\n dispatchRenderEvent(type, frameState) {\n const map = this.getMap();\n if (map.hasListener(type)) {\n const event = new RenderEvent(type, undefined, frameState);\n map.dispatchEvent(event);\n }\n }\n\n /**\n * @override\n */\n disposeInternal() {\n unlistenByKey(this.fontChangeListenerKey_);\n this.element_.remove();\n super.disposeInternal();\n }\n\n /**\n * Render.\n * @param {?import(\"../Map.js\").FrameState} frameState Frame state.\n * @override\n */\n renderFrame(frameState) {\n if (!frameState) {\n if (this.renderedVisible_) {\n this.element_.style.display = 'none';\n this.renderedVisible_ = false;\n }\n return;\n }\n\n this.calculateMatrices2D(frameState);\n this.dispatchRenderEvent(RenderEventType.PRECOMPOSE, frameState);\n\n const layerStatesArray = frameState.layerStatesArray.sort(\n (a, b) => a.zIndex - b.zIndex,\n );\n const declutter = layerStatesArray.some(\n (layerState) =>\n layerState.layer instanceof BaseVectorLayer &&\n layerState.layer.getDeclutter(),\n );\n if (declutter) {\n // Some layers need decluttering, turn on deferred rendering hint\n frameState.declutter = {};\n }\n const viewState = frameState.viewState;\n\n this.children_.length = 0;\n\n const renderedLayerStates = [];\n let previousElement = null;\n for (let i = 0, ii = layerStatesArray.length; i < ii; ++i) {\n const layerState = layerStatesArray[i];\n frameState.layerIndex = i;\n\n const layer = layerState.layer;\n const sourceState = layer.getSourceState();\n if (\n !inView(layerState, viewState) ||\n (sourceState != 'ready' && sourceState != 'undefined')\n ) {\n layer.unrender();\n continue;\n }\n\n const element = layer.render(frameState, previousElement);\n if (!element) {\n continue;\n }\n if (element !== previousElement) {\n this.children_.push(element);\n previousElement = element;\n }\n\n renderedLayerStates.push(layerState);\n }\n\n this.declutter(frameState, renderedLayerStates);\n\n replaceChildren(this.element_, this.children_);\n\n this.dispatchRenderEvent(RenderEventType.POSTCOMPOSE, frameState);\n\n if (!this.renderedVisible_) {\n this.element_.style.display = '';\n this.renderedVisible_ = true;\n }\n\n this.scheduleExpireIconCache(frameState);\n }\n\n /**\n * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n * @param {Array} layerStates Layers.\n */\n declutter(frameState, layerStates) {\n if (!frameState.declutter) {\n return;\n }\n for (let i = layerStates.length - 1; i >= 0; --i) {\n const layerState = layerStates[i];\n const layer = layerState.layer;\n if (layer.getDeclutter()) {\n layer.renderDeclutter(frameState, layerState);\n }\n }\n layerStates.forEach((layerState) =>\n layerState.layer.renderDeferred(frameState),\n );\n }\n}\n\nexport default CompositeMapRenderer;\n","/**\n * @module ol/MapEvent\n */\nimport Event from './events/Event.js';\n\n/**\n * @classdesc\n * Events emitted as map events are instances of this type.\n * See {@link module:ol/Map~Map} for which events trigger a map event.\n */\nclass MapEvent extends Event {\n /**\n * @param {string} type Event type.\n * @param {import(\"./Map.js\").default} map Map.\n * @param {?import(\"./Map.js\").FrameState} [frameState] Frame state.\n */\n constructor(type, map, frameState) {\n super(type);\n\n /**\n * The map where the event occurred.\n * @type {import(\"./Map.js\").default}\n * @api\n */\n this.map = map;\n\n /**\n * The frame state at the time of the event.\n * @type {?import(\"./Map.js\").FrameState}\n * @api\n */\n this.frameState = frameState !== undefined ? frameState : null;\n }\n}\n\nexport default MapEvent;\n","/**\n * @module ol/MapBrowserEvent\n */\nimport MapEvent from './MapEvent.js';\n\n/**\n * @classdesc\n * Events emitted as map browser events are instances of this type.\n * See {@link module:ol/Map~Map} for which events trigger a map browser event.\n * @template {UIEvent} EVENT\n */\nclass MapBrowserEvent extends MapEvent {\n /**\n * @param {string} type Event type.\n * @param {import(\"./Map.js\").default} map Map.\n * @param {EVENT} originalEvent Original event.\n * @param {boolean} [dragging] Is the map currently being dragged?\n * @param {import(\"./Map.js\").FrameState} [frameState] Frame state.\n * @param {Array} [activePointers] Active pointers.\n */\n constructor(type, map, originalEvent, dragging, frameState, activePointers) {\n super(type, map, frameState);\n\n /**\n * The original browser event.\n * @const\n * @type {EVENT}\n * @api\n */\n this.originalEvent = originalEvent;\n\n /**\n * The map pixel relative to the viewport corresponding to the original browser event.\n * @type {?import(\"./pixel.js\").Pixel}\n * @private\n */\n this.pixel_ = null;\n\n /**\n * The coordinate in the user projection corresponding to the original browser event.\n * @type {?import(\"./coordinate.js\").Coordinate}\n * @private\n */\n this.coordinate_ = null;\n\n /**\n * Indicates if the map is currently being dragged. Only set for\n * `POINTERDRAG` and `POINTERMOVE` events. Default is `false`.\n *\n * @type {boolean}\n * @api\n */\n this.dragging = dragging !== undefined ? dragging : false;\n\n /**\n * @type {Array|undefined}\n */\n this.activePointers = activePointers;\n }\n\n /**\n * The map pixel relative to the viewport corresponding to the original event.\n * @type {import(\"./pixel.js\").Pixel}\n * @api\n */\n get pixel() {\n if (!this.pixel_) {\n this.pixel_ = this.map.getEventPixel(this.originalEvent);\n }\n return this.pixel_;\n }\n set pixel(pixel) {\n this.pixel_ = pixel;\n }\n\n /**\n * The coordinate corresponding to the original browser event. This will be in the user\n * projection if one is set. Otherwise it will be in the view projection.\n * @type {import(\"./coordinate.js\").Coordinate}\n * @api\n */\n get coordinate() {\n if (!this.coordinate_) {\n this.coordinate_ = this.map.getCoordinateFromPixel(this.pixel);\n }\n return this.coordinate_;\n }\n set coordinate(coordinate) {\n this.coordinate_ = coordinate;\n }\n\n /**\n * Prevents the default browser action.\n * See https://developer.mozilla.org/en-US/docs/Web/API/event.preventDefault.\n * @api\n * @override\n */\n preventDefault() {\n super.preventDefault();\n if ('preventDefault' in this.originalEvent) {\n /** @type {UIEvent} */ (this.originalEvent).preventDefault();\n }\n }\n\n /**\n * Prevents further propagation of the current event.\n * See https://developer.mozilla.org/en-US/docs/Web/API/event.stopPropagation.\n * @api\n * @override\n */\n stopPropagation() {\n super.stopPropagation();\n if ('stopPropagation' in this.originalEvent) {\n /** @type {UIEvent} */ (this.originalEvent).stopPropagation();\n }\n }\n}\n\nexport default MapBrowserEvent;\n","/**\n * @module ol/MapBrowserEventType\n */\nimport EventType from './events/EventType.js';\n\n/**\n * Constants for event names.\n * @enum {string}\n */\nexport default {\n /**\n * A true single click with no dragging and no double click. Note that this\n * event is delayed by 250 ms to ensure that it is not a double click.\n * @event module:ol/MapBrowserEvent~MapBrowserEvent#singleclick\n * @api\n */\n SINGLECLICK: 'singleclick',\n\n /**\n * A click with no dragging. A double click will fire two of this.\n * @event module:ol/MapBrowserEvent~MapBrowserEvent#click\n * @api\n */\n CLICK: EventType.CLICK,\n\n /**\n * A true double click, with no dragging.\n * @event module:ol/MapBrowserEvent~MapBrowserEvent#dblclick\n * @api\n */\n DBLCLICK: EventType.DBLCLICK,\n\n /**\n * Triggered when a pointer is dragged.\n * @event module:ol/MapBrowserEvent~MapBrowserEvent#pointerdrag\n * @api\n */\n POINTERDRAG: 'pointerdrag',\n\n /**\n * Triggered when a pointer is moved. Note that on touch devices this is\n * triggered when the map is panned, so is not the same as mousemove.\n * @event module:ol/MapBrowserEvent~MapBrowserEvent#pointermove\n * @api\n */\n POINTERMOVE: 'pointermove',\n\n POINTERDOWN: 'pointerdown',\n POINTERUP: 'pointerup',\n POINTEROVER: 'pointerover',\n POINTEROUT: 'pointerout',\n POINTERENTER: 'pointerenter',\n POINTERLEAVE: 'pointerleave',\n POINTERCANCEL: 'pointercancel',\n};\n\n/***\n * @typedef {'singleclick'|'click'|'dblclick'|'pointerdrag'|'pointermove'} Types\n */\n","/**\n * @module ol/pointer/EventType\n */\n\n/**\n * Constants for event names.\n * @enum {string}\n */\nexport default {\n POINTERMOVE: 'pointermove',\n POINTERDOWN: 'pointerdown',\n POINTERUP: 'pointerup',\n POINTEROVER: 'pointerover',\n POINTEROUT: 'pointerout',\n POINTERENTER: 'pointerenter',\n POINTERLEAVE: 'pointerleave',\n POINTERCANCEL: 'pointercancel',\n};\n","/**\n * @module ol/MapBrowserEventHandler\n */\n\nimport EventType from './events/EventType.js';\nimport MapBrowserEvent from './MapBrowserEvent.js';\nimport MapBrowserEventType from './MapBrowserEventType.js';\nimport PointerEventType from './pointer/EventType.js';\nimport Target from './events/Target.js';\nimport {PASSIVE_EVENT_LISTENERS} from './has.js';\nimport {listen, unlistenByKey} from './events.js';\n\nclass MapBrowserEventHandler extends Target {\n /**\n * @param {import(\"./Map.js\").default} map The map with the viewport to listen to events on.\n * @param {number} [moveTolerance] The minimal distance the pointer must travel to trigger a move.\n */\n constructor(map, moveTolerance) {\n super(map);\n\n /**\n * This is the element that we will listen to the real events on.\n * @type {import(\"./Map.js\").default}\n * @private\n */\n this.map_ = map;\n\n /**\n * @type {ReturnType}\n * @private\n */\n this.clickTimeoutId_;\n\n /**\n * Emulate dblclick and singleclick. Will be true when only one pointer is active.\n * @type {boolean}\n */\n this.emulateClicks_ = false;\n\n /**\n * @type {boolean}\n * @private\n */\n this.dragging_ = false;\n\n /**\n * @type {!Array}\n * @private\n */\n this.dragListenerKeys_ = [];\n\n /**\n * @type {number}\n * @private\n */\n this.moveTolerance_ = moveTolerance === undefined ? 1 : moveTolerance;\n\n /**\n * The most recent \"down\" type event (or null if none have occurred).\n * Set on pointerdown.\n * @type {PointerEvent|null}\n * @private\n */\n this.down_ = null;\n\n const element = this.map_.getViewport();\n\n /**\n * @type {Array}\n * @private\n */\n this.activePointers_ = [];\n\n /**\n * @type {!Object}\n * @private\n */\n this.trackedTouches_ = {};\n\n /**\n * @private\n */\n this.element_ = element;\n\n /**\n * @type {?import(\"./events.js\").EventsKey}\n * @private\n */\n this.pointerdownListenerKey_ = listen(\n element,\n PointerEventType.POINTERDOWN,\n this.handlePointerDown_,\n this,\n );\n\n /**\n * @type {PointerEvent}\n * @private\n */\n this.originalPointerMoveEvent_;\n\n /**\n * @type {?import(\"./events.js\").EventsKey}\n * @private\n */\n this.relayedListenerKey_ = listen(\n element,\n PointerEventType.POINTERMOVE,\n this.relayMoveEvent_,\n this,\n );\n\n /**\n * @private\n */\n this.boundHandleTouchMove_ = this.handleTouchMove_.bind(this);\n\n this.element_.addEventListener(\n EventType.TOUCHMOVE,\n this.boundHandleTouchMove_,\n PASSIVE_EVENT_LISTENERS ? {passive: false} : false,\n );\n }\n\n /**\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @private\n */\n emulateClick_(pointerEvent) {\n let newEvent = new MapBrowserEvent(\n MapBrowserEventType.CLICK,\n this.map_,\n pointerEvent,\n );\n this.dispatchEvent(newEvent);\n if (this.clickTimeoutId_ !== undefined) {\n // double-click\n clearTimeout(this.clickTimeoutId_);\n this.clickTimeoutId_ = undefined;\n newEvent = new MapBrowserEvent(\n MapBrowserEventType.DBLCLICK,\n this.map_,\n pointerEvent,\n );\n this.dispatchEvent(newEvent);\n } else {\n // click\n this.clickTimeoutId_ = setTimeout(() => {\n this.clickTimeoutId_ = undefined;\n const newEvent = new MapBrowserEvent(\n MapBrowserEventType.SINGLECLICK,\n this.map_,\n pointerEvent,\n );\n this.dispatchEvent(newEvent);\n }, 250);\n }\n }\n\n /**\n * Keeps track on how many pointers are currently active.\n *\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @private\n */\n updateActivePointers_(pointerEvent) {\n const event = pointerEvent;\n const id = event.pointerId;\n\n if (\n event.type == MapBrowserEventType.POINTERUP ||\n event.type == MapBrowserEventType.POINTERCANCEL\n ) {\n delete this.trackedTouches_[id];\n for (const pointerId in this.trackedTouches_) {\n if (this.trackedTouches_[pointerId].target !== event.target) {\n // Some platforms assign a new pointerId when the target changes.\n // If this happens, delete one tracked pointer. If there is more\n // than one tracked pointer for the old target, it will be cleared\n // by subsequent POINTERUP events from other pointers.\n delete this.trackedTouches_[pointerId];\n break;\n }\n }\n } else if (\n event.type == MapBrowserEventType.POINTERDOWN ||\n event.type == MapBrowserEventType.POINTERMOVE\n ) {\n this.trackedTouches_[id] = event;\n }\n this.activePointers_ = Object.values(this.trackedTouches_);\n }\n\n /**\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @private\n */\n handlePointerUp_(pointerEvent) {\n this.updateActivePointers_(pointerEvent);\n const newEvent = new MapBrowserEvent(\n MapBrowserEventType.POINTERUP,\n this.map_,\n pointerEvent,\n undefined,\n undefined,\n this.activePointers_,\n );\n this.dispatchEvent(newEvent);\n\n // We emulate click events on left mouse button click, touch contact, and pen\n // contact. isMouseActionButton returns true in these cases (evt.button is set\n // to 0).\n // See http://www.w3.org/TR/pointerevents/#button-states\n // We only fire click, singleclick, and doubleclick if nobody has called\n // event.preventDefault().\n if (\n this.emulateClicks_ &&\n !newEvent.defaultPrevented &&\n !this.dragging_ &&\n this.isMouseActionButton_(pointerEvent)\n ) {\n this.emulateClick_(this.down_);\n }\n\n if (this.activePointers_.length === 0) {\n this.dragListenerKeys_.forEach(unlistenByKey);\n this.dragListenerKeys_.length = 0;\n this.dragging_ = false;\n this.down_ = null;\n }\n }\n\n /**\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @return {boolean} If the left mouse button was pressed.\n * @private\n */\n isMouseActionButton_(pointerEvent) {\n return pointerEvent.button === 0;\n }\n\n /**\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @private\n */\n handlePointerDown_(pointerEvent) {\n this.emulateClicks_ = this.activePointers_.length === 0;\n this.updateActivePointers_(pointerEvent);\n const newEvent = new MapBrowserEvent(\n MapBrowserEventType.POINTERDOWN,\n this.map_,\n pointerEvent,\n undefined,\n undefined,\n this.activePointers_,\n );\n this.dispatchEvent(newEvent);\n\n this.down_ = new PointerEvent(pointerEvent.type, pointerEvent);\n Object.defineProperty(this.down_, 'target', {\n writable: false,\n value: pointerEvent.target,\n });\n\n if (this.dragListenerKeys_.length === 0) {\n const doc = this.map_.getOwnerDocument();\n this.dragListenerKeys_.push(\n listen(\n doc,\n MapBrowserEventType.POINTERMOVE,\n this.handlePointerMove_,\n this,\n ),\n listen(doc, MapBrowserEventType.POINTERUP, this.handlePointerUp_, this),\n /* Note that the listener for `pointercancel is set up on\n * `pointerEventHandler_` and not `documentPointerEventHandler_` like\n * the `pointerup` and `pointermove` listeners.\n *\n * The reason for this is the following: `TouchSource.vacuumTouches_()`\n * issues `pointercancel` events, when there was no `touchend` for a\n * `touchstart`. Now, let's say a first `touchstart` is registered on\n * `pointerEventHandler_`. The `documentPointerEventHandler_` is set up.\n * But `documentPointerEventHandler_` doesn't know about the first\n * `touchstart`. If there is no `touchend` for the `touchstart`, we can\n * only receive a `touchcancel` from `pointerEventHandler_`, because it is\n * only registered there.\n */\n listen(\n this.element_,\n MapBrowserEventType.POINTERCANCEL,\n this.handlePointerUp_,\n this,\n ),\n );\n if (this.element_.getRootNode && this.element_.getRootNode() !== doc) {\n this.dragListenerKeys_.push(\n listen(\n this.element_.getRootNode(),\n MapBrowserEventType.POINTERUP,\n this.handlePointerUp_,\n this,\n ),\n );\n }\n }\n }\n\n /**\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @private\n */\n handlePointerMove_(pointerEvent) {\n // Between pointerdown and pointerup, pointermove events are triggered.\n // To avoid a 'false' touchmove event to be dispatched, we test if the pointer\n // moved a significant distance.\n if (this.isMoving_(pointerEvent)) {\n this.updateActivePointers_(pointerEvent);\n this.dragging_ = true;\n const newEvent = new MapBrowserEvent(\n MapBrowserEventType.POINTERDRAG,\n this.map_,\n pointerEvent,\n this.dragging_,\n undefined,\n this.activePointers_,\n );\n this.dispatchEvent(newEvent);\n }\n }\n\n /**\n * Wrap and relay a pointermove event.\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @private\n */\n relayMoveEvent_(pointerEvent) {\n this.originalPointerMoveEvent_ = pointerEvent;\n const dragging = !!(this.down_ && this.isMoving_(pointerEvent));\n this.dispatchEvent(\n new MapBrowserEvent(\n MapBrowserEventType.POINTERMOVE,\n this.map_,\n pointerEvent,\n dragging,\n ),\n );\n }\n\n /**\n * Flexible handling of a `touch-action: none` css equivalent: because calling\n * `preventDefault()` on a `pointermove` event does not stop native page scrolling\n * and zooming, we also listen for `touchmove` and call `preventDefault()` on it\n * when an interaction (currently `DragPan` handles the event.\n * @param {TouchEvent} event Event.\n * @private\n */\n handleTouchMove_(event) {\n // Due to https://github.com/mpizenberg/elm-pep/issues/2, `this.originalPointerMoveEvent_`\n // may not be initialized yet when we get here on a platform without native pointer events,\n // when elm-pep is used as pointer events polyfill.\n const originalEvent = this.originalPointerMoveEvent_;\n if (\n (!originalEvent || originalEvent.defaultPrevented) &&\n (typeof event.cancelable !== 'boolean' || event.cancelable === true)\n ) {\n event.preventDefault();\n }\n }\n\n /**\n * @param {PointerEvent} pointerEvent Pointer\n * event.\n * @return {boolean} Is moving.\n * @private\n */\n isMoving_(pointerEvent) {\n return (\n this.dragging_ ||\n Math.abs(pointerEvent.clientX - this.down_.clientX) >\n this.moveTolerance_ ||\n Math.abs(pointerEvent.clientY - this.down_.clientY) > this.moveTolerance_\n );\n }\n\n /**\n * Clean up.\n * @override\n */\n disposeInternal() {\n if (this.relayedListenerKey_) {\n unlistenByKey(this.relayedListenerKey_);\n this.relayedListenerKey_ = null;\n }\n this.element_.removeEventListener(\n EventType.TOUCHMOVE,\n this.boundHandleTouchMove_,\n );\n\n if (this.pointerdownListenerKey_) {\n unlistenByKey(this.pointerdownListenerKey_);\n this.pointerdownListenerKey_ = null;\n }\n\n this.dragListenerKeys_.forEach(unlistenByKey);\n this.dragListenerKeys_.length = 0;\n\n this.element_ = null;\n super.disposeInternal();\n }\n}\n\nexport default MapBrowserEventHandler;\n","/**\n * @module ol/MapEventType\n */\n\n/**\n * @enum {string}\n */\nexport default {\n /**\n * Triggered after a map frame is rendered.\n * @event module:ol/MapEvent~MapEvent#postrender\n * @api\n */\n POSTRENDER: 'postrender',\n\n /**\n * Triggered when the map starts moving.\n * @event module:ol/MapEvent~MapEvent#movestart\n * @api\n */\n MOVESTART: 'movestart',\n\n /**\n * Triggered after the map is moved.\n * @event module:ol/MapEvent~MapEvent#moveend\n * @api\n */\n MOVEEND: 'moveend',\n\n /**\n * Triggered when loading of additional map data (tiles, images, features) starts.\n * @event module:ol/MapEvent~MapEvent#loadstart\n * @api\n */\n LOADSTART: 'loadstart',\n\n /**\n * Triggered when loading of additional map data has completed.\n * @event module:ol/MapEvent~MapEvent#loadend\n * @api\n */\n LOADEND: 'loadend',\n};\n\n/***\n * @typedef {'postrender'|'movestart'|'moveend'|'loadstart'|'loadend'} Types\n */\n","/**\n * @module ol/MapProperty\n */\n\n/**\n * @enum {string}\n */\nexport default {\n LAYERGROUP: 'layergroup',\n SIZE: 'size',\n TARGET: 'target',\n VIEW: 'view',\n};\n","/**\n * @module ol/control/Control\n */\nimport BaseObject from '../Object.js';\nimport MapEventType from '../MapEventType.js';\nimport {VOID} from '../functions.js';\nimport {listen, unlistenByKey} from '../events.js';\n\n/**\n * @typedef {Object} Options\n * @property {HTMLElement} [element] The element is the control's\n * container element. This only needs to be specified if you're developing\n * a custom control.\n * @property {function(import(\"../MapEvent.js\").default):void} [render] Function called when\n * the control should be re-rendered. This is called in a `requestAnimationFrame`\n * callback.\n * @property {HTMLElement|string} [target] Specify a target if you want\n * the control to be rendered outside of the map's viewport.\n */\n\n/**\n * @classdesc\n * A control is a visible widget with a DOM element in a fixed position on the\n * screen. They can involve user input (buttons), or be informational only;\n * the position is determined using CSS. By default these are placed in the\n * container with CSS class name `ol-overlaycontainer-stopevent`, but can use\n * any outside DOM element.\n *\n * This is the base class for controls. You can use it for simple custom\n * controls by creating the element with listeners, creating an instance:\n * ```js\n * const myControl = new Control({element: myElement});\n * ```\n * and then adding this to the map.\n *\n * The main advantage of having this as a control rather than a simple separate\n * DOM element is that preventing propagation is handled for you. Controls\n * will also be objects in a {@link module:ol/Collection~Collection}, so you can use their methods.\n *\n * You can also extend this base for your own control class. See\n * examples/custom-controls for an example of how to do this.\n *\n * @api\n */\nclass Control extends BaseObject {\n /**\n * @param {Options} options Control options.\n */\n constructor(options) {\n super();\n\n const element = options.element;\n if (element && !options.target && !element.style.pointerEvents) {\n element.style.pointerEvents = 'auto';\n }\n\n /**\n * @protected\n * @type {HTMLElement}\n */\n this.element = element ? element : null;\n\n /**\n * @private\n * @type {HTMLElement}\n */\n this.target_ = null;\n\n /**\n * @private\n * @type {import(\"../Map.js\").default|null}\n */\n this.map_ = null;\n\n /**\n * @protected\n * @type {!Array}\n */\n this.listenerKeys = [];\n\n if (options.render) {\n this.render = options.render;\n }\n\n if (options.target) {\n this.setTarget(options.target);\n }\n }\n\n /**\n * Clean up.\n * @override\n */\n disposeInternal() {\n this.element?.remove();\n super.disposeInternal();\n }\n\n /**\n * Get the map associated with this control.\n * @return {import(\"../Map.js\").default|null} Map.\n * @api\n */\n getMap() {\n return this.map_;\n }\n\n /**\n * Remove the control from its current map and attach it to the new map.\n * Pass `null` to just remove the control from the current map.\n * Subclasses may set up event handlers to get notified about changes to\n * the map here.\n * @param {import(\"../Map.js\").default|null} map Map.\n * @api\n */\n setMap(map) {\n if (this.map_) {\n this.element?.remove();\n }\n for (let i = 0, ii = this.listenerKeys.length; i < ii; ++i) {\n unlistenByKey(this.listenerKeys[i]);\n }\n this.listenerKeys.length = 0;\n this.map_ = map;\n if (map) {\n const target = this.target_ ?? map.getOverlayContainerStopEvent();\n target.appendChild(this.element);\n if (this.render !== VOID) {\n this.listenerKeys.push(\n listen(map, MapEventType.POSTRENDER, this.render, this),\n );\n }\n map.render();\n }\n }\n\n /**\n * Renders the control.\n * @param {import(\"../MapEvent.js\").default} mapEvent Map event.\n * @api\n */\n render(mapEvent) {}\n\n /**\n * This function is used to set a target element for the control. It has no\n * effect if it is called after the control has been added to the map (i.e.\n * after `setMap` is called on the control). If no `target` is set in the\n * options passed to the control constructor and if `setTarget` is not called\n * then the control is added to the map's overlay container.\n * @param {HTMLElement|string} target Target.\n * @api\n */\n setTarget(target) {\n this.target_ =\n typeof target === 'string' ? document.getElementById(target) : target;\n }\n}\n\nexport default Control;\n","/**\n * @module ol/control/Attribution\n */\nimport Control from './Control.js';\nimport EventType from '../events/EventType.js';\nimport {CLASS_COLLAPSED, CLASS_CONTROL, CLASS_UNSELECTABLE} from '../css.js';\nimport {equals} from '../array.js';\nimport {removeChildren, replaceNode} from '../dom.js';\nimport {toPromise} from '../functions.js';\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-attribution'] CSS class name.\n * @property {HTMLElement|string} [target] Specify a target if you\n * want the control to be rendered outside of the map's\n * viewport.\n * @property {boolean} [collapsible] Specify if attributions can\n * be collapsed. If not specified, sources control this behavior with their\n * `attributionsCollapsible` setting.\n * @property {boolean} [collapsed=true] Specify if attributions should\n * be collapsed at startup.\n * @property {string} [tipLabel='Attributions'] Text label to use for the button tip.\n * @property {string|HTMLElement} [label='i'] Text label to use for the\n * collapsed attributions button.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string} [expandClassName=className + '-expand'] CSS class name for the\n * collapsed attributions button.\n * @property {string|HTMLElement} [collapseLabel='›'] Text label to use\n * for the expanded attributions button.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string} [collapseClassName=className + '-collapse'] CSS class name for the\n * expanded attributions button.\n * @property {function(import(\"../MapEvent.js\").default):void} [render] Function called when\n * the control should be re-rendered. This is called in a `requestAnimationFrame`\n * callback.\n */\n\n/**\n * @classdesc\n * Control to show all the attributions associated with the layer sources\n * in the map. This control is one of the default controls included in maps.\n * By default it will show in the bottom right portion of the map, but this can\n * be changed by using a css selector for `.ol-attribution`.\n *\n * @api\n */\nclass Attribution extends Control {\n /**\n * @param {Options} [options] Attribution options.\n */\n constructor(options) {\n options = options ? options : {};\n\n super({\n element: document.createElement('div'),\n render: options.render,\n target: options.target,\n });\n\n /**\n * @private\n * @type {HTMLElement}\n */\n this.ulElement_ = document.createElement('ul');\n\n /**\n * @private\n * @type {boolean}\n */\n this.collapsed_ =\n options.collapsed !== undefined ? options.collapsed : true;\n\n /**\n * @private\n * @type {boolean}\n */\n this.userCollapsed_ = this.collapsed_;\n\n /**\n * @private\n * @type {boolean}\n */\n this.overrideCollapsible_ = options.collapsible !== undefined;\n\n /**\n * @private\n * @type {boolean}\n */\n this.collapsible_ =\n options.collapsible !== undefined ? options.collapsible : true;\n\n if (!this.collapsible_) {\n this.collapsed_ = false;\n }\n\n const className =\n options.className !== undefined ? options.className : 'ol-attribution';\n\n const tipLabel =\n options.tipLabel !== undefined ? options.tipLabel : 'Attributions';\n\n const expandClassName =\n options.expandClassName !== undefined\n ? options.expandClassName\n : className + '-expand';\n\n const collapseLabel =\n options.collapseLabel !== undefined ? options.collapseLabel : '\\u203A';\n\n const collapseClassName =\n options.collapseClassName !== undefined\n ? options.collapseClassName\n : className + '-collapse';\n\n if (typeof collapseLabel === 'string') {\n /**\n * @private\n * @type {HTMLElement}\n */\n this.collapseLabel_ = document.createElement('span');\n this.collapseLabel_.textContent = collapseLabel;\n this.collapseLabel_.className = collapseClassName;\n } else {\n this.collapseLabel_ = collapseLabel;\n }\n\n const label = options.label !== undefined ? options.label : 'i';\n\n if (typeof label === 'string') {\n /**\n * @private\n * @type {HTMLElement}\n */\n this.label_ = document.createElement('span');\n this.label_.textContent = label;\n this.label_.className = expandClassName;\n } else {\n this.label_ = label;\n }\n\n const activeLabel =\n this.collapsible_ && !this.collapsed_ ? this.collapseLabel_ : this.label_;\n\n /**\n * @private\n * @type {HTMLElement}\n */\n this.toggleButton_ = document.createElement('button');\n this.toggleButton_.setAttribute('type', 'button');\n this.toggleButton_.setAttribute('aria-expanded', String(!this.collapsed_));\n this.toggleButton_.title = tipLabel;\n this.toggleButton_.appendChild(activeLabel);\n\n this.toggleButton_.addEventListener(\n EventType.CLICK,\n this.handleClick_.bind(this),\n false,\n );\n\n const cssClasses =\n className +\n ' ' +\n CLASS_UNSELECTABLE +\n ' ' +\n CLASS_CONTROL +\n (this.collapsed_ && this.collapsible_ ? ' ' + CLASS_COLLAPSED : '') +\n (this.collapsible_ ? '' : ' ol-uncollapsible');\n const element = this.element;\n element.className = cssClasses;\n element.appendChild(this.toggleButton_);\n element.appendChild(this.ulElement_);\n\n /**\n * A list of currently rendered resolutions.\n * @type {Array}\n * @private\n */\n this.renderedAttributions_ = [];\n\n /**\n * @private\n * @type {boolean}\n */\n this.renderedVisible_ = true;\n }\n\n /**\n * Collect a list of visible attributions and set the collapsible state.\n * @param {import(\"../Map.js\").FrameState} frameState Frame state.\n * @return {Array} Attributions.\n * @private\n */\n collectSourceAttributions_(frameState) {\n const layers = this.getMap().getAllLayers();\n const visibleAttributions = Array.from(\n new Set(layers.flatMap((layer) => layer.getAttributions(frameState))),\n );\n\n if (!this.overrideCollapsible_) {\n const collapsible = !layers.some(\n (layer) => layer.getSource()?.getAttributionsCollapsible() === false,\n );\n this.setCollapsible(collapsible);\n }\n return visibleAttributions;\n }\n\n /**\n * @private\n * @param {?import(\"../Map.js\").FrameState} frameState Frame state.\n */\n async updateElement_(frameState) {\n if (!frameState) {\n if (this.renderedVisible_) {\n this.element.style.display = 'none';\n this.renderedVisible_ = false;\n }\n return;\n }\n\n const attributions = await Promise.all(\n this.collectSourceAttributions_(frameState).map((attribution) =>\n toPromise(() => attribution),\n ),\n );\n\n const visible = attributions.length > 0;\n if (this.renderedVisible_ != visible) {\n this.element.style.display = visible ? '' : 'none';\n this.renderedVisible_ = visible;\n }\n\n if (equals(attributions, this.renderedAttributions_)) {\n return;\n }\n\n removeChildren(this.ulElement_);\n\n // append the attributions\n for (let i = 0, ii = attributions.length; i < ii; ++i) {\n const element = document.createElement('li');\n element.innerHTML = attributions[i];\n this.ulElement_.appendChild(element);\n }\n\n this.renderedAttributions_ = attributions;\n }\n\n /**\n * @param {MouseEvent} event The event to handle\n * @private\n */\n handleClick_(event) {\n event.preventDefault();\n this.handleToggle_();\n this.userCollapsed_ = this.collapsed_;\n }\n\n /**\n * @private\n */\n handleToggle_() {\n this.element.classList.toggle(CLASS_COLLAPSED);\n if (this.collapsed_) {\n replaceNode(this.collapseLabel_, this.label_);\n } else {\n replaceNode(this.label_, this.collapseLabel_);\n }\n this.collapsed_ = !this.collapsed_;\n this.toggleButton_.setAttribute('aria-expanded', String(!this.collapsed_));\n }\n\n /**\n * Return `true` if the attribution is collapsible, `false` otherwise.\n * @return {boolean} True if the widget is collapsible.\n * @api\n */\n getCollapsible() {\n return this.collapsible_;\n }\n\n /**\n * Set whether the attribution should be collapsible.\n * @param {boolean} collapsible True if the widget is collapsible.\n * @api\n */\n setCollapsible(collapsible) {\n if (this.collapsible_ === collapsible) {\n return;\n }\n this.collapsible_ = collapsible;\n this.element.classList.toggle('ol-uncollapsible');\n if (this.userCollapsed_) {\n this.handleToggle_();\n }\n }\n\n /**\n * Collapse or expand the attribution according to the passed parameter. Will\n * not do anything if the attribution isn't collapsible or if the current\n * collapsed state is already the one requested.\n * @param {boolean} collapsed True if the widget is collapsed.\n * @api\n */\n setCollapsed(collapsed) {\n this.userCollapsed_ = collapsed;\n if (!this.collapsible_ || this.collapsed_ === collapsed) {\n return;\n }\n this.handleToggle_();\n }\n\n /**\n * Return `true` when the attribution is currently collapsed or `false`\n * otherwise.\n * @return {boolean} True if the widget is collapsed.\n * @api\n */\n getCollapsed() {\n return this.collapsed_;\n }\n\n /**\n * Update the attribution element.\n * @param {import(\"../MapEvent.js\").default} mapEvent Map event.\n * @override\n */\n render(mapEvent) {\n this.updateElement_(mapEvent.frameState);\n }\n}\n\nexport default Attribution;\n","/**\n * @module ol/control/Rotate\n */\nimport Control from './Control.js';\nimport EventType from '../events/EventType.js';\nimport {CLASS_CONTROL, CLASS_HIDDEN, CLASS_UNSELECTABLE} from '../css.js';\nimport {easeOut} from '../easing.js';\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-rotate'] CSS class name.\n * @property {string|HTMLElement} [label='⇧'] Text label to use for the rotate button.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string} [tipLabel='Reset rotation'] Text label to use for the rotate tip.\n * @property {string} [compassClassName='ol-compass'] CSS class name for the compass.\n * @property {number} [duration=250] Animation duration in milliseconds.\n * @property {boolean} [autoHide=true] Hide the control when rotation is 0.\n * @property {function(import(\"../MapEvent.js\").default):void} [render] Function called when the control should\n * be re-rendered. This is called in a `requestAnimationFrame` callback.\n * @property {function():void} [resetNorth] Function called when the control is clicked.\n * This will override the default `resetNorth`.\n * @property {HTMLElement|string} [target] Specify a target if you want the control to be\n * rendered outside of the map's viewport.\n */\n\n/**\n * @classdesc\n * A button control to reset rotation to 0.\n * To style this control use css selector `.ol-rotate`. A `.ol-hidden` css\n * selector is added to the button when the rotation is 0.\n *\n * @api\n */\nclass Rotate extends Control {\n /**\n * @param {Options} [options] Rotate options.\n */\n constructor(options) {\n options = options ? options : {};\n\n super({\n element: document.createElement('div'),\n render: options.render,\n target: options.target,\n });\n\n const className =\n options.className !== undefined ? options.className : 'ol-rotate';\n\n const label = options.label !== undefined ? options.label : '\\u21E7';\n\n const compassClassName =\n options.compassClassName !== undefined\n ? options.compassClassName\n : 'ol-compass';\n\n /**\n * @type {HTMLElement}\n * @private\n */\n this.label_ = null;\n\n if (typeof label === 'string') {\n this.label_ = document.createElement('span');\n this.label_.className = compassClassName;\n this.label_.textContent = label;\n } else {\n this.label_ = label;\n this.label_.classList.add(compassClassName);\n }\n\n const tipLabel = options.tipLabel ? options.tipLabel : 'Reset rotation';\n\n const button = document.createElement('button');\n button.className = className + '-reset';\n button.setAttribute('type', 'button');\n button.title = tipLabel;\n button.appendChild(this.label_);\n\n button.addEventListener(\n EventType.CLICK,\n this.handleClick_.bind(this),\n false,\n );\n\n const cssClasses =\n className + ' ' + CLASS_UNSELECTABLE + ' ' + CLASS_CONTROL;\n const element = this.element;\n element.className = cssClasses;\n element.appendChild(button);\n\n /**\n * @private\n */\n this.callResetNorth_ = options.resetNorth ? options.resetNorth : undefined;\n\n /**\n * @type {number}\n * @private\n */\n this.duration_ = options.duration !== undefined ? options.duration : 250;\n\n /**\n * @type {boolean}\n * @private\n */\n this.autoHide_ = options.autoHide !== undefined ? options.autoHide : true;\n\n /**\n * @private\n * @type {number|undefined}\n */\n this.rotation_ = undefined;\n\n if (this.autoHide_) {\n this.element.classList.add(CLASS_HIDDEN);\n }\n }\n\n /**\n * @param {MouseEvent} event The event to handle\n * @private\n */\n handleClick_(event) {\n event.preventDefault();\n if (this.callResetNorth_ !== undefined) {\n this.callResetNorth_();\n } else {\n this.resetNorth_();\n }\n }\n\n /**\n * @private\n */\n resetNorth_() {\n const map = this.getMap();\n const view = map.getView();\n if (!view) {\n // the map does not have a view, so we can't act\n // upon it\n return;\n }\n const rotation = view.getRotation();\n if (rotation !== undefined) {\n if (this.duration_ > 0 && rotation % (2 * Math.PI) !== 0) {\n view.animate({\n rotation: 0,\n duration: this.duration_,\n easing: easeOut,\n });\n } else {\n view.setRotation(0);\n }\n }\n }\n\n /**\n * Update the rotate control element.\n * @param {import(\"../MapEvent.js\").default} mapEvent Map event.\n * @override\n */\n render(mapEvent) {\n const frameState = mapEvent.frameState;\n if (!frameState) {\n return;\n }\n const rotation = frameState.viewState.rotation;\n if (rotation != this.rotation_) {\n const transform = 'rotate(' + rotation + 'rad)';\n if (this.autoHide_) {\n const contains = this.element.classList.contains(CLASS_HIDDEN);\n if (!contains && rotation === 0) {\n this.element.classList.add(CLASS_HIDDEN);\n } else if (contains && rotation !== 0) {\n this.element.classList.remove(CLASS_HIDDEN);\n }\n }\n this.label_.style.transform = transform;\n }\n this.rotation_ = rotation;\n }\n}\n\nexport default Rotate;\n","/**\n * @module ol/control/Zoom\n */\nimport Control from './Control.js';\nimport EventType from '../events/EventType.js';\nimport {CLASS_CONTROL, CLASS_UNSELECTABLE} from '../css.js';\nimport {easeOut} from '../easing.js';\n\n/**\n * @typedef {Object} Options\n * @property {number} [duration=250] Animation duration in milliseconds.\n * @property {string} [className='ol-zoom'] CSS class name.\n * @property {string} [zoomInClassName=className + '-in'] CSS class name for the zoom-in button.\n * @property {string} [zoomOutClassName=className + '-out'] CSS class name for the zoom-out button.\n * @property {string|HTMLElement} [zoomInLabel='+'] Text label to use for the zoom-in\n * button. Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string|HTMLElement} [zoomOutLabel='–'] Text label to use for the zoom-out button.\n * Instead of text, also an element (e.g. a `span` element) can be used.\n * @property {string} [zoomInTipLabel='Zoom in'] Text label to use for the button tip.\n * @property {string} [zoomOutTipLabel='Zoom out'] Text label to use for the button tip.\n * @property {number} [delta=1] The zoom delta applied on each click.\n * @property {HTMLElement|string} [target] Specify a target if you want the control to be\n * rendered outside of the map's viewport.\n */\n\n/**\n * @classdesc\n * A control with 2 buttons, one for zoom in and one for zoom out.\n * This control is one of the default controls of a map. To style this control\n * use css selectors `.ol-zoom-in` and `.ol-zoom-out`.\n *\n * @api\n */\nclass Zoom extends Control {\n /**\n * @param {Options} [options] Zoom options.\n */\n constructor(options) {\n options = options ? options : {};\n\n super({\n element: document.createElement('div'),\n target: options.target,\n });\n\n const className =\n options.className !== undefined ? options.className : 'ol-zoom';\n\n const delta = options.delta !== undefined ? options.delta : 1;\n\n const zoomInClassName =\n options.zoomInClassName !== undefined\n ? options.zoomInClassName\n : className + '-in';\n\n const zoomOutClassName =\n options.zoomOutClassName !== undefined\n ? options.zoomOutClassName\n : className + '-out';\n\n const zoomInLabel =\n options.zoomInLabel !== undefined ? options.zoomInLabel : '+';\n const zoomOutLabel =\n options.zoomOutLabel !== undefined ? options.zoomOutLabel : '\\u2013';\n\n const zoomInTipLabel =\n options.zoomInTipLabel !== undefined ? options.zoomInTipLabel : 'Zoom in';\n const zoomOutTipLabel =\n options.zoomOutTipLabel !== undefined\n ? options.zoomOutTipLabel\n : 'Zoom out';\n\n const inElement = document.createElement('button');\n inElement.className = zoomInClassName;\n inElement.setAttribute('type', 'button');\n inElement.title = zoomInTipLabel;\n inElement.appendChild(\n typeof zoomInLabel === 'string'\n ? document.createTextNode(zoomInLabel)\n : zoomInLabel,\n );\n\n inElement.addEventListener(\n EventType.CLICK,\n this.handleClick_.bind(this, delta),\n false,\n );\n\n const outElement = document.createElement('button');\n outElement.className = zoomOutClassName;\n outElement.setAttribute('type', 'button');\n outElement.title = zoomOutTipLabel;\n outElement.appendChild(\n typeof zoomOutLabel === 'string'\n ? document.createTextNode(zoomOutLabel)\n : zoomOutLabel,\n );\n\n outElement.addEventListener(\n EventType.CLICK,\n this.handleClick_.bind(this, -delta),\n false,\n );\n\n const cssClasses =\n className + ' ' + CLASS_UNSELECTABLE + ' ' + CLASS_CONTROL;\n const element = this.element;\n element.className = cssClasses;\n element.appendChild(inElement);\n element.appendChild(outElement);\n\n /**\n * @type {number}\n * @private\n */\n this.duration_ = options.duration !== undefined ? options.duration : 250;\n }\n\n /**\n * @param {number} delta Zoom delta.\n * @param {MouseEvent} event The event to handle\n * @private\n */\n handleClick_(delta, event) {\n event.preventDefault();\n this.zoomByDelta_(delta);\n }\n\n /**\n * @param {number} delta Zoom delta.\n * @private\n */\n zoomByDelta_(delta) {\n const map = this.getMap();\n const view = map.getView();\n if (!view) {\n // the map does not have a view, so we can't act\n // upon it\n return;\n }\n const currentZoom = view.getZoom();\n if (currentZoom !== undefined) {\n const newZoom = view.getConstrainedZoom(currentZoom + delta);\n if (this.duration_ > 0) {\n if (view.getAnimating()) {\n view.cancelAnimations();\n }\n view.animate({\n zoom: newZoom,\n duration: this.duration_,\n easing: easeOut,\n });\n } else {\n view.setZoom(newZoom);\n }\n }\n }\n}\n\nexport default Zoom;\n","/**\n * @module ol/interaction/Property\n */\n\n/**\n * @enum {string}\n */\nexport default {\n ACTIVE: 'active',\n};\n","/**\n * @module ol/interaction/Interaction\n */\nimport BaseObject from '../Object.js';\nimport InteractionProperty from './Property.js';\nimport {easeOut, linear} from '../easing.js';\n\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature &\n * import(\"../Observable\").OnSignature &\n * import(\"../Observable\").CombinedOnSignature} InteractionOnSignature\n */\n\n/**\n * Object literal with config options for interactions.\n * @typedef {Object} InteractionOptions\n * @property {function(import(\"../MapBrowserEvent.js\").default):boolean} handleEvent\n * Method called by the map to notify the interaction that a browser event was\n * dispatched to the map. If the function returns a falsy value, propagation of\n * the event to other interactions in the map's interactions chain will be\n * prevented (this includes functions with no explicit return). The interactions\n * are traversed in reverse order of the interactions collection of the map.\n */\n\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * User actions that change the state of the map. Some are similar to controls,\n * but are not associated with a DOM element.\n * For example, {@link module:ol/interaction/KeyboardZoom~KeyboardZoom} is\n * functionally the same as {@link module:ol/control/Zoom~Zoom}, but triggered\n * by a keyboard event not a button element event.\n * Although interactions do not have a DOM element, some of them do render\n * vectors and so are visible on the screen.\n * @api\n */\nclass Interaction extends BaseObject {\n /**\n * @param {InteractionOptions} [options] Options.\n */\n constructor(options) {\n super();\n\n /***\n * @type {InteractionOnSignature}\n */\n this.on;\n\n /***\n * @type {InteractionOnSignature}\n */\n this.once;\n\n /***\n * @type {InteractionOnSignature}\n */\n this.un;\n\n if (options && options.handleEvent) {\n this.handleEvent = options.handleEvent;\n }\n\n /**\n * @private\n * @type {import(\"../Map.js\").default|null}\n */\n this.map_ = null;\n\n this.setActive(true);\n }\n\n /**\n * Return whether the interaction is currently active.\n * @return {boolean} `true` if the interaction is active, `false` otherwise.\n * @observable\n * @api\n */\n getActive() {\n return /** @type {boolean} */ (this.get(InteractionProperty.ACTIVE));\n }\n\n /**\n * Get the map associated with this interaction.\n * @return {import(\"../Map.js\").default|null} Map.\n * @api\n */\n getMap() {\n return this.map_;\n }\n\n /**\n * Handles the {@link module:ol/MapBrowserEvent~MapBrowserEvent map browser event}.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} `false` to stop event propagation.\n * @api\n */\n handleEvent(mapBrowserEvent) {\n return true;\n }\n\n /**\n * Activate or deactivate the interaction.\n * @param {boolean} active Active.\n * @observable\n * @api\n */\n setActive(active) {\n this.set(InteractionProperty.ACTIVE, active);\n }\n\n /**\n * Remove the interaction from its current map and attach it to the new map.\n * Subclasses may set up event handlers to get notified about changes to\n * the map here.\n * @param {import(\"../Map.js\").default|null} map Map.\n */\n setMap(map) {\n this.map_ = map;\n }\n}\n\n/**\n * @param {import(\"../View.js\").default} view View.\n * @param {import(\"../coordinate.js\").Coordinate} delta Delta.\n * @param {number} [duration] Duration.\n */\nexport function pan(view, delta, duration) {\n const currentCenter = view.getCenterInternal();\n if (currentCenter) {\n const center = [currentCenter[0] + delta[0], currentCenter[1] + delta[1]];\n view.animateInternal({\n duration: duration !== undefined ? duration : 250,\n easing: linear,\n center: view.getConstrainedCenter(center),\n });\n }\n}\n\n/**\n * @param {import(\"../View.js\").default} view View.\n * @param {number} delta Delta from previous zoom level.\n * @param {import(\"../coordinate.js\").Coordinate} [anchor] Anchor coordinate in the user projection.\n * @param {number} [duration] Duration.\n */\nexport function zoomByDelta(view, delta, anchor, duration) {\n const currentZoom = view.getZoom();\n\n if (currentZoom === undefined) {\n return;\n }\n\n const newZoom = view.getConstrainedZoom(currentZoom + delta);\n const newResolution = view.getResolutionForZoom(newZoom);\n\n if (view.getAnimating()) {\n view.cancelAnimations();\n }\n view.animate({\n resolution: newResolution,\n anchor: anchor,\n duration: duration !== undefined ? duration : 250,\n easing: easeOut,\n });\n}\n\nexport default Interaction;\n","/**\n * @module ol/interaction/DoubleClickZoom\n */\nimport Interaction, {zoomByDelta} from './Interaction.js';\nimport MapBrowserEventType from '../MapBrowserEventType.js';\n\n/**\n * @typedef {Object} Options\n * @property {number} [duration=250] Animation duration in milliseconds.\n * @property {number} [delta=1] The zoom delta applied on each double click.\n */\n\n/**\n * @classdesc\n * Allows the user to zoom by double-clicking on the map.\n * @api\n */\nclass DoubleClickZoom extends Interaction {\n /**\n * @param {Options} [options] Options.\n */\n constructor(options) {\n super();\n\n options = options ? options : {};\n\n /**\n * @private\n * @type {number}\n */\n this.delta_ = options.delta ? options.delta : 1;\n\n /**\n * @private\n * @type {number}\n */\n this.duration_ = options.duration !== undefined ? options.duration : 250;\n }\n\n /**\n * Handles the {@link module:ol/MapBrowserEvent~MapBrowserEvent map browser event} (if it was a\n * doubleclick) and eventually zooms the map.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} `false` to stop event propagation.\n * @override\n */\n handleEvent(mapBrowserEvent) {\n let stopEvent = false;\n if (mapBrowserEvent.type == MapBrowserEventType.DBLCLICK) {\n const browserEvent = /** @type {MouseEvent} */ (\n mapBrowserEvent.originalEvent\n );\n const map = mapBrowserEvent.map;\n const anchor = mapBrowserEvent.coordinate;\n const delta = browserEvent.shiftKey ? -this.delta_ : this.delta_;\n const view = map.getView();\n zoomByDelta(view, delta, anchor, this.duration_);\n browserEvent.preventDefault();\n stopEvent = true;\n }\n return !stopEvent;\n }\n}\n\nexport default DoubleClickZoom;\n","/**\n * @module ol/interaction/Pointer\n */\nimport Interaction from './Interaction.js';\nimport MapBrowserEventType from '../MapBrowserEventType.js';\n\n/**\n * @typedef {Object} Options\n * @property {function(import(\"../MapBrowserEvent.js\").default):boolean} [handleDownEvent]\n * Function handling \"down\" events. If the function returns `true` then a drag\n * sequence is started.\n * @property {function(import(\"../MapBrowserEvent.js\").default):void} [handleDragEvent]\n * Function handling \"drag\" events. This function is called on \"move\" events\n * during a drag sequence.\n * @property {function(import(\"../MapBrowserEvent.js\").default):boolean} [handleEvent]\n * Method called by the map to notify the interaction that a browser event was\n * dispatched to the map. The function may return `false` to prevent the\n * propagation of the event to other interactions in the map's interactions\n * chain.\n * @property {function(import(\"../MapBrowserEvent.js\").default):void} [handleMoveEvent]\n * Function handling \"move\" events. This function is called on \"move\" events.\n * This functions is also called during a drag sequence, so during a drag\n * sequence both the `handleDragEvent` function and this function are called.\n * If `handleDownEvent` is defined and it returns true this function will not\n * be called during a drag sequence.\n * @property {function(import(\"../MapBrowserEvent.js\").default):boolean} [handleUpEvent]\n * Function handling \"up\" events. If the function returns `false` then the\n * current drag sequence is stopped.\n * @property {function(boolean):boolean} [stopDown]\n * Should the down event be propagated to other interactions, or should be\n * stopped?\n */\n\n/**\n * @classdesc\n * Base class that calls user-defined functions on `down`, `move` and `up`\n * events. This class also manages \"drag sequences\".\n *\n * When the `handleDownEvent` user function returns `true` a drag sequence is\n * started. During a drag sequence the `handleDragEvent` user function is\n * called on `move` events. The drag sequence ends when the `handleUpEvent`\n * user function is called and returns `false`.\n * @api\n */\nclass PointerInteraction extends Interaction {\n /**\n * @param {Options} [options] Options.\n */\n constructor(options) {\n options = options ? options : {};\n\n super(\n /** @type {import(\"./Interaction.js\").InteractionOptions} */ (options),\n );\n\n if (options.handleDownEvent) {\n this.handleDownEvent = options.handleDownEvent;\n }\n\n if (options.handleDragEvent) {\n this.handleDragEvent = options.handleDragEvent;\n }\n\n if (options.handleMoveEvent) {\n this.handleMoveEvent = options.handleMoveEvent;\n }\n\n if (options.handleUpEvent) {\n this.handleUpEvent = options.handleUpEvent;\n }\n\n if (options.stopDown) {\n this.stopDown = options.stopDown;\n }\n\n /**\n * @type {boolean}\n * @protected\n */\n this.handlingDownUpSequence = false;\n\n /**\n * @type {Array}\n * @protected\n */\n this.targetPointers = [];\n }\n\n /**\n * Returns the current number of pointers involved in the interaction,\n * e.g. `2` when two fingers are used.\n * @return {number} The number of pointers.\n * @api\n */\n getPointerCount() {\n return this.targetPointers.length;\n }\n\n /**\n * Handle pointer down events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n * @protected\n */\n handleDownEvent(mapBrowserEvent) {\n return false;\n }\n\n /**\n * Handle pointer drag events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @protected\n */\n handleDragEvent(mapBrowserEvent) {}\n\n /**\n * Handles the {@link module:ol/MapBrowserEvent~MapBrowserEvent map browser event} and may call into\n * other functions, if event sequences like e.g. 'drag' or 'down-up' etc. are\n * detected.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} `false` to stop event propagation.\n * @api\n * @override\n */\n handleEvent(mapBrowserEvent) {\n if (!mapBrowserEvent.originalEvent) {\n return true;\n }\n\n let stopEvent = false;\n this.updateTrackedPointers_(mapBrowserEvent);\n if (this.handlingDownUpSequence) {\n if (mapBrowserEvent.type == MapBrowserEventType.POINTERDRAG) {\n this.handleDragEvent(mapBrowserEvent);\n // prevent page scrolling during dragging\n mapBrowserEvent.originalEvent.preventDefault();\n } else if (mapBrowserEvent.type == MapBrowserEventType.POINTERUP) {\n const handledUp = this.handleUpEvent(mapBrowserEvent);\n this.handlingDownUpSequence =\n handledUp && this.targetPointers.length > 0;\n }\n } else {\n if (mapBrowserEvent.type == MapBrowserEventType.POINTERDOWN) {\n const handled = this.handleDownEvent(mapBrowserEvent);\n this.handlingDownUpSequence = handled;\n stopEvent = this.stopDown(handled);\n } else if (mapBrowserEvent.type == MapBrowserEventType.POINTERMOVE) {\n this.handleMoveEvent(mapBrowserEvent);\n }\n }\n return !stopEvent;\n }\n\n /**\n * Handle pointer move events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @protected\n */\n handleMoveEvent(mapBrowserEvent) {}\n\n /**\n * Handle pointer up events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n * @protected\n */\n handleUpEvent(mapBrowserEvent) {\n return false;\n }\n\n /**\n * This function is used to determine if \"down\" events should be propagated\n * to other interactions or should be stopped.\n * @param {boolean} handled Was the event handled by the interaction?\n * @return {boolean} Should the `down` event be stopped?\n */\n stopDown(handled) {\n return handled;\n }\n\n /**\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @private\n */\n updateTrackedPointers_(mapBrowserEvent) {\n if (mapBrowserEvent.activePointers) {\n this.targetPointers = mapBrowserEvent.activePointers;\n }\n }\n}\n\n/**\n * @param {Array} pointerEvents List of events.\n * @return {{clientX: number, clientY: number}} Centroid pixel.\n */\nexport function centroid(pointerEvents) {\n const length = pointerEvents.length;\n let clientX = 0;\n let clientY = 0;\n for (let i = 0; i < length; i++) {\n clientX += pointerEvents[i].clientX;\n clientY += pointerEvents[i].clientY;\n }\n return {clientX: clientX / length, clientY: clientY / length};\n}\n\nexport default PointerInteraction;\n","/**\n * @module ol/events/condition\n */\nimport MapBrowserEventType from '../MapBrowserEventType.js';\nimport {FALSE, TRUE} from '../functions.js';\nimport {MAC, WEBKIT} from '../has.js';\nimport {assert} from '../asserts.js';\n\n/**\n * A function that takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * `{boolean}`. If the condition is met, true should be returned.\n *\n * @typedef {function(this: ?, import(\"../MapBrowserEvent.js\").default): boolean} Condition\n */\n\n/**\n * Creates a condition function that passes when all provided conditions pass.\n * @param {...Condition} var_args Conditions to check.\n * @return {Condition} Condition function.\n */\nexport function all(var_args) {\n const conditions = arguments;\n /**\n * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n * @return {boolean} All conditions passed.\n */\n return function (event) {\n let pass = true;\n for (let i = 0, ii = conditions.length; i < ii; ++i) {\n pass = pass && conditions[i](event);\n if (!pass) {\n break;\n }\n }\n return pass;\n };\n}\n\n/**\n * Return `true` if only the alt-key is pressed, `false` otherwise (e.g. when\n * additionally the shift-key is pressed).\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if only the alt key is pressed.\n * @api\n */\nexport const altKeyOnly = function (mapBrowserEvent) {\n const originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (\n mapBrowserEvent.originalEvent\n );\n return (\n originalEvent.altKey &&\n !(originalEvent.metaKey || originalEvent.ctrlKey) &&\n !originalEvent.shiftKey\n );\n};\n\n/**\n * Return `true` if only the alt-key and shift-key is pressed, `false` otherwise\n * (e.g. when additionally the platform-modifier-key is pressed).\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if only the alt and shift keys are pressed.\n * @api\n */\nexport const altShiftKeysOnly = function (mapBrowserEvent) {\n const originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (\n mapBrowserEvent.originalEvent\n );\n return (\n originalEvent.altKey &&\n !(originalEvent.metaKey || originalEvent.ctrlKey) &&\n originalEvent.shiftKey\n );\n};\n\n/**\n * Return `true` if the map has the focus. This condition requires a map target\n * element with a `tabindex` attribute, e.g. `
`.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} event Map browser event.\n * @return {boolean} The map has the focus.\n * @api\n */\nexport const focus = function (event) {\n const targetElement = event.map.getTargetElement();\n const activeElement = event.map.getOwnerDocument().activeElement;\n return targetElement.contains(activeElement);\n};\n\n/**\n * Return `true` if the map has the focus or no 'tabindex' attribute set.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} event Map browser event.\n * @return {boolean} The map container has the focus or no 'tabindex' attribute.\n */\nexport const focusWithTabindex = function (event) {\n return event.map.getTargetElement().hasAttribute('tabindex')\n ? focus(event)\n : true;\n};\n\n/**\n * Return always true.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True.\n * @api\n */\nexport const always = TRUE;\n\n/**\n * Return `true` if the event is a `click` event, `false` otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event is a map `click` event.\n * @api\n */\nexport const click = function (mapBrowserEvent) {\n return mapBrowserEvent.type == MapBrowserEventType.CLICK;\n};\n\n/**\n * Return `true` if the event has an \"action\"-producing mouse button.\n *\n * By definition, this includes left-click on windows/linux, and left-click\n * without the ctrl key on Macs.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} The result.\n */\nexport const mouseActionButton = function (mapBrowserEvent) {\n const originalEvent = /** @type {MouseEvent} */ (\n mapBrowserEvent.originalEvent\n );\n return originalEvent.button == 0 && !(WEBKIT && MAC && originalEvent.ctrlKey);\n};\n\n/**\n * Return always false.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} False.\n * @api\n */\nexport const never = FALSE;\n\n/**\n * Return `true` if the browser event is a `pointermove` event, `false`\n * otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the browser event is a `pointermove` event.\n * @api\n */\nexport const pointerMove = function (mapBrowserEvent) {\n return mapBrowserEvent.type == 'pointermove';\n};\n\n/**\n * Return `true` if the event is a map `singleclick` event, `false` otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event is a map `singleclick` event.\n * @api\n */\nexport const singleClick = function (mapBrowserEvent) {\n return mapBrowserEvent.type == MapBrowserEventType.SINGLECLICK;\n};\n\n/**\n * Return `true` if the event is a map `dblclick` event, `false` otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event is a map `dblclick` event.\n * @api\n */\nexport const doubleClick = function (mapBrowserEvent) {\n return mapBrowserEvent.type == MapBrowserEventType.DBLCLICK;\n};\n\n/**\n * Return `true` if no modifier key (alt-, shift- or platform-modifier-key) is\n * pressed.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True only if there no modifier keys are pressed.\n * @api\n */\nexport const noModifierKeys = function (mapBrowserEvent) {\n const originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (\n mapBrowserEvent.originalEvent\n );\n return (\n !originalEvent.altKey &&\n !(originalEvent.metaKey || originalEvent.ctrlKey) &&\n !originalEvent.shiftKey\n );\n};\n\n/**\n * Return `true` if only the platform-modifier-key (the meta-key on Mac,\n * ctrl-key otherwise) is pressed, `false` otherwise (e.g. when additionally\n * the shift-key is pressed).\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if only the platform modifier key is pressed.\n * @api\n */\nexport const platformModifierKeyOnly = function (mapBrowserEvent) {\n const originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (\n mapBrowserEvent.originalEvent\n );\n return (\n !originalEvent.altKey &&\n (MAC ? originalEvent.metaKey : originalEvent.ctrlKey) &&\n !originalEvent.shiftKey\n );\n};\n\n/**\n * Return `true` if the platform-modifier-key (the meta-key on Mac,\n * ctrl-key otherwise) is pressed.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the platform modifier key is pressed.\n * @api\n */\nexport const platformModifierKey = function (mapBrowserEvent) {\n const originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (\n mapBrowserEvent.originalEvent\n );\n return MAC ? originalEvent.metaKey : originalEvent.ctrlKey;\n};\n\n/**\n * Return `true` if only the shift-key is pressed, `false` otherwise (e.g. when\n * additionally the alt-key is pressed).\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if only the shift key is pressed.\n * @api\n */\nexport const shiftKeyOnly = function (mapBrowserEvent) {\n const originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (\n mapBrowserEvent.originalEvent\n );\n return (\n !originalEvent.altKey &&\n !(originalEvent.metaKey || originalEvent.ctrlKey) &&\n originalEvent.shiftKey\n );\n};\n\n/**\n * Return `true` if the target element is not editable, i.e. not an `input`,\n * `select`, or `textarea` element and no `contenteditable` attribute is\n * set or inherited, `false` otherwise.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True only if the target element is not editable.\n * @api\n */\nexport const targetNotEditable = function (mapBrowserEvent) {\n const originalEvent = /** @type {KeyboardEvent|MouseEvent|TouchEvent} */ (\n mapBrowserEvent.originalEvent\n );\n const tagName = /** @type {Element} */ (originalEvent.target).tagName;\n return (\n tagName !== 'INPUT' &&\n tagName !== 'SELECT' &&\n tagName !== 'TEXTAREA' &&\n // `isContentEditable` is only available on `HTMLElement`, but it may also be a\n // different type like `SVGElement`.\n // @ts-ignore\n !originalEvent.target.isContentEditable\n );\n};\n\n/**\n * Return `true` if the event originates from a mouse device.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event originates from a mouse device.\n * @api\n */\nexport const mouseOnly = function (mapBrowserEvent) {\n const pointerEvent = /** @type {import(\"../MapBrowserEvent\").default} */ (\n mapBrowserEvent\n ).originalEvent;\n assert(\n pointerEvent !== undefined,\n 'mapBrowserEvent must originate from a pointer event',\n );\n // see https://www.w3.org/TR/pointerevents/#widl-PointerEvent-pointerType\n return pointerEvent.pointerType == 'mouse';\n};\n\n/**\n * Return `true` if the event originates from a touchable device.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event originates from a touchable device.\n * @api\n */\nexport const touchOnly = function (mapBrowserEvent) {\n const pointerEvt = /** @type {import(\"../MapBrowserEvent\").default} */ (\n mapBrowserEvent\n ).originalEvent;\n assert(\n pointerEvt !== undefined,\n 'mapBrowserEvent must originate from a pointer event',\n );\n // see https://www.w3.org/TR/pointerevents/#widl-PointerEvent-pointerType\n return pointerEvt.pointerType === 'touch';\n};\n\n/**\n * Return `true` if the event originates from a digital pen.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event originates from a digital pen.\n * @api\n */\nexport const penOnly = function (mapBrowserEvent) {\n const pointerEvt = /** @type {import(\"../MapBrowserEvent\").default} */ (\n mapBrowserEvent\n ).originalEvent;\n assert(\n pointerEvt !== undefined,\n 'mapBrowserEvent must originate from a pointer event',\n );\n // see https://www.w3.org/TR/pointerevents/#widl-PointerEvent-pointerType\n return pointerEvt.pointerType === 'pen';\n};\n\n/**\n * Return `true` if the event originates from a primary pointer in\n * contact with the surface or if the left mouse button is pressed.\n * See https://www.w3.org/TR/pointerevents/#button-states.\n *\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} True if the event originates from a primary pointer.\n * @api\n */\nexport const primaryAction = function (mapBrowserEvent) {\n const pointerEvent = /** @type {import(\"../MapBrowserEvent\").default} */ (\n mapBrowserEvent\n ).originalEvent;\n assert(\n pointerEvent !== undefined,\n 'mapBrowserEvent must originate from a pointer event',\n );\n return pointerEvent.isPrimary && pointerEvent.button === 0;\n};\n","/**\n * @module ol/interaction/DragPan\n */\nimport PointerInteraction, {\n centroid as centroidFromPointers,\n} from './Pointer.js';\nimport {FALSE} from '../functions.js';\nimport {\n all,\n focusWithTabindex,\n noModifierKeys,\n primaryAction,\n} from '../events/condition.js';\nimport {easeOut} from '../easing.js';\nimport {\n rotate as rotateCoordinate,\n scale as scaleCoordinate,\n} from '../coordinate.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a boolean\n * to indicate whether that event should be handled.\n * Default is {@link module:ol/events/condition.noModifierKeys} and {@link module:ol/events/condition.primaryAction}.\n * @property {boolean} [onFocusOnly=false] When the map's target has a `tabindex` attribute set,\n * the interaction will only handle events when the map has the focus.\n * @property {import(\"../Kinetic.js\").default} [kinetic] Kinetic inertia to apply to the pan.\n */\n\n/**\n * @classdesc\n * Allows the user to pan the map by dragging the map.\n * @api\n */\nclass DragPan extends PointerInteraction {\n /**\n * @param {Options} [options] Options.\n */\n constructor(options) {\n super({\n stopDown: FALSE,\n });\n\n options = options ? options : {};\n\n /**\n * @private\n * @type {import(\"../Kinetic.js\").default|undefined}\n */\n this.kinetic_ = options.kinetic;\n\n /**\n * @type {import(\"../pixel.js\").Pixel}\n */\n this.lastCentroid = null;\n\n /**\n * @type {number}\n * @private\n */\n this.lastPointersCount_;\n\n /**\n * @type {boolean}\n * @private\n */\n this.panning_ = false;\n\n const condition = options.condition\n ? options.condition\n : all(noModifierKeys, primaryAction);\n\n /**\n * @private\n * @type {import(\"../events/condition.js\").Condition}\n */\n this.condition_ = options.onFocusOnly\n ? all(focusWithTabindex, condition)\n : condition;\n\n /**\n * @private\n * @type {boolean}\n */\n this.noKinetic_ = false;\n }\n\n /**\n * Handle pointer drag events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @override\n */\n handleDragEvent(mapBrowserEvent) {\n const map = mapBrowserEvent.map;\n if (!this.panning_) {\n this.panning_ = true;\n map.getView().beginInteraction();\n }\n const targetPointers = this.targetPointers;\n const centroid = map.getEventPixel(centroidFromPointers(targetPointers));\n if (targetPointers.length == this.lastPointersCount_) {\n if (this.kinetic_) {\n this.kinetic_.update(centroid[0], centroid[1]);\n }\n if (this.lastCentroid) {\n const delta = [\n this.lastCentroid[0] - centroid[0],\n centroid[1] - this.lastCentroid[1],\n ];\n const map = mapBrowserEvent.map;\n const view = map.getView();\n scaleCoordinate(delta, view.getResolution());\n rotateCoordinate(delta, view.getRotation());\n view.adjustCenterInternal(delta);\n }\n } else if (this.kinetic_) {\n // reset so we don't overestimate the kinetic energy after\n // after one finger down, tiny drag, second finger down\n this.kinetic_.begin();\n }\n this.lastCentroid = centroid;\n this.lastPointersCount_ = targetPointers.length;\n mapBrowserEvent.originalEvent.preventDefault();\n }\n\n /**\n * Handle pointer up events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n * @override\n */\n handleUpEvent(mapBrowserEvent) {\n const map = mapBrowserEvent.map;\n const view = map.getView();\n if (this.targetPointers.length === 0) {\n if (!this.noKinetic_ && this.kinetic_ && this.kinetic_.end()) {\n const distance = this.kinetic_.getDistance();\n const angle = this.kinetic_.getAngle();\n const center = view.getCenterInternal();\n const centerpx = map.getPixelFromCoordinateInternal(center);\n const dest = map.getCoordinateFromPixelInternal([\n centerpx[0] - distance * Math.cos(angle),\n centerpx[1] - distance * Math.sin(angle),\n ]);\n view.animateInternal({\n center: view.getConstrainedCenter(dest),\n duration: 500,\n easing: easeOut,\n });\n }\n if (this.panning_) {\n this.panning_ = false;\n view.endInteraction();\n }\n return false;\n }\n if (this.kinetic_) {\n // reset so we don't overestimate the kinetic energy after\n // after one finger up, tiny drag, second finger up\n this.kinetic_.begin();\n }\n this.lastCentroid = null;\n return true;\n }\n\n /**\n * Handle pointer down events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n * @override\n */\n handleDownEvent(mapBrowserEvent) {\n if (this.targetPointers.length > 0 && this.condition_(mapBrowserEvent)) {\n const map = mapBrowserEvent.map;\n const view = map.getView();\n this.lastCentroid = null;\n // stop any current animation\n if (view.getAnimating()) {\n view.cancelAnimations();\n }\n if (this.kinetic_) {\n this.kinetic_.begin();\n }\n // No kinetic as soon as more than one pointer on the screen is\n // detected. This is to prevent nasty pans after pinch.\n this.noKinetic_ = this.targetPointers.length > 1;\n return true;\n }\n return false;\n }\n}\n\nexport default DragPan;\n","/**\n * @module ol/interaction/DragRotate\n */\nimport PointerInteraction from './Pointer.js';\nimport {FALSE} from '../functions.js';\nimport {\n altShiftKeysOnly,\n mouseActionButton,\n mouseOnly,\n} from '../events/condition.js';\nimport {disable} from '../rotationconstraint.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that takes a\n * {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a boolean\n * to indicate whether that event should be handled.\n * Default is {@link module:ol/events/condition.altShiftKeysOnly}.\n * @property {number} [duration=250] Animation duration in milliseconds.\n */\n\n/**\n * @classdesc\n * Allows the user to rotate the map by clicking and dragging on the map,\n * normally combined with a {@link module:ol/events/condition} that limits\n * it to when the alt and shift keys are held down.\n *\n * This interaction is only supported for mouse devices.\n * @api\n */\nclass DragRotate extends PointerInteraction {\n /**\n * @param {Options} [options] Options.\n */\n constructor(options) {\n options = options ? options : {};\n\n super({\n stopDown: FALSE,\n });\n\n /**\n * @private\n * @type {import(\"../events/condition.js\").Condition}\n */\n this.condition_ = options.condition ? options.condition : altShiftKeysOnly;\n\n /**\n * @private\n * @type {number|undefined}\n */\n this.lastAngle_ = undefined;\n\n /**\n * @private\n * @type {number}\n */\n this.duration_ = options.duration !== undefined ? options.duration : 250;\n }\n\n /**\n * Handle pointer drag events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @override\n */\n handleDragEvent(mapBrowserEvent) {\n if (!mouseOnly(mapBrowserEvent)) {\n return;\n }\n\n const map = mapBrowserEvent.map;\n const view = map.getView();\n if (view.getConstraints().rotation === disable) {\n return;\n }\n const size = map.getSize();\n const offset = mapBrowserEvent.pixel;\n const theta = Math.atan2(size[1] / 2 - offset[1], offset[0] - size[0] / 2);\n if (this.lastAngle_ !== undefined) {\n const delta = theta - this.lastAngle_;\n view.adjustRotationInternal(-delta);\n }\n this.lastAngle_ = theta;\n }\n\n /**\n * Handle pointer up events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n * @override\n */\n handleUpEvent(mapBrowserEvent) {\n if (!mouseOnly(mapBrowserEvent)) {\n return true;\n }\n\n const map = mapBrowserEvent.map;\n const view = map.getView();\n view.endInteraction(this.duration_);\n return false;\n }\n\n /**\n * Handle pointer down events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n * @override\n */\n handleDownEvent(mapBrowserEvent) {\n if (!mouseOnly(mapBrowserEvent)) {\n return false;\n }\n\n if (\n mouseActionButton(mapBrowserEvent) &&\n this.condition_(mapBrowserEvent)\n ) {\n const map = mapBrowserEvent.map;\n map.getView().beginInteraction();\n this.lastAngle_ = undefined;\n return true;\n }\n return false;\n }\n}\n\nexport default DragRotate;\n","/**\n * @module ol/render/Box\n */\n\nimport Disposable from '../Disposable.js';\nimport Polygon from '../geom/Polygon.js';\n\nclass RenderBox extends Disposable {\n /**\n * @param {string} className CSS class name.\n */\n constructor(className) {\n super();\n\n /**\n * @type {import(\"../geom/Polygon.js\").default}\n * @private\n */\n this.geometry_ = null;\n\n /**\n * @type {HTMLDivElement}\n * @private\n */\n this.element_ = document.createElement('div');\n this.element_.style.position = 'absolute';\n this.element_.style.pointerEvents = 'auto';\n this.element_.className = 'ol-box ' + className;\n\n /**\n * @private\n * @type {import(\"../Map.js\").default|null}\n */\n this.map_ = null;\n\n /**\n * @private\n * @type {import(\"../pixel.js\").Pixel}\n */\n this.startPixel_ = null;\n\n /**\n * @private\n * @type {import(\"../pixel.js\").Pixel}\n */\n this.endPixel_ = null;\n }\n\n /**\n * Clean up.\n * @override\n */\n disposeInternal() {\n this.setMap(null);\n }\n\n /**\n * @private\n */\n render_() {\n const startPixel = this.startPixel_;\n const endPixel = this.endPixel_;\n const px = 'px';\n const style = this.element_.style;\n style.left = Math.min(startPixel[0], endPixel[0]) + px;\n style.top = Math.min(startPixel[1], endPixel[1]) + px;\n style.width = Math.abs(endPixel[0] - startPixel[0]) + px;\n style.height = Math.abs(endPixel[1] - startPixel[1]) + px;\n }\n\n /**\n * @param {import(\"../Map.js\").default|null} map Map.\n */\n setMap(map) {\n if (this.map_) {\n this.map_.getOverlayContainer().removeChild(this.element_);\n const style = this.element_.style;\n style.left = 'inherit';\n style.top = 'inherit';\n style.width = 'inherit';\n style.height = 'inherit';\n }\n this.map_ = map;\n if (this.map_) {\n this.map_.getOverlayContainer().appendChild(this.element_);\n }\n }\n\n /**\n * @param {import(\"../pixel.js\").Pixel} startPixel Start pixel.\n * @param {import(\"../pixel.js\").Pixel} endPixel End pixel.\n */\n setPixels(startPixel, endPixel) {\n this.startPixel_ = startPixel;\n this.endPixel_ = endPixel;\n this.createOrUpdateGeometry();\n this.render_();\n }\n\n /**\n * Creates or updates the cached geometry.\n */\n createOrUpdateGeometry() {\n if (!this.map_) {\n return;\n }\n\n const startPixel = this.startPixel_;\n const endPixel = this.endPixel_;\n const pixels = [\n startPixel,\n [startPixel[0], endPixel[1]],\n endPixel,\n [endPixel[0], startPixel[1]],\n ];\n const coordinates = pixels.map(\n this.map_.getCoordinateFromPixelInternal,\n this.map_,\n );\n // close the polygon\n coordinates[4] = coordinates[0].slice();\n if (!this.geometry_) {\n this.geometry_ = new Polygon([coordinates]);\n } else {\n this.geometry_.setCoordinates([coordinates]);\n }\n }\n\n /**\n * @return {import(\"../geom/Polygon.js\").default} Geometry.\n */\n getGeometry() {\n return this.geometry_;\n }\n}\n\nexport default RenderBox;\n","/**\n * @module ol/interaction/DragBox\n */\n// FIXME draw drag box\nimport Event from '../events/Event.js';\nimport PointerInteraction from './Pointer.js';\nimport RenderBox from '../render/Box.js';\nimport {mouseActionButton} from '../events/condition.js';\n\n/**\n * A function that takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and two\n * {@link module:ol/pixel~Pixel}s and returns a `{boolean}`. If the condition is met,\n * true should be returned.\n * @typedef {function(this: ?, import(\"../MapBrowserEvent.js\").default, import(\"../pixel.js\").Pixel, import(\"../pixel.js\").Pixel):boolean} EndCondition\n */\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-dragbox'] CSS class name for styling the box.\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a boolean\n * to indicate whether that event should be handled.\n * Default is {@link ol/events/condition~mouseActionButton}.\n * @property {number} [minArea=64] The minimum area of the box in pixel, this value is used by the default\n * `boxEndCondition` function.\n * @property {EndCondition} [boxEndCondition] A function that takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and two\n * {@link module:ol/pixel~Pixel}s to indicate whether a `boxend` event should be fired.\n * Default is `true` if the area of the box is bigger than the `minArea` option.\n * @property {function(this:DragBox, import(\"../MapBrowserEvent.js\").default):void} [onBoxEnd] Code to execute just\n * before `boxend` is fired.\n */\n\n/**\n * @enum {string}\n */\nconst DragBoxEventType = {\n /**\n * Triggered upon drag box start.\n * @event DragBoxEvent#boxstart\n * @api\n */\n BOXSTART: 'boxstart',\n\n /**\n * Triggered on drag when box is active.\n * @event DragBoxEvent#boxdrag\n * @api\n */\n BOXDRAG: 'boxdrag',\n\n /**\n * Triggered upon drag box end.\n * @event DragBoxEvent#boxend\n * @api\n */\n BOXEND: 'boxend',\n\n /**\n * Triggered upon drag box canceled.\n * @event DragBoxEvent#boxcancel\n * @api\n */\n BOXCANCEL: 'boxcancel',\n};\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/interaction/DragBox~DragBox} instances are instances of\n * this type.\n */\nexport class DragBoxEvent extends Event {\n /**\n * @param {string} type The event type.\n * @param {import(\"../coordinate.js\").Coordinate} coordinate The event coordinate.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Originating event.\n */\n constructor(type, coordinate, mapBrowserEvent) {\n super(type);\n\n /**\n * The coordinate of the drag event.\n * @const\n * @type {import(\"../coordinate.js\").Coordinate}\n * @api\n */\n this.coordinate = coordinate;\n\n /**\n * @const\n * @type {import(\"../MapBrowserEvent.js\").default}\n * @api\n */\n this.mapBrowserEvent = mapBrowserEvent;\n }\n}\n\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature &\n * import(\"../Observable\").OnSignature &\n * import(\"../Observable\").OnSignature<'boxcancel'|'boxdrag'|'boxend'|'boxstart', DragBoxEvent, Return> &\n * import(\"../Observable\").CombinedOnSignature} DragBoxOnSignature\n */\n\n/**\n * @classdesc\n * Allows the user to draw a vector box by clicking and dragging on the map,\n * normally combined with a {@link module:ol/events/condition} that limits\n * it to when the shift or other key is held down. This is used, for example,\n * for zooming to a specific area of the map\n * (see {@link module:ol/interaction/DragZoom~DragZoom} and\n * {@link module:ol/interaction/DragRotateAndZoom~DragRotateAndZoom}).\n *\n * @fires DragBoxEvent\n * @api\n */\nclass DragBox extends PointerInteraction {\n /**\n * @param {Options} [options] Options.\n */\n constructor(options) {\n super();\n\n /***\n * @type {DragBoxOnSignature}\n */\n this.on;\n\n /***\n * @type {DragBoxOnSignature}\n */\n this.once;\n\n /***\n * @type {DragBoxOnSignature}\n */\n this.un;\n\n options = options ? options : {};\n\n /**\n * @type {import(\"../render/Box.js\").default}\n * @private\n */\n this.box_ = new RenderBox(options.className || 'ol-dragbox');\n\n /**\n * @type {number}\n * @private\n */\n this.minArea_ = options.minArea !== undefined ? options.minArea : 64;\n\n if (options.onBoxEnd) {\n this.onBoxEnd = options.onBoxEnd;\n }\n\n /**\n * @type {import(\"../pixel.js\").Pixel}\n * @private\n */\n this.startPixel_ = null;\n\n /**\n * @private\n * @type {import(\"../events/condition.js\").Condition}\n */\n this.condition_ = options.condition ? options.condition : mouseActionButton;\n\n /**\n * @private\n * @type {EndCondition}\n */\n this.boxEndCondition_ = options.boxEndCondition\n ? options.boxEndCondition\n : this.defaultBoxEndCondition;\n }\n\n /**\n * The default condition for determining whether the boxend event\n * should fire.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent The originating MapBrowserEvent\n * leading to the box end.\n * @param {import(\"../pixel.js\").Pixel} startPixel The starting pixel of the box.\n * @param {import(\"../pixel.js\").Pixel} endPixel The end pixel of the box.\n * @return {boolean} Whether or not the boxend condition should be fired.\n */\n defaultBoxEndCondition(mapBrowserEvent, startPixel, endPixel) {\n const width = endPixel[0] - startPixel[0];\n const height = endPixel[1] - startPixel[1];\n return width * width + height * height >= this.minArea_;\n }\n\n /**\n * Returns geometry of last drawn box.\n * @return {import(\"../geom/Polygon.js\").default} Geometry.\n * @api\n */\n getGeometry() {\n return this.box_.getGeometry();\n }\n\n /**\n * Handle pointer drag events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @override\n */\n handleDragEvent(mapBrowserEvent) {\n if (!this.startPixel_) {\n return;\n }\n\n this.box_.setPixels(this.startPixel_, mapBrowserEvent.pixel);\n\n this.dispatchEvent(\n new DragBoxEvent(\n DragBoxEventType.BOXDRAG,\n mapBrowserEvent.coordinate,\n mapBrowserEvent,\n ),\n );\n }\n\n /**\n * Handle pointer up events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n * @override\n */\n handleUpEvent(mapBrowserEvent) {\n if (!this.startPixel_) {\n return false;\n }\n\n this.box_.setMap(null);\n\n const completeBox = this.boxEndCondition_(\n mapBrowserEvent,\n this.startPixel_,\n mapBrowserEvent.pixel,\n );\n if (completeBox) {\n this.onBoxEnd(mapBrowserEvent);\n }\n this.dispatchEvent(\n new DragBoxEvent(\n completeBox ? DragBoxEventType.BOXEND : DragBoxEventType.BOXCANCEL,\n mapBrowserEvent.coordinate,\n mapBrowserEvent,\n ),\n );\n return false;\n }\n\n /**\n * Handle pointer down events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n * @override\n */\n handleDownEvent(mapBrowserEvent) {\n if (this.condition_(mapBrowserEvent)) {\n this.startPixel_ = mapBrowserEvent.pixel;\n this.box_.setMap(mapBrowserEvent.map);\n this.box_.setPixels(this.startPixel_, this.startPixel_);\n this.dispatchEvent(\n new DragBoxEvent(\n DragBoxEventType.BOXSTART,\n mapBrowserEvent.coordinate,\n mapBrowserEvent,\n ),\n );\n return true;\n }\n return false;\n }\n\n /**\n * Function to execute just before `onboxend` is fired\n * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n */\n onBoxEnd(event) {}\n\n /**\n * Activate or deactivate the interaction.\n * @param {boolean} active Active.\n * @observable\n * @api\n * @override\n */\n setActive(active) {\n if (!active) {\n this.box_.setMap(null);\n if (this.startPixel_) {\n this.dispatchEvent(\n new DragBoxEvent(DragBoxEventType.BOXCANCEL, this.startPixel_, null),\n );\n this.startPixel_ = null;\n }\n }\n\n super.setActive(active);\n }\n}\n\nexport default DragBox;\n","/**\n * @module ol/interaction/DragZoom\n */\nimport DragBox from './DragBox.js';\nimport {easeOut} from '../easing.js';\nimport {shiftKeyOnly} from '../events/condition.js';\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-dragzoom'] CSS class name for styling the\n * box.\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether that event should be handled.\n * Default is {@link module:ol/events/condition.shiftKeyOnly}.\n * @property {number} [duration=200] Animation duration in milliseconds.\n * @property {boolean} [out=false] Use interaction for zooming out.\n * @property {number} [minArea=64] The minimum area of the box in pixel, this value is used by the parent default\n * `boxEndCondition` function.\n */\n\n/**\n * @classdesc\n * Allows the user to zoom the map by clicking and dragging on the map,\n * normally combined with a {@link module:ol/events/condition} that limits\n * it to when a key, shift by default, is held down.\n *\n * To change the style of the box, use CSS and the `.ol-dragzoom` selector, or\n * your custom one configured with `className`.\n * @api\n */\nclass DragZoom extends DragBox {\n /**\n * @param {Options} [options] Options.\n */\n constructor(options) {\n options = options ? options : {};\n\n const condition = options.condition ? options.condition : shiftKeyOnly;\n\n super({\n condition: condition,\n className: options.className || 'ol-dragzoom',\n minArea: options.minArea,\n });\n\n /**\n * @private\n * @type {number}\n */\n this.duration_ = options.duration !== undefined ? options.duration : 200;\n\n /**\n * @private\n * @type {boolean}\n */\n this.out_ = options.out !== undefined ? options.out : false;\n }\n\n /**\n * Function to execute just before `onboxend` is fired\n * @param {import(\"../MapBrowserEvent.js\").default} event Event.\n * @override\n */\n onBoxEnd(event) {\n const map = this.getMap();\n const view = /** @type {!import(\"../View.js\").default} */ (map.getView());\n let geometry = this.getGeometry();\n\n if (this.out_) {\n const rotatedExtent = view.rotatedExtentForGeometry(geometry);\n const resolution = view.getResolutionForExtentInternal(rotatedExtent);\n const factor = view.getResolution() / resolution;\n geometry = geometry.clone();\n geometry.scale(factor * factor);\n }\n\n view.fitInternal(geometry, {\n duration: this.duration_,\n easing: easeOut,\n });\n }\n}\n\nexport default DragZoom;\n","/**\n * @module ol/events/Key\n */\n\n/**\n * @enum {string}\n * @const\n */\nexport default {\n LEFT: 'ArrowLeft',\n UP: 'ArrowUp',\n RIGHT: 'ArrowRight',\n DOWN: 'ArrowDown',\n};\n","/**\n * @module ol/interaction/KeyboardPan\n */\nimport EventType from '../events/EventType.js';\nimport Interaction, {pan} from './Interaction.js';\nimport Key from '../events/Key.js';\nimport {noModifierKeys, targetNotEditable} from '../events/condition.js';\nimport {rotate as rotateCoordinate} from '../coordinate.js';\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether that event should be handled. Default is\n * {@link module:ol/events/condition.noModifierKeys} and\n * {@link module:ol/events/condition.targetNotEditable}.\n * @property {number} [duration=100] Animation duration in milliseconds.\n * @property {number} [pixelDelta=128] The amount of pixels to pan on each key\n * press.\n */\n\n/**\n * @classdesc\n * Allows the user to pan the map using keyboard arrows.\n * Note that, although this interaction is by default included in maps,\n * the keys can only be used when browser focus is on the element to which\n * the keyboard events are attached. By default, this is the map div,\n * though you can change this with the `keyboardEventTarget` in\n * {@link module:ol/Map~Map}. `document` never loses focus but, for any other\n * element, focus will have to be on, and returned to, this element if the keys\n * are to function.\n * See also {@link module:ol/interaction/KeyboardZoom~KeyboardZoom}.\n * @api\n */\nclass KeyboardPan extends Interaction {\n /**\n * @param {Options} [options] Options.\n */\n constructor(options) {\n super();\n\n options = options || {};\n\n /**\n * @private\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Browser event.\n * @return {boolean} Combined condition result.\n */\n this.defaultCondition_ = function (mapBrowserEvent) {\n return (\n noModifierKeys(mapBrowserEvent) && targetNotEditable(mapBrowserEvent)\n );\n };\n\n /**\n * @private\n * @type {import(\"../events/condition.js\").Condition}\n */\n this.condition_ =\n options.condition !== undefined\n ? options.condition\n : this.defaultCondition_;\n\n /**\n * @private\n * @type {number}\n */\n this.duration_ = options.duration !== undefined ? options.duration : 100;\n\n /**\n * @private\n * @type {number}\n */\n this.pixelDelta_ =\n options.pixelDelta !== undefined ? options.pixelDelta : 128;\n }\n\n /**\n * Handles the {@link module:ol/MapBrowserEvent~MapBrowserEvent map browser event} if it was a\n * `KeyEvent`, and decides the direction to pan to (if an arrow key was\n * pressed).\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} `false` to stop event propagation.\n * @override\n */\n handleEvent(mapBrowserEvent) {\n let stopEvent = false;\n if (mapBrowserEvent.type == EventType.KEYDOWN) {\n const keyEvent = /** @type {KeyboardEvent} */ (\n mapBrowserEvent.originalEvent\n );\n const key = keyEvent.key;\n if (\n this.condition_(mapBrowserEvent) &&\n (key == Key.DOWN ||\n key == Key.LEFT ||\n key == Key.RIGHT ||\n key == Key.UP)\n ) {\n const map = mapBrowserEvent.map;\n const view = map.getView();\n const mapUnitsDelta = view.getResolution() * this.pixelDelta_;\n let deltaX = 0,\n deltaY = 0;\n if (key == Key.DOWN) {\n deltaY = -mapUnitsDelta;\n } else if (key == Key.LEFT) {\n deltaX = -mapUnitsDelta;\n } else if (key == Key.RIGHT) {\n deltaX = mapUnitsDelta;\n } else {\n deltaY = mapUnitsDelta;\n }\n const delta = [deltaX, deltaY];\n rotateCoordinate(delta, view.getRotation());\n pan(view, delta, this.duration_);\n keyEvent.preventDefault();\n stopEvent = true;\n }\n }\n return !stopEvent;\n }\n}\n\nexport default KeyboardPan;\n","/**\n * @module ol/interaction/KeyboardZoom\n */\nimport EventType from '../events/EventType.js';\nimport Interaction, {zoomByDelta} from './Interaction.js';\nimport {platformModifierKey, targetNotEditable} from '../events/condition.js';\n\n/**\n * @typedef {Object} Options\n * @property {number} [duration=100] Animation duration in milliseconds.\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether that event should be handled. The default condition is\n * that {@link module:ol/events/condition.targetNotEditable} is fulfilled and that\n * the platform modifier key isn't pressed\n * (!{@link module:ol/events/condition.platformModifierKey}).\n * @property {number} [delta=1] The zoom level delta on each key press.\n */\n\n/**\n * @classdesc\n * Allows the user to zoom the map using keyboard + and -.\n * Note that, although this interaction is by default included in maps,\n * the keys can only be used when browser focus is on the element to which\n * the keyboard events are attached. By default, this is the map div,\n * though you can change this with the `keyboardEventTarget` in\n * {@link module:ol/Map~Map}. `document` never loses focus but, for any other\n * element, focus will have to be on, and returned to, this element if the keys\n * are to function.\n * See also {@link module:ol/interaction/KeyboardPan~KeyboardPan}.\n * @api\n */\nclass KeyboardZoom extends Interaction {\n /**\n * @param {Options} [options] Options.\n */\n constructor(options) {\n super();\n\n options = options ? options : {};\n\n /**\n * @private\n * @type {import(\"../events/condition.js\").Condition}\n */\n this.condition_ = options.condition\n ? options.condition\n : function (mapBrowserEvent) {\n return (\n !platformModifierKey(mapBrowserEvent) &&\n targetNotEditable(mapBrowserEvent)\n );\n };\n\n /**\n * @private\n * @type {number}\n */\n this.delta_ = options.delta ? options.delta : 1;\n\n /**\n * @private\n * @type {number}\n */\n this.duration_ = options.duration !== undefined ? options.duration : 100;\n }\n\n /**\n * Handles the {@link module:ol/MapBrowserEvent~MapBrowserEvent map browser event} if it was a\n * `KeyEvent`, and decides whether to zoom in or out (depending on whether the\n * key pressed was '+' or '-').\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} `false` to stop event propagation.\n * @override\n */\n handleEvent(mapBrowserEvent) {\n let stopEvent = false;\n if (\n mapBrowserEvent.type == EventType.KEYDOWN ||\n mapBrowserEvent.type == EventType.KEYPRESS\n ) {\n const keyEvent = /** @type {KeyboardEvent} */ (\n mapBrowserEvent.originalEvent\n );\n const key = keyEvent.key;\n if (this.condition_(mapBrowserEvent) && (key === '+' || key === '-')) {\n const map = mapBrowserEvent.map;\n const delta = key === '+' ? this.delta_ : -this.delta_;\n const view = map.getView();\n zoomByDelta(view, delta, undefined, this.duration_);\n keyEvent.preventDefault();\n stopEvent = true;\n }\n }\n return !stopEvent;\n }\n}\n\nexport default KeyboardZoom;\n","/**\n * @module ol/Kinetic\n */\n\n/**\n * @classdesc\n * Implementation of inertial deceleration for map movement.\n *\n * @api\n */\nclass Kinetic {\n /**\n * @param {number} decay Rate of decay (must be negative).\n * @param {number} minVelocity Minimum velocity (pixels/millisecond).\n * @param {number} delay Delay to consider to calculate the kinetic\n * initial values (milliseconds).\n */\n constructor(decay, minVelocity, delay) {\n /**\n * @private\n * @type {number}\n */\n this.decay_ = decay;\n\n /**\n * @private\n * @type {number}\n */\n this.minVelocity_ = minVelocity;\n\n /**\n * @private\n * @type {number}\n */\n this.delay_ = delay;\n\n /**\n * @private\n * @type {Array}\n */\n this.points_ = [];\n\n /**\n * @private\n * @type {number}\n */\n this.angle_ = 0;\n\n /**\n * @private\n * @type {number}\n */\n this.initialVelocity_ = 0;\n }\n\n /**\n * FIXME empty description for jsdoc\n */\n begin() {\n this.points_.length = 0;\n this.angle_ = 0;\n this.initialVelocity_ = 0;\n }\n\n /**\n * @param {number} x X.\n * @param {number} y Y.\n */\n update(x, y) {\n this.points_.push(x, y, Date.now());\n }\n\n /**\n * @return {boolean} Whether we should do kinetic animation.\n */\n end() {\n if (this.points_.length < 6) {\n // at least 2 points are required (i.e. there must be at least 6 elements\n // in the array)\n return false;\n }\n const delay = Date.now() - this.delay_;\n const lastIndex = this.points_.length - 3;\n if (this.points_[lastIndex + 2] < delay) {\n // the last tracked point is too old, which means that the user stopped\n // panning before releasing the map\n return false;\n }\n\n // get the first point which still falls into the delay time\n let firstIndex = lastIndex - 3;\n while (firstIndex > 0 && this.points_[firstIndex + 2] > delay) {\n firstIndex -= 3;\n }\n\n const duration = this.points_[lastIndex + 2] - this.points_[firstIndex + 2];\n // we don't want a duration of 0 (divide by zero)\n // we also make sure the user panned for a duration of at least one frame\n // (1/60s) to compute sane displacement values\n if (duration < 1000 / 60) {\n return false;\n }\n\n const dx = this.points_[lastIndex] - this.points_[firstIndex];\n const dy = this.points_[lastIndex + 1] - this.points_[firstIndex + 1];\n this.angle_ = Math.atan2(dy, dx);\n this.initialVelocity_ = Math.sqrt(dx * dx + dy * dy) / duration;\n return this.initialVelocity_ > this.minVelocity_;\n }\n\n /**\n * @return {number} Total distance travelled (pixels).\n */\n getDistance() {\n return (this.minVelocity_ - this.initialVelocity_) / this.decay_;\n }\n\n /**\n * @return {number} Angle of the kinetic panning animation (radians).\n */\n getAngle() {\n return this.angle_;\n }\n}\n\nexport default Kinetic;\n","/**\n * @module ol/interaction/MouseWheelZoom\n */\nimport EventType from '../events/EventType.js';\nimport Interaction, {zoomByDelta} from './Interaction.js';\nimport {DEVICE_PIXEL_RATIO, FIREFOX} from '../has.js';\nimport {all, always, focusWithTabindex} from '../events/condition.js';\nimport {clamp} from '../math.js';\n\n/**\n * @typedef {'trackpad' | 'wheel'} Mode\n */\n\n/**\n * @typedef {Object} Options\n * @property {import(\"../events/condition.js\").Condition} [condition] A function that\n * takes a {@link module:ol/MapBrowserEvent~MapBrowserEvent} and returns a\n * boolean to indicate whether that event should be handled. Default is\n * {@link module:ol/events/condition.always}.\n * @property {boolean} [onFocusOnly=false] When the map's target has a `tabindex` attribute set,\n * the interaction will only handle events when the map has the focus.\n * @property {number} [maxDelta=1] Maximum mouse wheel delta.\n * @property {number} [duration=250] Animation duration in milliseconds.\n * @property {number} [timeout=80] Mouse wheel timeout duration in milliseconds.\n * @property {boolean} [useAnchor=true] Enable zooming using the mouse's\n * location as the anchor. When set to `false`, zooming in and out will zoom to\n * the center of the screen instead of zooming on the mouse's location.\n * @property {boolean} [constrainResolution=false] If true, the mouse wheel zoom\n * event will always animate to the closest zoom level after an interaction;\n * false means intermediary zoom levels are allowed.\n */\n\n/**\n * @classdesc\n * Allows the user to zoom the map by scrolling the mouse wheel.\n * @api\n */\nclass MouseWheelZoom extends Interaction {\n /**\n * @param {Options} [options] Options.\n */\n constructor(options) {\n options = options ? options : {};\n\n super(\n /** @type {import(\"./Interaction.js\").InteractionOptions} */ (options),\n );\n\n /**\n * @private\n * @type {number}\n */\n this.totalDelta_ = 0;\n\n /**\n * @private\n * @type {number}\n */\n this.lastDelta_ = 0;\n\n /**\n * @private\n * @type {number}\n */\n this.maxDelta_ = options.maxDelta !== undefined ? options.maxDelta : 1;\n\n /**\n * @private\n * @type {number}\n */\n this.duration_ = options.duration !== undefined ? options.duration : 250;\n\n /**\n * @private\n * @type {number}\n */\n this.timeout_ = options.timeout !== undefined ? options.timeout : 80;\n\n /**\n * @private\n * @type {boolean}\n */\n this.useAnchor_ =\n options.useAnchor !== undefined ? options.useAnchor : true;\n\n /**\n * @private\n * @type {boolean}\n */\n this.constrainResolution_ =\n options.constrainResolution !== undefined\n ? options.constrainResolution\n : false;\n\n const condition = options.condition ? options.condition : always;\n\n /**\n * @private\n * @type {import(\"../events/condition.js\").Condition}\n */\n this.condition_ = options.onFocusOnly\n ? all(focusWithTabindex, condition)\n : condition;\n\n /**\n * @private\n * @type {?import(\"../coordinate.js\").Coordinate}\n */\n this.lastAnchor_ = null;\n\n /**\n * @private\n * @type {number|undefined}\n */\n this.startTime_ = undefined;\n\n /**\n * @private\n * @type {ReturnType}\n */\n this.timeoutId_;\n\n /**\n * @private\n * @type {Mode|undefined}\n */\n this.mode_ = undefined;\n\n /**\n * Trackpad events separated by this delay will be considered separate\n * interactions.\n * @private\n * @type {number}\n */\n this.trackpadEventGap_ = 400;\n\n /**\n * @private\n * @type {ReturnType}\n */\n this.trackpadTimeoutId_;\n\n /**\n * The number of delta values per zoom level\n * @private\n * @type {number}\n */\n this.deltaPerZoom_ = 300;\n }\n\n /**\n * @private\n */\n endInteraction_() {\n this.trackpadTimeoutId_ = undefined;\n const map = this.getMap();\n if (!map) {\n return;\n }\n const view = map.getView();\n view.endInteraction(\n undefined,\n this.lastDelta_ ? (this.lastDelta_ > 0 ? 1 : -1) : 0,\n this.lastAnchor_,\n );\n }\n\n /**\n * Handles the {@link module:ol/MapBrowserEvent~MapBrowserEvent map browser event} (if it was a mousewheel-event) and eventually\n * zooms the map.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Map browser event.\n * @return {boolean} `false` to stop event propagation.\n * @override\n */\n handleEvent(mapBrowserEvent) {\n if (!this.condition_(mapBrowserEvent)) {\n return true;\n }\n const type = mapBrowserEvent.type;\n if (type !== EventType.WHEEL) {\n return true;\n }\n\n const map = mapBrowserEvent.map;\n const wheelEvent = /** @type {WheelEvent} */ (\n mapBrowserEvent.originalEvent\n );\n wheelEvent.preventDefault();\n\n if (this.useAnchor_) {\n this.lastAnchor_ = mapBrowserEvent.coordinate;\n }\n\n // Delta normalisation inspired by\n // https://github.com/mapbox/mapbox-gl-js/blob/001c7b9/js/ui/handler/scroll_zoom.js\n let delta;\n if (mapBrowserEvent.type == EventType.WHEEL) {\n delta = wheelEvent.deltaY;\n if (FIREFOX && wheelEvent.deltaMode === WheelEvent.DOM_DELTA_PIXEL) {\n delta /= DEVICE_PIXEL_RATIO;\n }\n if (wheelEvent.deltaMode === WheelEvent.DOM_DELTA_LINE) {\n delta *= 40;\n }\n }\n\n if (delta === 0) {\n return false;\n }\n this.lastDelta_ = delta;\n\n const now = Date.now();\n\n if (this.startTime_ === undefined) {\n this.startTime_ = now;\n }\n\n if (!this.mode_ || now - this.startTime_ > this.trackpadEventGap_) {\n this.mode_ = Math.abs(delta) < 4 ? 'trackpad' : 'wheel';\n }\n\n const view = map.getView();\n if (\n this.mode_ === 'trackpad' &&\n !(view.getConstrainResolution() || this.constrainResolution_)\n ) {\n if (this.trackpadTimeoutId_) {\n clearTimeout(this.trackpadTimeoutId_);\n } else {\n if (view.getAnimating()) {\n view.cancelAnimations();\n }\n view.beginInteraction();\n }\n this.trackpadTimeoutId_ = setTimeout(\n this.endInteraction_.bind(this),\n this.timeout_,\n );\n view.adjustZoom(-delta / this.deltaPerZoom_, this.lastAnchor_);\n this.startTime_ = now;\n return false;\n }\n\n this.totalDelta_ += delta;\n\n const timeLeft = Math.max(this.timeout_ - (now - this.startTime_), 0);\n\n clearTimeout(this.timeoutId_);\n this.timeoutId_ = setTimeout(\n this.handleWheelZoom_.bind(this, map),\n timeLeft,\n );\n\n return false;\n }\n\n /**\n * @private\n * @param {import(\"../Map.js\").default} map Map.\n */\n handleWheelZoom_(map) {\n const view = map.getView();\n if (view.getAnimating()) {\n view.cancelAnimations();\n }\n let delta =\n -clamp(\n this.totalDelta_,\n -this.maxDelta_ * this.deltaPerZoom_,\n this.maxDelta_ * this.deltaPerZoom_,\n ) / this.deltaPerZoom_;\n if (view.getConstrainResolution() || this.constrainResolution_) {\n // view has a zoom constraint, zoom by 1\n delta = delta ? (delta > 0 ? 1 : -1) : 0;\n }\n zoomByDelta(view, delta, this.lastAnchor_, this.duration_);\n\n this.mode_ = undefined;\n this.totalDelta_ = 0;\n this.lastAnchor_ = null;\n this.startTime_ = undefined;\n this.timeoutId_ = undefined;\n }\n\n /**\n * Enable or disable using the mouse's location as an anchor when zooming\n * @param {boolean} useAnchor true to zoom to the mouse's location, false\n * to zoom to the center of the map\n * @api\n */\n setMouseAnchor(useAnchor) {\n this.useAnchor_ = useAnchor;\n if (!useAnchor) {\n this.lastAnchor_ = null;\n }\n }\n}\n\nexport default MouseWheelZoom;\n","/**\n * @module ol/interaction/PinchRotate\n */\nimport PointerInteraction, {\n centroid as centroidFromPointers,\n} from './Pointer.js';\nimport {FALSE} from '../functions.js';\nimport {disable} from '../rotationconstraint.js';\n\n/**\n * @typedef {Object} Options\n * @property {number} [duration=250] The duration of the animation in\n * milliseconds.\n * @property {number} [threshold=0.3] Minimal angle in radians to start a rotation.\n */\n\n/**\n * @classdesc\n * Allows the user to rotate the map by twisting with two fingers\n * on a touch screen.\n * @api\n */\nclass PinchRotate extends PointerInteraction {\n /**\n * @param {Options} [options] Options.\n */\n constructor(options) {\n options = options ? options : {};\n\n const pointerOptions = /** @type {import(\"./Pointer.js\").Options} */ (\n options\n );\n\n if (!pointerOptions.stopDown) {\n pointerOptions.stopDown = FALSE;\n }\n\n super(pointerOptions);\n\n /**\n * @private\n * @type {import(\"../coordinate.js\").Coordinate}\n */\n this.anchor_ = null;\n\n /**\n * @private\n * @type {number|undefined}\n */\n this.lastAngle_ = undefined;\n\n /**\n * @private\n * @type {boolean}\n */\n this.rotating_ = false;\n\n /**\n * @private\n * @type {number}\n */\n this.rotationDelta_ = 0.0;\n\n /**\n * @private\n * @type {number}\n */\n this.threshold_ = options.threshold !== undefined ? options.threshold : 0.3;\n\n /**\n * @private\n * @type {number}\n */\n this.duration_ = options.duration !== undefined ? options.duration : 250;\n }\n\n /**\n * Handle pointer drag events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @override\n */\n handleDragEvent(mapBrowserEvent) {\n let rotationDelta = 0.0;\n\n const touch0 = this.targetPointers[0];\n const touch1 = this.targetPointers[1];\n\n // angle between touches\n const angle = Math.atan2(\n touch1.clientY - touch0.clientY,\n touch1.clientX - touch0.clientX,\n );\n\n if (this.lastAngle_ !== undefined) {\n const delta = angle - this.lastAngle_;\n this.rotationDelta_ += delta;\n if (!this.rotating_ && Math.abs(this.rotationDelta_) > this.threshold_) {\n this.rotating_ = true;\n }\n rotationDelta = delta;\n }\n this.lastAngle_ = angle;\n\n const map = mapBrowserEvent.map;\n const view = map.getView();\n if (view.getConstraints().rotation === disable) {\n return;\n }\n\n // rotate anchor point.\n // FIXME: should be the intersection point between the lines:\n // touch0,touch1 and previousTouch0,previousTouch1\n this.anchor_ = map.getCoordinateFromPixelInternal(\n map.getEventPixel(centroidFromPointers(this.targetPointers)),\n );\n\n // rotate\n if (this.rotating_) {\n map.render();\n view.adjustRotationInternal(rotationDelta, this.anchor_);\n }\n }\n\n /**\n * Handle pointer up events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n * @override\n */\n handleUpEvent(mapBrowserEvent) {\n if (this.targetPointers.length < 2) {\n const map = mapBrowserEvent.map;\n const view = map.getView();\n view.endInteraction(this.duration_);\n return false;\n }\n return true;\n }\n\n /**\n * Handle pointer down events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n * @override\n */\n handleDownEvent(mapBrowserEvent) {\n if (this.targetPointers.length >= 2) {\n const map = mapBrowserEvent.map;\n this.anchor_ = null;\n this.lastAngle_ = undefined;\n this.rotating_ = false;\n this.rotationDelta_ = 0.0;\n if (!this.handlingDownUpSequence) {\n map.getView().beginInteraction();\n }\n return true;\n }\n return false;\n }\n}\n\nexport default PinchRotate;\n","/**\n * @module ol/interaction/PinchZoom\n */\nimport PointerInteraction, {\n centroid as centroidFromPointers,\n} from './Pointer.js';\nimport {FALSE} from '../functions.js';\n\n/**\n * @typedef {Object} Options\n * @property {number} [duration=400] Animation duration in milliseconds.\n */\n\n/**\n * @classdesc\n * Allows the user to zoom the map by pinching with two fingers\n * on a touch screen.\n * @api\n */\nclass PinchZoom extends PointerInteraction {\n /**\n * @param {Options} [options] Options.\n */\n constructor(options) {\n options = options ? options : {};\n\n const pointerOptions = /** @type {import(\"./Pointer.js\").Options} */ (\n options\n );\n\n if (!pointerOptions.stopDown) {\n pointerOptions.stopDown = FALSE;\n }\n\n super(pointerOptions);\n\n /**\n * @private\n * @type {import(\"../coordinate.js\").Coordinate}\n */\n this.anchor_ = null;\n\n /**\n * @private\n * @type {number}\n */\n this.duration_ = options.duration !== undefined ? options.duration : 400;\n\n /**\n * @private\n * @type {number|undefined}\n */\n this.lastDistance_ = undefined;\n\n /**\n * @private\n * @type {number}\n */\n this.lastScaleDelta_ = 1;\n }\n\n /**\n * Handle pointer drag events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @override\n */\n handleDragEvent(mapBrowserEvent) {\n let scaleDelta = 1.0;\n\n const touch0 = this.targetPointers[0];\n const touch1 = this.targetPointers[1];\n const dx = touch0.clientX - touch1.clientX;\n const dy = touch0.clientY - touch1.clientY;\n\n // distance between touches\n const distance = Math.sqrt(dx * dx + dy * dy);\n\n if (this.lastDistance_ !== undefined) {\n scaleDelta = this.lastDistance_ / distance;\n }\n this.lastDistance_ = distance;\n\n const map = mapBrowserEvent.map;\n const view = map.getView();\n\n if (scaleDelta != 1.0) {\n this.lastScaleDelta_ = scaleDelta;\n }\n\n // scale anchor point.\n this.anchor_ = map.getCoordinateFromPixelInternal(\n map.getEventPixel(centroidFromPointers(this.targetPointers)),\n );\n\n // scale, bypass the resolution constraint\n map.render();\n view.adjustResolutionInternal(scaleDelta, this.anchor_);\n }\n\n /**\n * Handle pointer up events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n * @override\n */\n handleUpEvent(mapBrowserEvent) {\n if (this.targetPointers.length < 2) {\n const map = mapBrowserEvent.map;\n const view = map.getView();\n const direction = this.lastScaleDelta_ > 1 ? 1 : -1;\n view.endInteraction(this.duration_, direction);\n return false;\n }\n return true;\n }\n\n /**\n * Handle pointer down events.\n * @param {import(\"../MapBrowserEvent.js\").default} mapBrowserEvent Event.\n * @return {boolean} If the event was consumed.\n * @override\n */\n handleDownEvent(mapBrowserEvent) {\n if (this.targetPointers.length >= 2) {\n const map = mapBrowserEvent.map;\n this.anchor_ = null;\n this.lastDistance_ = undefined;\n this.lastScaleDelta_ = 1;\n if (!this.handlingDownUpSequence) {\n map.getView().beginInteraction();\n }\n return true;\n }\n return false;\n }\n}\n\nexport default PinchZoom;\n","/**\n * @module ol/Map\n */\nimport BaseObject from './Object.js';\nimport Collection from './Collection.js';\nimport CollectionEventType from './CollectionEventType.js';\nimport CompositeMapRenderer from './renderer/Composite.js';\nimport EventType from './events/EventType.js';\nimport Layer from './layer/Layer.js';\nimport LayerGroup, {GroupEvent} from './layer/Group.js';\nimport MapBrowserEvent from './MapBrowserEvent.js';\nimport MapBrowserEventHandler from './MapBrowserEventHandler.js';\nimport MapBrowserEventType from './MapBrowserEventType.js';\nimport MapEvent from './MapEvent.js';\nimport MapEventType from './MapEventType.js';\nimport MapProperty from './MapProperty.js';\nimport ObjectEventType from './ObjectEventType.js';\nimport PointerEventType from './pointer/EventType.js';\nimport RenderEventType from './render/EventType.js';\nimport TileQueue, {getTilePriority} from './TileQueue.js';\nimport View from './View.js';\nimport ViewHint from './ViewHint.js';\nimport {DEVICE_PIXEL_RATIO, PASSIVE_EVENT_LISTENERS} from './has.js';\nimport {TRUE} from './functions.js';\nimport {\n apply as applyTransform,\n create as createTransform,\n} from './transform.js';\nimport {assert} from './asserts.js';\nimport {\n clone,\n createOrUpdateEmpty,\n equals as equalsExtent,\n getForViewAndSize,\n isEmpty,\n} from './extent.js';\nimport {defaults as defaultControls} from './control/defaults.js';\nimport {defaults as defaultInteractions} from './interaction/defaults.js';\nimport {equals} from './array.js';\nimport {fromUserCoordinate, toUserCoordinate} from './proj.js';\nimport {getUid} from './util.js';\nimport {hasArea} from './size.js';\nimport {listen, unlistenByKey} from './events.js';\nimport {warn} from './console.js';\n\n/**\n * State of the current frame. Only `pixelRatio`, `time` and `viewState` should\n * be used in applications.\n * @typedef {Object} FrameState\n * @property {number} pixelRatio The pixel ratio of the frame.\n * @property {number} time The time when rendering of the frame was requested.\n * @property {import(\"./View.js\").State} viewState The state of the current view.\n * @property {boolean} animate Animate.\n * @property {import(\"./transform.js\").Transform} coordinateToPixelTransform CoordinateToPixelTransform.\n * @property {Object>|null} declutter\n * Declutter trees by declutter group.\n * When null, no decluttering is needed because no layers have decluttering enabled.\n * @property {null|import(\"./extent.js\").Extent} extent Extent (in view projection coordinates).\n * @property {import(\"./extent.js\").Extent} [nextExtent] Next extent during an animation series.\n * @property {number} index Index.\n * @property {Array} layerStatesArray LayerStatesArray.\n * @property {number} layerIndex LayerIndex.\n * @property {import(\"./transform.js\").Transform} pixelToCoordinateTransform PixelToCoordinateTransform.\n * @property {Array} postRenderFunctions PostRenderFunctions.\n * @property {import(\"./size.js\").Size} size Size.\n * @property {TileQueue} tileQueue TileQueue.\n * @property {!Object>} usedTiles UsedTiles.\n * @property {Array} viewHints ViewHints.\n * @property {!Object>} wantedTiles WantedTiles.\n * @property {string} mapId The id of the map.\n * @property {Object} renderTargets Identifiers of previously rendered elements.\n */\n\n/**\n * @typedef {function(Map, ?FrameState): any} PostRenderFunction\n */\n\n/**\n * @typedef {Object} AtPixelOptions\n * @property {undefined|function(import(\"./layer/Layer.js\").default): boolean} [layerFilter] Layer filter\n * function. The filter function will receive one argument, the\n * {@link module:ol/layer/Layer~Layer layer-candidate} and it should return a boolean value.\n * Only layers which are visible and for which this function returns `true`\n * will be tested for features. By default, all visible layers will be tested.\n * @property {number} [hitTolerance=0] Hit-detection tolerance in css pixels. Pixels\n * inside the radius around the given position will be checked for features.\n * @property {boolean} [checkWrapped=true] Check-Wrapped Will check for wrapped geometries inside the range of\n * +/- 1 world width. Works only if a projection is used that can be wrapped.\n */\n\n/**\n * @typedef {Object} MapOptionsInternal\n * @property {Collection} [controls] Controls.\n * @property {Collection} [interactions] Interactions.\n * @property {HTMLElement|Document} keyboardEventTarget KeyboardEventTarget.\n * @property {Collection} overlays Overlays.\n * @property {Object} values Values.\n */\n\n/**\n * @typedef {import(\"./ObjectEventType\").Types|'change:layergroup'|'change:size'|'change:target'|'change:view'} MapObjectEventTypes\n */\n\n/***\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature &\n * import(\"./Observable\").OnSignature &\n * import(\"./Observable\").OnSignature &\n * import(\"./Observable\").OnSignature &\n * import(\"./Observable\").OnSignature &\n * import(\"./Observable\").CombinedOnSignature} MapEventHandler\n */\n\n/**\n * Object literal with config options for the map.\n * @typedef {Object} MapOptions\n * @property {Collection|Array} [controls]\n * Controls initially added to the map. If not specified,\n * {@link module:ol/control/defaults.defaults} is used.\n * @property {number} [pixelRatio=window.devicePixelRatio] The ratio between\n * physical pixels and device-independent pixels (dips) on the device.\n * @property {Collection|Array} [interactions]\n * Interactions that are initially added to the map. If not specified,\n * {@link module:ol/interaction/defaults.defaults} is used.\n * @property {HTMLElement|Document|string} [keyboardEventTarget] The element to\n * listen to keyboard events on. This determines when the `KeyboardPan` and\n * `KeyboardZoom` interactions trigger. For example, if this option is set to\n * `document` the keyboard interactions will always trigger. If this option is\n * not specified, the element the library listens to keyboard events on is the\n * map target (i.e. the user-provided div for the map). If this is not\n * `document`, the target element needs to be focused for key events to be\n * emitted, requiring that the target element has a `tabindex` attribute.\n * @property {Array|Collection|LayerGroup} [layers]\n * Layers. If this is not defined, a map with no layers will be rendered. Note\n * that layers are rendered in the order supplied, so if you want, for example,\n * a vector layer to appear on top of a tile layer, it must come after the tile\n * layer.\n * @property {number} [maxTilesLoading=16] Maximum number tiles to load\n * simultaneously.\n * @property {number} [moveTolerance=1] The minimum distance in pixels the\n * cursor must move to be detected as a map move event instead of a click.\n * Increasing this value can make it easier to click on the map.\n * @property {Collection|Array} [overlays]\n * Overlays initially added to the map. By default, no overlays are added.\n * @property {HTMLElement|string} [target] The container for the map, either the\n * element itself or the `id` of the element. If not specified at construction\n * time, {@link module:ol/Map~Map#setTarget} must be called for the map to be\n * rendered. If passed by element, the container can be in a secondary document.\n * **Note:** CSS `transform` support for the target element is limited to `scale`.\n * @property {View|Promise} [view] The map's view. No layer sources will be\n * fetched unless this is specified at construction time or through\n * {@link module:ol/Map~Map#setView}.\n */\n\n/**\n * @param {import(\"./layer/Base.js\").default} layer Layer.\n */\nfunction removeLayerMapProperty(layer) {\n if (layer instanceof Layer) {\n layer.setMapInternal(null);\n return;\n }\n if (layer instanceof LayerGroup) {\n layer.getLayers().forEach(removeLayerMapProperty);\n }\n}\n\n/**\n * @param {import(\"./layer/Base.js\").default} layer Layer.\n * @param {Map} map Map.\n */\nfunction setLayerMapProperty(layer, map) {\n if (layer instanceof Layer) {\n layer.setMapInternal(map);\n return;\n }\n if (layer instanceof LayerGroup) {\n const layers = layer.getLayers().getArray();\n for (let i = 0, ii = layers.length; i < ii; ++i) {\n setLayerMapProperty(layers[i], map);\n }\n }\n}\n\n/**\n * @classdesc\n * The map is the core component of OpenLayers. For a map to render, a view,\n * one or more layers, and a target container are needed:\n *\n * import Map from 'ol/Map.js';\n * import View from 'ol/View.js';\n * import TileLayer from 'ol/layer/Tile.js';\n * import OSM from 'ol/source/OSM.js';\n *\n * const map = new Map({\n * view: new View({\n * center: [0, 0],\n * zoom: 1,\n * }),\n * layers: [\n * new TileLayer({\n * source: new OSM(),\n * }),\n * ],\n * target: 'map',\n * });\n *\n * The above snippet creates a map using a {@link module:ol/layer/Tile~TileLayer} to\n * display {@link module:ol/source/OSM~OSM} OSM data and render it to a DOM\n * element with the id `map`.\n *\n * The constructor places a viewport container (with CSS class name\n * `ol-viewport`) in the target element (see `getViewport()`), and then two\n * further elements within the viewport: one with CSS class name\n * `ol-overlaycontainer-stopevent` for controls and some overlays, and one with\n * CSS class name `ol-overlaycontainer` for other overlays (see the `stopEvent`\n * option of {@link module:ol/Overlay~Overlay} for the difference). The map\n * itself is placed in a further element within the viewport.\n *\n * Layers are stored as a {@link module:ol/Collection~Collection} in\n * layerGroups. A top-level group is provided by the library. This is what is\n * accessed by `getLayerGroup` and `setLayerGroup`. Layers entered in the\n * options are added to this group, and `addLayer` and `removeLayer` change the\n * layer collection in the group. `getLayers` is a convenience function for\n * `getLayerGroup().getLayers()`. Note that {@link module:ol/layer/Group~LayerGroup}\n * is a subclass of {@link module:ol/layer/Base~BaseLayer}, so layers entered in the\n * options or added with `addLayer` can be groups, which can contain further\n * groups, and so on.\n *\n * @fires import(\"./MapBrowserEvent.js\").MapBrowserEvent\n * @fires import(\"./MapEvent.js\").MapEvent\n * @fires import(\"./render/Event.js\").default#precompose\n * @fires import(\"./render/Event.js\").default#postcompose\n * @fires import(\"./render/Event.js\").default#rendercomplete\n * @api\n */\nclass Map extends BaseObject {\n /**\n * @param {MapOptions} [options] Map options.\n */\n constructor(options) {\n super();\n\n options = options || {};\n\n /***\n * @type {MapEventHandler}\n */\n this.on;\n\n /***\n * @type {MapEventHandler}\n */\n this.once;\n\n /***\n * @type {MapEventHandler}\n */\n this.un;\n\n const optionsInternal = createOptionsInternal(options);\n\n /**\n * @private\n * @type {boolean}\n */\n this.renderComplete_ = false;\n\n /**\n * @private\n * @type {boolean}\n */\n this.loaded_ = true;\n\n /** @private */\n this.boundHandleBrowserEvent_ = this.handleBrowserEvent.bind(this);\n\n /**\n * @type {number}\n * @private\n */\n this.maxTilesLoading_ =\n options.maxTilesLoading !== undefined ? options.maxTilesLoading : 16;\n\n /**\n * @private\n * @type {number}\n */\n this.pixelRatio_ =\n options.pixelRatio !== undefined\n ? options.pixelRatio\n : DEVICE_PIXEL_RATIO;\n\n /**\n * @private\n * @type {ReturnType}\n */\n this.postRenderTimeoutHandle_;\n\n /**\n * @private\n * @type {number|undefined}\n */\n this.animationDelayKey_;\n\n /**\n * @private\n */\n this.animationDelay_ = this.animationDelay_.bind(this);\n\n /**\n * @private\n * @type {import(\"./transform.js\").Transform}\n */\n this.coordinateToPixelTransform_ = createTransform();\n\n /**\n * @private\n * @type {import(\"./transform.js\").Transform}\n */\n this.pixelToCoordinateTransform_ = createTransform();\n\n /**\n * @private\n * @type {number}\n */\n this.frameIndex_ = 0;\n\n /**\n * @private\n * @type {?FrameState}\n */\n this.frameState_ = null;\n\n /**\n * The extent at the previous 'moveend' event.\n * @private\n * @type {import(\"./extent.js\").Extent}\n */\n this.previousExtent_ = null;\n\n /**\n * @private\n * @type {?import(\"./events.js\").EventsKey}\n */\n this.viewPropertyListenerKey_ = null;\n\n /**\n * @private\n * @type {?import(\"./events.js\").EventsKey}\n */\n this.viewChangeListenerKey_ = null;\n\n /**\n * @private\n * @type {?Array}\n */\n this.layerGroupPropertyListenerKeys_ = null;\n\n /**\n * @private\n * @type {!HTMLElement}\n */\n this.viewport_ = document.createElement('div');\n this.viewport_.className =\n 'ol-viewport' + ('ontouchstart' in window ? ' ol-touch' : '');\n this.viewport_.style.position = 'relative';\n this.viewport_.style.overflow = 'hidden';\n this.viewport_.style.width = '100%';\n this.viewport_.style.height = '100%';\n\n /**\n * @private\n * @type {!HTMLElement}\n */\n this.overlayContainer_ = document.createElement('div');\n this.overlayContainer_.style.position = 'absolute';\n this.overlayContainer_.style.zIndex = '0';\n this.overlayContainer_.style.width = '100%';\n this.overlayContainer_.style.height = '100%';\n this.overlayContainer_.style.pointerEvents = 'none';\n this.overlayContainer_.className = 'ol-overlaycontainer';\n this.viewport_.appendChild(this.overlayContainer_);\n\n /**\n * @private\n * @type {!HTMLElement}\n */\n this.overlayContainerStopEvent_ = document.createElement('div');\n this.overlayContainerStopEvent_.style.position = 'absolute';\n this.overlayContainerStopEvent_.style.zIndex = '0';\n this.overlayContainerStopEvent_.style.width = '100%';\n this.overlayContainerStopEvent_.style.height = '100%';\n this.overlayContainerStopEvent_.style.pointerEvents = 'none';\n this.overlayContainerStopEvent_.className = 'ol-overlaycontainer-stopevent';\n this.viewport_.appendChild(this.overlayContainerStopEvent_);\n\n /**\n * @private\n * @type {MapBrowserEventHandler}\n */\n this.mapBrowserEventHandler_ = null;\n\n /**\n * @private\n * @type {number}\n */\n this.moveTolerance_ = options.moveTolerance;\n\n /**\n * @private\n * @type {HTMLElement|Document}\n */\n this.keyboardEventTarget_ = optionsInternal.keyboardEventTarget;\n\n /**\n * @private\n * @type {?Array}\n */\n this.targetChangeHandlerKeys_ = null;\n\n /**\n * @private\n * @type {HTMLElement|null}\n */\n this.targetElement_ = null;\n\n /**\n * @private\n * @type {ResizeObserver}\n */\n this.resizeObserver_ = new ResizeObserver(() => this.updateSize());\n\n /**\n * @type {Collection}\n * @protected\n */\n this.controls = optionsInternal.controls || defaultControls();\n\n /**\n * @type {Collection}\n * @protected\n */\n this.interactions =\n optionsInternal.interactions ||\n defaultInteractions({\n onFocusOnly: true,\n });\n\n /**\n * @type {Collection}\n * @private\n */\n this.overlays_ = optionsInternal.overlays;\n\n /**\n * A lookup of overlays by id.\n * @private\n * @type {Object}\n */\n this.overlayIdIndex_ = {};\n\n /**\n * @type {import(\"./renderer/Map.js\").default|null}\n * @private\n */\n this.renderer_ = null;\n\n /**\n * @private\n * @type {!Array}\n */\n this.postRenderFunctions_ = [];\n\n /**\n * @private\n * @type {TileQueue}\n */\n this.tileQueue_ = new TileQueue(\n this.getTilePriority.bind(this),\n this.handleTileChange_.bind(this),\n );\n\n this.addChangeListener(\n MapProperty.LAYERGROUP,\n this.handleLayerGroupChanged_,\n );\n this.addChangeListener(MapProperty.VIEW, this.handleViewChanged_);\n this.addChangeListener(MapProperty.SIZE, this.handleSizeChanged_);\n this.addChangeListener(MapProperty.TARGET, this.handleTargetChanged_);\n\n // setProperties will trigger the rendering of the map if the map\n // is \"defined\" already.\n this.setProperties(optionsInternal.values);\n\n const map = this;\n if (options.view && !(options.view instanceof View)) {\n options.view.then(function (viewOptions) {\n map.setView(new View(viewOptions));\n });\n }\n\n this.controls.addEventListener(\n CollectionEventType.ADD,\n /**\n * @param {import(\"./Collection.js\").CollectionEvent} event CollectionEvent\n */\n (event) => {\n event.element.setMap(this);\n },\n );\n\n this.controls.addEventListener(\n CollectionEventType.REMOVE,\n /**\n * @param {import(\"./Collection.js\").CollectionEvent} event CollectionEvent.\n */\n (event) => {\n event.element.setMap(null);\n },\n );\n\n this.interactions.addEventListener(\n CollectionEventType.ADD,\n /**\n * @param {import(\"./Collection.js\").CollectionEvent} event CollectionEvent.\n */\n (event) => {\n event.element.setMap(this);\n },\n );\n\n this.interactions.addEventListener(\n CollectionEventType.REMOVE,\n /**\n * @param {import(\"./Collection.js\").CollectionEvent} event CollectionEvent.\n */\n (event) => {\n event.element.setMap(null);\n },\n );\n\n this.overlays_.addEventListener(\n CollectionEventType.ADD,\n /**\n * @param {import(\"./Collection.js\").CollectionEvent} event CollectionEvent.\n */\n (event) => {\n this.addOverlayInternal_(event.element);\n },\n );\n\n this.overlays_.addEventListener(\n CollectionEventType.REMOVE,\n /**\n * @param {import(\"./Collection.js\").CollectionEvent} event CollectionEvent.\n */\n (event) => {\n const id = event.element.getId();\n if (id !== undefined) {\n delete this.overlayIdIndex_[id.toString()];\n }\n event.element.setMap(null);\n },\n );\n\n this.controls.forEach(\n /**\n * @param {import(\"./control/Control.js\").default} control Control.\n */\n (control) => {\n control.setMap(this);\n },\n );\n\n this.interactions.forEach(\n /**\n * @param {import(\"./interaction/Interaction.js\").default} interaction Interaction.\n */\n (interaction) => {\n interaction.setMap(this);\n },\n );\n\n this.overlays_.forEach(this.addOverlayInternal_.bind(this));\n }\n\n /**\n * Add the given control to the map.\n * @param {import(\"./control/Control.js\").default} control Control.\n * @api\n */\n addControl(control) {\n this.getControls().push(control);\n }\n\n /**\n * Add the given interaction to the map. If you want to add an interaction\n * at another point of the collection use `getInteractions()` and the methods\n * available on {@link module:ol/Collection~Collection}. This can be used to\n * stop the event propagation from the handleEvent function. The interactions\n * get to handle the events in the reverse order of this collection.\n * @param {import(\"./interaction/Interaction.js\").default} interaction Interaction to add.\n * @api\n */\n addInteraction(interaction) {\n this.getInteractions().push(interaction);\n }\n\n /**\n * Adds the given layer to the top of this map. If you want to add a layer\n * elsewhere in the stack, use `getLayers()` and the methods available on\n * {@link module:ol/Collection~Collection}.\n * @param {import(\"./layer/Base.js\").default} layer Layer.\n * @api\n */\n addLayer(layer) {\n const layers = this.getLayerGroup().getLayers();\n layers.push(layer);\n }\n\n /**\n * @param {import(\"./layer/Group.js\").GroupEvent} event The layer add event.\n * @private\n */\n handleLayerAdd_(event) {\n setLayerMapProperty(event.layer, this);\n }\n\n /**\n * Add the given overlay to the map.\n * @param {import(\"./Overlay.js\").default} overlay Overlay.\n * @api\n */\n addOverlay(overlay) {\n this.getOverlays().push(overlay);\n }\n\n /**\n * This deals with map's overlay collection changes.\n * @param {import(\"./Overlay.js\").default} overlay Overlay.\n * @private\n */\n addOverlayInternal_(overlay) {\n const id = overlay.getId();\n if (id !== undefined) {\n this.overlayIdIndex_[id.toString()] = overlay;\n }\n overlay.setMap(this);\n }\n\n /**\n *\n * Clean up.\n * @override\n */\n disposeInternal() {\n this.controls.clear();\n this.interactions.clear();\n this.overlays_.clear();\n this.resizeObserver_.disconnect();\n this.setTarget(null);\n super.disposeInternal();\n }\n\n /**\n * Detect features that intersect a pixel on the viewport, and execute a\n * callback with each intersecting feature. Layers included in the detection can\n * be configured through the `layerFilter` option in `options`.\n * @param {import(\"./pixel.js\").Pixel} pixel Pixel.\n * @param {function(import(\"./Feature.js\").FeatureLike, import(\"./layer/Layer.js\").default, import(\"./geom/SimpleGeometry.js\").default): T} callback Feature callback. The callback will be\n * called with two arguments. The first argument is one\n * {@link module:ol/Feature~Feature feature} or\n * {@link module:ol/render/Feature~RenderFeature render feature} at the pixel, the second is\n * the {@link module:ol/layer/Layer~Layer layer} of the feature and will be null for\n * unmanaged layers. To stop detection, callback functions can return a\n * truthy value.\n * @param {AtPixelOptions} [options] Optional options.\n * @return {T|undefined} Callback result, i.e. the return value of last\n * callback execution, or the first truthy callback return value.\n * @template T\n * @api\n */\n forEachFeatureAtPixel(pixel, callback, options) {\n if (!this.frameState_ || !this.renderer_) {\n return;\n }\n const coordinate = this.getCoordinateFromPixelInternal(pixel);\n options = options !== undefined ? options : {};\n const hitTolerance =\n options.hitTolerance !== undefined ? options.hitTolerance : 0;\n const layerFilter =\n options.layerFilter !== undefined ? options.layerFilter : TRUE;\n const checkWrapped = options.checkWrapped !== false;\n return this.renderer_.forEachFeatureAtCoordinate(\n coordinate,\n this.frameState_,\n hitTolerance,\n checkWrapped,\n callback,\n null,\n layerFilter,\n null,\n );\n }\n\n /**\n * Get all features that intersect a pixel on the viewport.\n * @param {import(\"./pixel.js\").Pixel} pixel Pixel.\n * @param {AtPixelOptions} [options] Optional options.\n * @return {Array} The detected features or\n * an empty array if none were found.\n * @api\n */\n getFeaturesAtPixel(pixel, options) {\n const features = [];\n this.forEachFeatureAtPixel(\n pixel,\n function (feature) {\n features.push(feature);\n },\n options,\n );\n return features;\n }\n\n /**\n * Get all layers from all layer groups.\n * @return {Array} Layers.\n * @api\n */\n getAllLayers() {\n const layers = [];\n function addLayersFrom(layerGroup) {\n layerGroup.forEach(function (layer) {\n if (layer instanceof LayerGroup) {\n addLayersFrom(layer.getLayers());\n } else {\n layers.push(layer);\n }\n });\n }\n addLayersFrom(this.getLayers());\n return layers;\n }\n\n /**\n * Detect if features intersect a pixel on the viewport. Layers included in the\n * detection can be configured through the `layerFilter` option.\n * @param {import(\"./pixel.js\").Pixel} pixel Pixel.\n * @param {AtPixelOptions} [options] Optional options.\n * @return {boolean} Is there a feature at the given pixel?\n * @api\n */\n hasFeatureAtPixel(pixel, options) {\n if (!this.frameState_ || !this.renderer_) {\n return false;\n }\n const coordinate = this.getCoordinateFromPixelInternal(pixel);\n options = options !== undefined ? options : {};\n const layerFilter =\n options.layerFilter !== undefined ? options.layerFilter : TRUE;\n const hitTolerance =\n options.hitTolerance !== undefined ? options.hitTolerance : 0;\n const checkWrapped = options.checkWrapped !== false;\n return this.renderer_.hasFeatureAtCoordinate(\n coordinate,\n this.frameState_,\n hitTolerance,\n checkWrapped,\n layerFilter,\n null,\n );\n }\n\n /**\n * Returns the coordinate in user projection for a browser event.\n * @param {MouseEvent} event Event.\n * @return {import(\"./coordinate.js\").Coordinate} Coordinate.\n * @api\n */\n getEventCoordinate(event) {\n return this.getCoordinateFromPixel(this.getEventPixel(event));\n }\n\n /**\n * Returns the coordinate in view projection for a browser event.\n * @param {MouseEvent} event Event.\n * @return {import(\"./coordinate.js\").Coordinate} Coordinate.\n */\n getEventCoordinateInternal(event) {\n return this.getCoordinateFromPixelInternal(this.getEventPixel(event));\n }\n\n /**\n * Returns the map pixel position for a browser event relative to the viewport.\n * @param {UIEvent|{clientX: number, clientY: number}} event Event.\n * @return {import(\"./pixel.js\").Pixel} Pixel.\n * @api\n */\n getEventPixel(event) {\n const viewport = this.viewport_;\n const viewportPosition = viewport.getBoundingClientRect();\n const viewportSize = this.getSize();\n const scaleX = viewportPosition.width / viewportSize[0];\n const scaleY = viewportPosition.height / viewportSize[1];\n const eventPosition =\n //FIXME Are we really calling this with a TouchEvent anywhere?\n 'changedTouches' in event\n ? /** @type {TouchEvent} */ (event).changedTouches[0]\n : /** @type {MouseEvent} */ (event);\n\n return [\n (eventPosition.clientX - viewportPosition.left) / scaleX,\n (eventPosition.clientY - viewportPosition.top) / scaleY,\n ];\n }\n\n /**\n * Get the target in which this map is rendered.\n * Note that this returns what is entered as an option or in setTarget:\n * if that was an element, it returns an element; if a string, it returns that.\n * @return {HTMLElement|string|undefined} The Element or id of the Element that the\n * map is rendered in.\n * @observable\n * @api\n */\n getTarget() {\n return /** @type {HTMLElement|string|undefined} */ (\n this.get(MapProperty.TARGET)\n );\n }\n\n /**\n * Get the DOM element into which this map is rendered. In contrast to\n * `getTarget` this method always return an `Element`, or `null` if the\n * map has no target.\n * @return {HTMLElement} The element that the map is rendered in.\n * @api\n */\n getTargetElement() {\n return this.targetElement_;\n }\n\n /**\n * Get the coordinate for a given pixel. This returns a coordinate in the\n * user projection.\n * @param {import(\"./pixel.js\").Pixel} pixel Pixel position in the map viewport.\n * @return {import(\"./coordinate.js\").Coordinate} The coordinate for the pixel position.\n * @api\n */\n getCoordinateFromPixel(pixel) {\n return toUserCoordinate(\n this.getCoordinateFromPixelInternal(pixel),\n this.getView().getProjection(),\n );\n }\n\n /**\n * Get the coordinate for a given pixel. This returns a coordinate in the\n * map view projection.\n * @param {import(\"./pixel.js\").Pixel} pixel Pixel position in the map viewport.\n * @return {import(\"./coordinate.js\").Coordinate} The coordinate for the pixel position.\n */\n getCoordinateFromPixelInternal(pixel) {\n const frameState = this.frameState_;\n if (!frameState) {\n return null;\n }\n return applyTransform(frameState.pixelToCoordinateTransform, pixel.slice());\n }\n\n /**\n * Get the map controls. Modifying this collection changes the controls\n * associated with the map.\n * @return {Collection} Controls.\n * @api\n */\n getControls() {\n return this.controls;\n }\n\n /**\n * Get the map overlays. Modifying this collection changes the overlays\n * associated with the map.\n * @return {Collection} Overlays.\n * @api\n */\n getOverlays() {\n return this.overlays_;\n }\n\n /**\n * Get an overlay by its identifier (the value returned by overlay.getId()).\n * Note that the index treats string and numeric identifiers as the same. So\n * `map.getOverlayById(2)` will return an overlay with id `'2'` or `2`.\n * @param {string|number} id Overlay identifier.\n * @return {import(\"./Overlay.js\").default|null} Overlay.\n * @api\n */\n getOverlayById(id) {\n const overlay = this.overlayIdIndex_[id.toString()];\n return overlay !== undefined ? overlay : null;\n }\n\n /**\n * Get the map interactions. Modifying this collection changes the interactions\n * associated with the map.\n *\n * Interactions are used for e.g. pan, zoom and rotate.\n * @return {Collection} Interactions.\n * @api\n */\n getInteractions() {\n return this.interactions;\n }\n\n /**\n * Get the layergroup associated with this map.\n * @return {LayerGroup} A layer group containing the layers in this map.\n * @observable\n * @api\n */\n getLayerGroup() {\n return /** @type {LayerGroup} */ (this.get(MapProperty.LAYERGROUP));\n }\n\n /**\n * Clear any existing layers and add layers to the map.\n * @param {Array|Collection} layers The layers to be added to the map.\n * @api\n */\n setLayers(layers) {\n const group = this.getLayerGroup();\n if (layers instanceof Collection) {\n group.setLayers(layers);\n return;\n }\n\n const collection = group.getLayers();\n collection.clear();\n collection.extend(layers);\n }\n\n /**\n * Get the collection of layers associated with this map.\n * @return {!Collection} Layers.\n * @api\n */\n getLayers() {\n const layers = this.getLayerGroup().getLayers();\n return layers;\n }\n\n /**\n * @return {boolean} Layers have sources that are still loading.\n */\n getLoadingOrNotReady() {\n const layerStatesArray = this.getLayerGroup().getLayerStatesArray();\n for (let i = 0, ii = layerStatesArray.length; i < ii; ++i) {\n const state = layerStatesArray[i];\n if (!state.visible) {\n continue;\n }\n const renderer = state.layer.getRenderer();\n if (renderer && !renderer.ready) {\n return true;\n }\n const source = state.layer.getSource();\n if (source && source.loading) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Get the pixel for a coordinate. This takes a coordinate in the user\n * projection and returns the corresponding pixel.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate A map coordinate.\n * @return {import(\"./pixel.js\").Pixel} A pixel position in the map viewport.\n * @api\n */\n getPixelFromCoordinate(coordinate) {\n const viewCoordinate = fromUserCoordinate(\n coordinate,\n this.getView().getProjection(),\n );\n return this.getPixelFromCoordinateInternal(viewCoordinate);\n }\n\n /**\n * Get the pixel for a coordinate. This takes a coordinate in the map view\n * projection and returns the corresponding pixel.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate A map coordinate.\n * @return {import(\"./pixel.js\").Pixel} A pixel position in the map viewport.\n */\n getPixelFromCoordinateInternal(coordinate) {\n const frameState = this.frameState_;\n if (!frameState) {\n return null;\n }\n return applyTransform(\n frameState.coordinateToPixelTransform,\n coordinate.slice(0, 2),\n );\n }\n\n /**\n * Get the map renderer.\n * @return {import(\"./renderer/Map.js\").default|null} Renderer\n */\n getRenderer() {\n return this.renderer_;\n }\n\n /**\n * Get the size of this map.\n * @return {import(\"./size.js\").Size|undefined} The size in pixels of the map in the DOM.\n * @observable\n * @api\n */\n getSize() {\n return /** @type {import(\"./size.js\").Size|undefined} */ (\n this.get(MapProperty.SIZE)\n );\n }\n\n /**\n * Get the view associated with this map. A view manages properties such as\n * center and resolution.\n * @return {View} The view that controls this map.\n * @observable\n * @api\n */\n getView() {\n return /** @type {View} */ (this.get(MapProperty.VIEW));\n }\n\n /**\n * Get the element that serves as the map viewport.\n * @return {HTMLElement} Viewport.\n * @api\n */\n getViewport() {\n return this.viewport_;\n }\n\n /**\n * Get the element that serves as the container for overlays. Elements added to\n * this container will let mousedown and touchstart events through to the map,\n * so clicks and gestures on an overlay will trigger {@link module:ol/MapBrowserEvent~MapBrowserEvent}\n * events.\n * @return {!HTMLElement} The map's overlay container.\n */\n getOverlayContainer() {\n return this.overlayContainer_;\n }\n\n /**\n * Get the element that serves as a container for overlays that don't allow\n * event propagation. Elements added to this container won't let mousedown and\n * touchstart events through to the map, so clicks and gestures on an overlay\n * don't trigger any {@link module:ol/MapBrowserEvent~MapBrowserEvent}.\n * @return {!HTMLElement} The map's overlay container that stops events.\n */\n getOverlayContainerStopEvent() {\n return this.overlayContainerStopEvent_;\n }\n\n /**\n * @return {!Document} The document where the map is displayed.\n */\n getOwnerDocument() {\n const targetElement = this.getTargetElement();\n return targetElement ? targetElement.ownerDocument : document;\n }\n\n /**\n * @param {import(\"./Tile.js\").default} tile Tile.\n * @param {string} tileSourceKey Tile source key.\n * @param {import(\"./coordinate.js\").Coordinate} tileCenter Tile center.\n * @param {number} tileResolution Tile resolution.\n * @return {number} Tile priority.\n */\n getTilePriority(tile, tileSourceKey, tileCenter, tileResolution) {\n return getTilePriority(\n this.frameState_,\n tile,\n tileSourceKey,\n tileCenter,\n tileResolution,\n );\n }\n\n /**\n * @param {UIEvent} browserEvent Browser event.\n * @param {string} [type] Type.\n */\n handleBrowserEvent(browserEvent, type) {\n type = type || browserEvent.type;\n const mapBrowserEvent = new MapBrowserEvent(type, this, browserEvent);\n this.handleMapBrowserEvent(mapBrowserEvent);\n }\n\n /**\n * @param {MapBrowserEvent} mapBrowserEvent The event to handle.\n */\n handleMapBrowserEvent(mapBrowserEvent) {\n if (!this.frameState_) {\n // With no view defined, we cannot translate pixels into geographical\n // coordinates so interactions cannot be used.\n return;\n }\n const originalEvent = /** @type {PointerEvent} */ (\n mapBrowserEvent.originalEvent\n );\n const eventType = originalEvent.type;\n if (\n eventType === PointerEventType.POINTERDOWN ||\n eventType === EventType.WHEEL ||\n eventType === EventType.KEYDOWN\n ) {\n const doc = this.getOwnerDocument();\n const rootNode = this.viewport_.getRootNode\n ? this.viewport_.getRootNode()\n : doc;\n const target = /** @type {Node} */ (originalEvent.target);\n if (\n // Abort if the target is a child of the container for elements whose events are not meant\n // to be handled by map interactions.\n this.overlayContainerStopEvent_.contains(target) ||\n // Abort if the event target is a child of the container that is no longer in the page.\n // It's possible for the target to no longer be in the page if it has been removed in an\n // event listener, this might happen in a Control that recreates it's content based on\n // user interaction either manually or via a render in something like https://reactjs.org/\n !(rootNode === doc ? doc.documentElement : rootNode).contains(target)\n ) {\n return;\n }\n }\n mapBrowserEvent.frameState = this.frameState_;\n if (this.dispatchEvent(mapBrowserEvent) !== false) {\n const interactionsArray = this.getInteractions().getArray().slice();\n for (let i = interactionsArray.length - 1; i >= 0; i--) {\n const interaction = interactionsArray[i];\n if (\n interaction.getMap() !== this ||\n !interaction.getActive() ||\n !this.getTargetElement()\n ) {\n continue;\n }\n const cont = interaction.handleEvent(mapBrowserEvent);\n if (!cont || mapBrowserEvent.propagationStopped) {\n break;\n }\n }\n }\n }\n\n /**\n * @protected\n */\n handlePostRender() {\n const frameState = this.frameState_;\n\n // Manage the tile queue\n // Image loads are expensive and a limited resource, so try to use them\n // efficiently:\n // * When the view is static we allow a large number of parallel tile loads\n // to complete the frame as quickly as possible.\n // * When animating or interacting, image loads can cause janks, so we reduce\n // the maximum number of loads per frame and limit the number of parallel\n // tile loads to remain reactive to view changes and to reduce the chance of\n // loading tiles that will quickly disappear from view.\n const tileQueue = this.tileQueue_;\n if (!tileQueue.isEmpty()) {\n let maxTotalLoading = this.maxTilesLoading_;\n let maxNewLoads = maxTotalLoading;\n if (frameState) {\n const hints = frameState.viewHints;\n if (hints[ViewHint.ANIMATING] || hints[ViewHint.INTERACTING]) {\n const lowOnFrameBudget = Date.now() - frameState.time > 8;\n maxTotalLoading = lowOnFrameBudget ? 0 : 8;\n maxNewLoads = lowOnFrameBudget ? 0 : 2;\n }\n }\n if (tileQueue.getTilesLoading() < maxTotalLoading) {\n tileQueue.reprioritize(); // FIXME only call if view has changed\n tileQueue.loadMoreTiles(maxTotalLoading, maxNewLoads);\n }\n }\n\n if (frameState && this.renderer_ && !frameState.animate) {\n if (this.renderComplete_) {\n if (this.hasListener(RenderEventType.RENDERCOMPLETE)) {\n this.renderer_.dispatchRenderEvent(\n RenderEventType.RENDERCOMPLETE,\n frameState,\n );\n }\n if (this.loaded_ === false) {\n this.loaded_ = true;\n this.dispatchEvent(\n new MapEvent(MapEventType.LOADEND, this, frameState),\n );\n }\n } else if (this.loaded_ === true) {\n this.loaded_ = false;\n this.dispatchEvent(\n new MapEvent(MapEventType.LOADSTART, this, frameState),\n );\n }\n }\n\n const postRenderFunctions = this.postRenderFunctions_;\n for (let i = 0, ii = postRenderFunctions.length; i < ii; ++i) {\n postRenderFunctions[i](this, frameState);\n }\n postRenderFunctions.length = 0;\n }\n\n /**\n * @private\n */\n handleSizeChanged_() {\n if (this.getView() && !this.getView().getAnimating()) {\n this.getView().resolveConstraints(0);\n }\n\n this.render();\n }\n\n /**\n * @private\n */\n handleTargetChanged_() {\n if (this.mapBrowserEventHandler_) {\n for (let i = 0, ii = this.targetChangeHandlerKeys_.length; i < ii; ++i) {\n unlistenByKey(this.targetChangeHandlerKeys_[i]);\n }\n this.targetChangeHandlerKeys_ = null;\n this.viewport_.removeEventListener(\n EventType.CONTEXTMENU,\n this.boundHandleBrowserEvent_,\n );\n this.viewport_.removeEventListener(\n EventType.WHEEL,\n this.boundHandleBrowserEvent_,\n );\n this.mapBrowserEventHandler_.dispose();\n this.mapBrowserEventHandler_ = null;\n this.viewport_.remove();\n }\n\n if (this.targetElement_) {\n this.resizeObserver_.unobserve(this.targetElement_);\n const rootNode = this.targetElement_.getRootNode();\n if (rootNode instanceof ShadowRoot) {\n this.resizeObserver_.unobserve(rootNode.host);\n }\n this.setSize(undefined);\n }\n\n // target may be undefined, null, a string or an Element.\n // If it's a string we convert it to an Element before proceeding.\n // If it's not now an Element we remove the viewport from the DOM.\n // If it's an Element we append the viewport element to it.\n\n const target = this.getTarget();\n const targetElement =\n typeof target === 'string' ? document.getElementById(target) : target;\n this.targetElement_ = targetElement;\n if (!targetElement) {\n if (this.renderer_) {\n clearTimeout(this.postRenderTimeoutHandle_);\n this.postRenderTimeoutHandle_ = undefined;\n this.postRenderFunctions_.length = 0;\n this.renderer_.dispose();\n this.renderer_ = null;\n }\n if (this.animationDelayKey_) {\n cancelAnimationFrame(this.animationDelayKey_);\n this.animationDelayKey_ = undefined;\n }\n } else {\n targetElement.appendChild(this.viewport_);\n if (!this.renderer_) {\n this.renderer_ = new CompositeMapRenderer(this);\n }\n\n this.mapBrowserEventHandler_ = new MapBrowserEventHandler(\n this,\n this.moveTolerance_,\n );\n for (const key in MapBrowserEventType) {\n this.mapBrowserEventHandler_.addEventListener(\n MapBrowserEventType[key],\n this.handleMapBrowserEvent.bind(this),\n );\n }\n this.viewport_.addEventListener(\n EventType.CONTEXTMENU,\n this.boundHandleBrowserEvent_,\n false,\n );\n this.viewport_.addEventListener(\n EventType.WHEEL,\n this.boundHandleBrowserEvent_,\n PASSIVE_EVENT_LISTENERS ? {passive: false} : false,\n );\n\n const keyboardEventTarget = !this.keyboardEventTarget_\n ? targetElement\n : this.keyboardEventTarget_;\n this.targetChangeHandlerKeys_ = [\n listen(\n keyboardEventTarget,\n EventType.KEYDOWN,\n this.handleBrowserEvent,\n this,\n ),\n listen(\n keyboardEventTarget,\n EventType.KEYPRESS,\n this.handleBrowserEvent,\n this,\n ),\n ];\n const rootNode = targetElement.getRootNode();\n if (rootNode instanceof ShadowRoot) {\n this.resizeObserver_.observe(rootNode.host);\n }\n this.resizeObserver_.observe(targetElement);\n }\n\n this.updateSize();\n // updateSize calls setSize, so no need to call this.render\n // ourselves here.\n }\n\n /**\n * @private\n */\n handleTileChange_() {\n this.render();\n }\n\n /**\n * @private\n */\n handleViewPropertyChanged_() {\n this.render();\n }\n\n /**\n * @private\n */\n handleViewChanged_() {\n if (this.viewPropertyListenerKey_) {\n unlistenByKey(this.viewPropertyListenerKey_);\n this.viewPropertyListenerKey_ = null;\n }\n if (this.viewChangeListenerKey_) {\n unlistenByKey(this.viewChangeListenerKey_);\n this.viewChangeListenerKey_ = null;\n }\n const view = this.getView();\n if (view) {\n this.updateViewportSize_(this.getSize());\n\n this.viewPropertyListenerKey_ = listen(\n view,\n ObjectEventType.PROPERTYCHANGE,\n this.handleViewPropertyChanged_,\n this,\n );\n this.viewChangeListenerKey_ = listen(\n view,\n EventType.CHANGE,\n this.handleViewPropertyChanged_,\n this,\n );\n\n view.resolveConstraints(0);\n }\n this.render();\n }\n\n /**\n * @private\n */\n handleLayerGroupChanged_() {\n if (this.layerGroupPropertyListenerKeys_) {\n this.layerGroupPropertyListenerKeys_.forEach(unlistenByKey);\n this.layerGroupPropertyListenerKeys_ = null;\n }\n const layerGroup = this.getLayerGroup();\n if (layerGroup) {\n this.handleLayerAdd_(new GroupEvent('addlayer', layerGroup));\n this.layerGroupPropertyListenerKeys_ = [\n listen(layerGroup, ObjectEventType.PROPERTYCHANGE, this.render, this),\n listen(layerGroup, EventType.CHANGE, this.render, this),\n listen(layerGroup, 'addlayer', this.handleLayerAdd_, this),\n listen(layerGroup, 'removelayer', this.handleLayerRemove_, this),\n ];\n }\n this.render();\n }\n\n /**\n * @return {boolean} Is rendered.\n */\n isRendered() {\n return !!this.frameState_;\n }\n\n /**\n * @private\n */\n animationDelay_() {\n this.animationDelayKey_ = undefined;\n this.renderFrame_(Date.now());\n }\n\n /**\n * Requests an immediate render in a synchronous manner.\n * @api\n */\n renderSync() {\n if (this.animationDelayKey_) {\n cancelAnimationFrame(this.animationDelayKey_);\n }\n this.animationDelay_();\n }\n\n /**\n * Redraws all text after new fonts have loaded\n */\n redrawText() {\n const layerStates = this.getLayerGroup().getLayerStatesArray();\n for (let i = 0, ii = layerStates.length; i < ii; ++i) {\n const layer = layerStates[i].layer;\n if (layer.hasRenderer()) {\n layer.getRenderer().handleFontsChanged();\n }\n }\n }\n\n /**\n * Request a map rendering (at the next animation frame).\n * @api\n */\n render() {\n if (this.renderer_ && this.animationDelayKey_ === undefined) {\n this.animationDelayKey_ = requestAnimationFrame(this.animationDelay_);\n }\n }\n\n /**\n * Remove the given control from the map.\n * @param {import(\"./control/Control.js\").default} control Control.\n * @return {import(\"./control/Control.js\").default|undefined} The removed control (or undefined\n * if the control was not found).\n * @api\n */\n removeControl(control) {\n return this.getControls().remove(control);\n }\n\n /**\n * Remove the given interaction from the map.\n * @param {import(\"./interaction/Interaction.js\").default} interaction Interaction to remove.\n * @return {import(\"./interaction/Interaction.js\").default|undefined} The removed interaction (or\n * undefined if the interaction was not found).\n * @api\n */\n removeInteraction(interaction) {\n return this.getInteractions().remove(interaction);\n }\n\n /**\n * Removes the given layer from the map.\n * @param {import(\"./layer/Base.js\").default} layer Layer.\n * @return {import(\"./layer/Base.js\").default|undefined} The removed layer (or undefined if the\n * layer was not found).\n * @api\n */\n removeLayer(layer) {\n const layers = this.getLayerGroup().getLayers();\n return layers.remove(layer);\n }\n\n /**\n * @param {import(\"./layer/Group.js\").GroupEvent} event The layer remove event.\n * @private\n */\n handleLayerRemove_(event) {\n removeLayerMapProperty(event.layer);\n }\n\n /**\n * Remove the given overlay from the map.\n * @param {import(\"./Overlay.js\").default} overlay Overlay.\n * @return {import(\"./Overlay.js\").default|undefined} The removed overlay (or undefined\n * if the overlay was not found).\n * @api\n */\n removeOverlay(overlay) {\n return this.getOverlays().remove(overlay);\n }\n\n /**\n * @param {number} time Time.\n * @private\n */\n renderFrame_(time) {\n const size = this.getSize();\n const view = this.getView();\n const previousFrameState = this.frameState_;\n /** @type {?FrameState} */\n let frameState = null;\n if (size !== undefined && hasArea(size) && view && view.isDef()) {\n const viewHints = view.getHints(\n this.frameState_ ? this.frameState_.viewHints : undefined,\n );\n const viewState = view.getState();\n frameState = {\n animate: false,\n coordinateToPixelTransform: this.coordinateToPixelTransform_,\n declutter: null,\n extent: getForViewAndSize(\n viewState.center,\n viewState.resolution,\n viewState.rotation,\n size,\n ),\n index: this.frameIndex_++,\n layerIndex: 0,\n layerStatesArray: this.getLayerGroup().getLayerStatesArray(),\n pixelRatio: this.pixelRatio_,\n pixelToCoordinateTransform: this.pixelToCoordinateTransform_,\n postRenderFunctions: [],\n size: size,\n tileQueue: this.tileQueue_,\n time: time,\n usedTiles: {},\n viewState: viewState,\n viewHints: viewHints,\n wantedTiles: {},\n mapId: getUid(this),\n renderTargets: {},\n };\n if (viewState.nextCenter && viewState.nextResolution) {\n const rotation = isNaN(viewState.nextRotation)\n ? viewState.rotation\n : viewState.nextRotation;\n\n frameState.nextExtent = getForViewAndSize(\n viewState.nextCenter,\n viewState.nextResolution,\n rotation,\n size,\n );\n }\n }\n\n this.frameState_ = frameState;\n this.renderer_.renderFrame(frameState);\n\n if (frameState) {\n if (frameState.animate) {\n this.render();\n }\n Array.prototype.push.apply(\n this.postRenderFunctions_,\n frameState.postRenderFunctions,\n );\n\n if (previousFrameState) {\n const moveStart =\n !this.previousExtent_ ||\n (!isEmpty(this.previousExtent_) &&\n !equalsExtent(frameState.extent, this.previousExtent_));\n if (moveStart) {\n this.dispatchEvent(\n new MapEvent(MapEventType.MOVESTART, this, previousFrameState),\n );\n this.previousExtent_ = createOrUpdateEmpty(this.previousExtent_);\n }\n }\n\n const idle =\n this.previousExtent_ &&\n !frameState.viewHints[ViewHint.ANIMATING] &&\n !frameState.viewHints[ViewHint.INTERACTING] &&\n !equalsExtent(frameState.extent, this.previousExtent_);\n\n if (idle) {\n this.dispatchEvent(\n new MapEvent(MapEventType.MOVEEND, this, frameState),\n );\n clone(frameState.extent, this.previousExtent_);\n }\n }\n\n this.dispatchEvent(new MapEvent(MapEventType.POSTRENDER, this, frameState));\n\n this.renderComplete_ =\n (this.hasListener(MapEventType.LOADSTART) ||\n this.hasListener(MapEventType.LOADEND) ||\n this.hasListener(RenderEventType.RENDERCOMPLETE)) &&\n !this.tileQueue_.getTilesLoading() &&\n !this.tileQueue_.getCount() &&\n !this.getLoadingOrNotReady();\n\n if (!this.postRenderTimeoutHandle_) {\n this.postRenderTimeoutHandle_ = setTimeout(() => {\n this.postRenderTimeoutHandle_ = undefined;\n this.handlePostRender();\n }, 0);\n }\n }\n\n /**\n * Sets the layergroup of this map.\n * @param {LayerGroup} layerGroup A layer group containing the layers in this map.\n * @observable\n * @api\n */\n setLayerGroup(layerGroup) {\n const oldLayerGroup = this.getLayerGroup();\n if (oldLayerGroup) {\n this.handleLayerRemove_(new GroupEvent('removelayer', oldLayerGroup));\n }\n this.set(MapProperty.LAYERGROUP, layerGroup);\n }\n\n /**\n * Set the size of this map.\n * @param {import(\"./size.js\").Size|undefined} size The size in pixels of the map in the DOM.\n * @observable\n * @api\n */\n setSize(size) {\n this.set(MapProperty.SIZE, size);\n }\n\n /**\n * Set the target element to render this map into.\n * @param {HTMLElement|string} [target] The Element or id of the Element\n * that the map is rendered in.\n * @observable\n * @api\n */\n setTarget(target) {\n this.set(MapProperty.TARGET, target);\n }\n\n /**\n * Set the view for this map.\n * @param {View|Promise} view The view that controls this map.\n * It is also possible to pass a promise that resolves to options for constructing a view. This\n * alternative allows view properties to be resolved by sources or other components that load\n * view-related metadata.\n * @observable\n * @api\n */\n setView(view) {\n if (!view || view instanceof View) {\n this.set(MapProperty.VIEW, view);\n return;\n }\n this.set(MapProperty.VIEW, new View());\n\n const map = this;\n view.then(function (viewOptions) {\n map.setView(new View(viewOptions));\n });\n }\n\n /**\n * Force a recalculation of the map viewport size. This should be called when\n * third-party code changes the size of the map viewport.\n * @api\n */\n updateSize() {\n const targetElement = this.getTargetElement();\n\n let size = undefined;\n if (targetElement) {\n const computedStyle = getComputedStyle(targetElement);\n const width =\n targetElement.offsetWidth -\n parseFloat(computedStyle['borderLeftWidth']) -\n parseFloat(computedStyle['paddingLeft']) -\n parseFloat(computedStyle['paddingRight']) -\n parseFloat(computedStyle['borderRightWidth']);\n const height =\n targetElement.offsetHeight -\n parseFloat(computedStyle['borderTopWidth']) -\n parseFloat(computedStyle['paddingTop']) -\n parseFloat(computedStyle['paddingBottom']) -\n parseFloat(computedStyle['borderBottomWidth']);\n if (!isNaN(width) && !isNaN(height)) {\n size = [Math.max(0, width), Math.max(0, height)];\n if (\n !hasArea(size) &&\n !!(\n targetElement.offsetWidth ||\n targetElement.offsetHeight ||\n targetElement.getClientRects().length\n )\n ) {\n warn(\n \"No map visible because the map container's width or height are 0.\",\n );\n }\n }\n }\n\n const oldSize = this.getSize();\n if (size && (!oldSize || !equals(size, oldSize))) {\n this.setSize(size);\n this.updateViewportSize_(size);\n }\n }\n\n /**\n * Recomputes the viewport size and save it on the view object (if any)\n * @param {import(\"./size.js\").Size|undefined} size The size.\n * @private\n */\n updateViewportSize_(size) {\n const view = this.getView();\n if (view) {\n view.setViewportSize(size);\n }\n }\n}\n\n/**\n * @param {MapOptions} options Map options.\n * @return {MapOptionsInternal} Internal map options.\n */\nfunction createOptionsInternal(options) {\n /**\n * @type {HTMLElement|Document}\n */\n let keyboardEventTarget = null;\n if (options.keyboardEventTarget !== undefined) {\n keyboardEventTarget =\n typeof options.keyboardEventTarget === 'string'\n ? document.getElementById(options.keyboardEventTarget)\n : options.keyboardEventTarget;\n }\n\n /**\n * @type {Object}\n */\n const values = {};\n\n const layerGroup =\n options.layers &&\n typeof (/** @type {?} */ (options.layers).getLayers) === 'function'\n ? /** @type {LayerGroup} */ (options.layers)\n : new LayerGroup({\n layers:\n /** @type {Collection|Array} */ (\n options.layers\n ),\n });\n values[MapProperty.LAYERGROUP] = layerGroup;\n\n values[MapProperty.TARGET] = options.target;\n\n values[MapProperty.VIEW] =\n options.view instanceof View ? options.view : new View();\n\n /** @type {Collection} */\n let controls;\n if (options.controls !== undefined) {\n if (Array.isArray(options.controls)) {\n controls = new Collection(options.controls.slice());\n } else {\n assert(\n typeof (/** @type {?} */ (options.controls).getArray) === 'function',\n 'Expected `controls` to be an array or an `ol/Collection.js`',\n );\n controls = options.controls;\n }\n }\n\n /** @type {Collection} */\n let interactions;\n if (options.interactions !== undefined) {\n if (Array.isArray(options.interactions)) {\n interactions = new Collection(options.interactions.slice());\n } else {\n assert(\n typeof (/** @type {?} */ (options.interactions).getArray) ===\n 'function',\n 'Expected `interactions` to be an array or an `ol/Collection.js`',\n );\n interactions = options.interactions;\n }\n }\n\n /** @type {Collection} */\n let overlays;\n if (options.overlays !== undefined) {\n if (Array.isArray(options.overlays)) {\n overlays = new Collection(options.overlays.slice());\n } else {\n assert(\n typeof (/** @type {?} */ (options.overlays).getArray) === 'function',\n 'Expected `overlays` to be an array or an `ol/Collection.js`',\n );\n overlays = options.overlays;\n }\n } else {\n overlays = new Collection();\n }\n\n return {\n controls: controls,\n interactions: interactions,\n keyboardEventTarget: keyboardEventTarget,\n overlays: overlays,\n values: values,\n };\n}\nexport default Map;\n","/**\n * @module ol/control/defaults\n */\nimport Attribution from './Attribution.js';\nimport Collection from '../Collection.js';\nimport Rotate from './Rotate.js';\nimport Zoom from './Zoom.js';\n\n/**\n * @typedef {Object} DefaultsOptions\n * @property {boolean} [attribution=true] Include\n * {@link module:ol/control/Attribution~Attribution}.\n * @property {import(\"./Attribution.js\").Options} [attributionOptions]\n * Options for {@link module:ol/control/Attribution~Attribution}.\n * @property {boolean} [rotate=true] Include\n * {@link module:ol/control/Rotate~Rotate}.\n * @property {import(\"./Rotate.js\").Options} [rotateOptions] Options\n * for {@link module:ol/control/Rotate~Rotate}.\n * @property {boolean} [zoom] Include {@link module:ol/control/Zoom~Zoom}.\n * @property {import(\"./Zoom.js\").Options} [zoomOptions] Options for\n * {@link module:ol/control/Zoom~Zoom}.\n */\n\n/**\n * Set of controls included in maps by default. Unless configured otherwise,\n * this returns a collection containing an instance of each of the following\n * controls:\n * * {@link module:ol/control/Zoom~Zoom}\n * * {@link module:ol/control/Rotate~Rotate}\n * * {@link module:ol/control/Attribution~Attribution}\n *\n * @param {DefaultsOptions} [options] Options for the default controls.\n * @return {Collection} A collection of controls\n * to be used with the {@link module:ol/Map~Map} constructor's `controls` option.\n * @api\n */\nexport function defaults(options) {\n options = options ? options : {};\n\n /** @type {Collection} */\n const controls = new Collection();\n\n const zoomControl = options.zoom !== undefined ? options.zoom : true;\n if (zoomControl) {\n controls.push(new Zoom(options.zoomOptions));\n }\n\n const rotateControl = options.rotate !== undefined ? options.rotate : true;\n if (rotateControl) {\n controls.push(new Rotate(options.rotateOptions));\n }\n\n const attributionControl =\n options.attribution !== undefined ? options.attribution : true;\n if (attributionControl) {\n controls.push(new Attribution(options.attributionOptions));\n }\n\n return controls;\n}\n","/**\n * @module ol/interaction/defaults\n */\nimport Collection from '../Collection.js';\nimport DoubleClickZoom from './DoubleClickZoom.js';\nimport DragPan from './DragPan.js';\nimport DragRotate from './DragRotate.js';\nimport DragZoom from './DragZoom.js';\nimport KeyboardPan from './KeyboardPan.js';\nimport KeyboardZoom from './KeyboardZoom.js';\nimport Kinetic from '../Kinetic.js';\nimport MouseWheelZoom from './MouseWheelZoom.js';\nimport PinchRotate from './PinchRotate.js';\nimport PinchZoom from './PinchZoom.js';\n\n/**\n * @typedef {Object} DefaultsOptions\n * @property {boolean} [altShiftDragRotate=true] Whether Alt-Shift-drag rotate is\n * desired.\n * @property {boolean} [onFocusOnly=false] Interact only when the map has the\n * focus. This affects the `MouseWheelZoom` and `DragPan` interactions and is\n * useful when page scroll is desired for maps that do not have the browser's\n * focus.\n * @property {boolean} [doubleClickZoom=true] Whether double click zoom is\n * desired.\n * @property {boolean} [keyboard=true] Whether keyboard interaction is desired.\n * @property {boolean} [mouseWheelZoom=true] Whether mousewheel zoom is desired.\n * @property {boolean} [shiftDragZoom=true] Whether Shift-drag zoom is desired.\n * @property {boolean} [dragPan=true] Whether drag pan is desired.\n * @property {boolean} [pinchRotate=true] Whether pinch rotate is desired.\n * @property {boolean} [pinchZoom=true] Whether pinch zoom is desired.\n * @property {number} [zoomDelta] Zoom level delta when using keyboard or double click zoom.\n * @property {number} [zoomDuration] Duration of the zoom animation in\n * milliseconds.\n */\n\n/**\n * Set of interactions included in maps by default. Specific interactions can be\n * excluded by setting the appropriate option to false in the constructor\n * options, but the order of the interactions is fixed. If you want to specify\n * a different order for interactions, you will need to create your own\n * {@link module:ol/interaction/Interaction~Interaction} instances and insert\n * them into a {@link module:ol/Collection~Collection} in the order you want\n * before creating your {@link module:ol/Map~Map} instance. Changing the order can\n * be of interest if the event propagation needs to be stopped at a point.\n * The default set of interactions, in sequence, is:\n * * {@link module:ol/interaction/DragRotate~DragRotate}\n * * {@link module:ol/interaction/DoubleClickZoom~DoubleClickZoom}\n * * {@link module:ol/interaction/DragPan~DragPan}\n * * {@link module:ol/interaction/PinchRotate~PinchRotate}\n * * {@link module:ol/interaction/PinchZoom~PinchZoom}\n * * {@link module:ol/interaction/KeyboardPan~KeyboardPan}\n * * {@link module:ol/interaction/KeyboardZoom~KeyboardZoom}\n * * {@link module:ol/interaction/MouseWheelZoom~MouseWheelZoom}\n * * {@link module:ol/interaction/DragZoom~DragZoom}\n *\n * @param {DefaultsOptions} [options] Defaults options.\n * @return {Collection}\n * A collection of interactions to be used with the {@link module:ol/Map~Map}\n * constructor's `interactions` option.\n * @api\n */\nexport function defaults(options) {\n options = options ? options : {};\n\n /** @type {Collection} */\n const interactions = new Collection();\n\n const kinetic = new Kinetic(-0.005, 0.05, 100);\n\n const altShiftDragRotate =\n options.altShiftDragRotate !== undefined\n ? options.altShiftDragRotate\n : true;\n if (altShiftDragRotate) {\n interactions.push(new DragRotate());\n }\n\n const doubleClickZoom =\n options.doubleClickZoom !== undefined ? options.doubleClickZoom : true;\n if (doubleClickZoom) {\n interactions.push(\n new DoubleClickZoom({\n delta: options.zoomDelta,\n duration: options.zoomDuration,\n }),\n );\n }\n\n const dragPan = options.dragPan !== undefined ? options.dragPan : true;\n if (dragPan) {\n interactions.push(\n new DragPan({\n onFocusOnly: options.onFocusOnly,\n kinetic: kinetic,\n }),\n );\n }\n\n const pinchRotate =\n options.pinchRotate !== undefined ? options.pinchRotate : true;\n if (pinchRotate) {\n interactions.push(new PinchRotate());\n }\n\n const pinchZoom = options.pinchZoom !== undefined ? options.pinchZoom : true;\n if (pinchZoom) {\n interactions.push(\n new PinchZoom({\n duration: options.zoomDuration,\n }),\n );\n }\n\n const keyboard = options.keyboard !== undefined ? options.keyboard : true;\n if (keyboard) {\n interactions.push(new KeyboardPan());\n interactions.push(\n new KeyboardZoom({\n delta: options.zoomDelta,\n duration: options.zoomDuration,\n }),\n );\n }\n\n const mouseWheelZoom =\n options.mouseWheelZoom !== undefined ? options.mouseWheelZoom : true;\n if (mouseWheelZoom) {\n interactions.push(\n new MouseWheelZoom({\n onFocusOnly: options.onFocusOnly,\n duration: options.zoomDuration,\n }),\n );\n }\n\n const shiftDragZoom =\n options.shiftDragZoom !== undefined ? options.shiftDragZoom : true;\n if (shiftDragZoom) {\n interactions.push(\n new DragZoom({\n duration: options.zoomDuration,\n }),\n );\n }\n\n return interactions;\n}\n","/**\n * @module ol/Object\n */\nimport Event from './events/Event.js';\nimport ObjectEventType from './ObjectEventType.js';\nimport Observable from './Observable.js';\nimport {getUid} from './util.js';\nimport {isEmpty} from './obj.js';\n\n/**\n * @classdesc\n * Events emitted by {@link module:ol/Object~BaseObject} instances are instances of this type.\n */\nexport class ObjectEvent extends Event {\n /**\n * @param {string} type The event type.\n * @param {string} key The property name.\n * @param {*} oldValue The old value for `key`.\n */\n constructor(type, key, oldValue) {\n super(type);\n\n /**\n * The name of the property whose value is changing.\n * @type {string}\n * @api\n */\n this.key = key;\n\n /**\n * The old value. To get the new value use `e.target.get(e.key)` where\n * `e` is the event object.\n * @type {*}\n * @api\n */\n this.oldValue = oldValue;\n }\n}\n\n/***\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature &\n * import(\"./Observable\").OnSignature &\n * import(\"./Observable\").CombinedOnSignature} ObjectOnSignature\n */\n\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * Most non-trivial classes inherit from this.\n *\n * This extends {@link module:ol/Observable~Observable} with observable\n * properties, where each property is observable as well as the object as a\n * whole.\n *\n * Classes that inherit from this have pre-defined properties, to which you can\n * add your owns. The pre-defined properties are listed in this documentation as\n * 'Observable Properties', and have their own accessors; for example,\n * {@link module:ol/Map~Map} has a `target` property, accessed with\n * `getTarget()` and changed with `setTarget()`. Not all properties are however\n * settable. There are also general-purpose accessors `get()` and `set()`. For\n * example, `get('target')` is equivalent to `getTarget()`.\n *\n * The `set` accessors trigger a change event, and you can monitor this by\n * registering a listener. For example, {@link module:ol/View~View} has a\n * `center` property, so `view.on('change:center', function(evt) {...});` would\n * call the function whenever the value of the center property changes. Within\n * the function, `evt.target` would be the view, so `evt.target.getCenter()`\n * would return the new center.\n *\n * You can add your own observable properties with\n * `object.set('prop', 'value')`, and retrieve that with `object.get('prop')`.\n * You can listen for changes on that property value with\n * `object.on('change:prop', listener)`. You can get a list of all\n * properties with {@link module:ol/Object~BaseObject#getProperties}.\n *\n * Note that the observable properties are separate from standard JS properties.\n * You can, for example, give your map object a title with\n * `map.title='New title'` and with `map.set('title', 'Another title')`. The\n * first will be a `hasOwnProperty`; the second will appear in\n * `getProperties()`. Only the second is observable.\n *\n * Properties can be deleted by using the unset method. E.g.\n * object.unset('foo').\n *\n * @fires ObjectEvent\n * @api\n */\nclass BaseObject extends Observable {\n /**\n * @param {Object} [values] An object with key-value pairs.\n */\n constructor(values) {\n super();\n\n /***\n * @type {ObjectOnSignature}\n */\n this.on;\n\n /***\n * @type {ObjectOnSignature}\n */\n this.once;\n\n /***\n * @type {ObjectOnSignature}\n */\n this.un;\n\n // Call {@link module:ol/util.getUid} to ensure that the order of objects' ids is\n // the same as the order in which they were created. This also helps to\n // ensure that object properties are always added in the same order, which\n // helps many JavaScript engines generate faster code.\n getUid(this);\n\n /**\n * @private\n * @type {Object|null}\n */\n this.values_ = null;\n\n if (values !== undefined) {\n this.setProperties(values);\n }\n }\n\n /**\n * Gets a value.\n * @param {string} key Key name.\n * @return {*} Value.\n * @api\n */\n get(key) {\n let value;\n if (this.values_ && this.values_.hasOwnProperty(key)) {\n value = this.values_[key];\n }\n return value;\n }\n\n /**\n * Get a list of object property names.\n * @return {Array} List of property names.\n * @api\n */\n getKeys() {\n return (this.values_ && Object.keys(this.values_)) || [];\n }\n\n /**\n * Get an object of all property names and values.\n * @return {Object} Object.\n * @api\n */\n getProperties() {\n return (this.values_ && Object.assign({}, this.values_)) || {};\n }\n\n /**\n * Get an object of all property names and values.\n * @return {Object?} Object.\n */\n getPropertiesInternal() {\n return this.values_;\n }\n\n /**\n * @return {boolean} The object has properties.\n */\n hasProperties() {\n return !!this.values_;\n }\n\n /**\n * @param {string} key Key name.\n * @param {*} oldValue Old value.\n */\n notify(key, oldValue) {\n let eventType;\n eventType = `change:${key}`;\n if (this.hasListener(eventType)) {\n this.dispatchEvent(new ObjectEvent(eventType, key, oldValue));\n }\n eventType = ObjectEventType.PROPERTYCHANGE;\n if (this.hasListener(eventType)) {\n this.dispatchEvent(new ObjectEvent(eventType, key, oldValue));\n }\n }\n\n /**\n * @param {string} key Key name.\n * @param {import(\"./events.js\").Listener} listener Listener.\n */\n addChangeListener(key, listener) {\n this.addEventListener(`change:${key}`, listener);\n }\n\n /**\n * @param {string} key Key name.\n * @param {import(\"./events.js\").Listener} listener Listener.\n */\n removeChangeListener(key, listener) {\n this.removeEventListener(`change:${key}`, listener);\n }\n\n /**\n * Sets a value.\n * @param {string} key Key name.\n * @param {*} value Value.\n * @param {boolean} [silent] Update without triggering an event.\n * @api\n */\n set(key, value, silent) {\n const values = this.values_ || (this.values_ = {});\n if (silent) {\n values[key] = value;\n } else {\n const oldValue = values[key];\n values[key] = value;\n if (oldValue !== value) {\n this.notify(key, oldValue);\n }\n }\n }\n\n /**\n * Sets a collection of key-value pairs. Note that this changes any existing\n * properties and adds new ones (it does not remove any existing properties).\n * @param {Object} values Values.\n * @param {boolean} [silent] Update without triggering an event.\n * @api\n */\n setProperties(values, silent) {\n for (const key in values) {\n this.set(key, values[key], silent);\n }\n }\n\n /**\n * Apply any properties from another object without triggering events.\n * @param {BaseObject} source The source object.\n * @protected\n */\n applyProperties(source) {\n if (!source.values_) {\n return;\n }\n Object.assign(this.values_ || (this.values_ = {}), source.values_);\n }\n\n /**\n * Unsets a property.\n * @param {string} key Key name.\n * @param {boolean} [silent] Unset without triggering an event.\n * @api\n */\n unset(key, silent) {\n if (this.values_ && key in this.values_) {\n const oldValue = this.values_[key];\n delete this.values_[key];\n if (isEmpty(this.values_)) {\n this.values_ = null;\n }\n if (!silent) {\n this.notify(key, oldValue);\n }\n }\n }\n}\n\nexport default BaseObject;\n","/**\n * @module ol/ObjectEventType\n */\n\n/**\n * @enum {string}\n */\nexport default {\n /**\n * Triggered when a property is changed.\n * @event module:ol/Object.ObjectEvent#propertychange\n * @api\n */\n PROPERTYCHANGE: 'propertychange',\n};\n\n/**\n * @typedef {'propertychange'} Types\n */\n","/**\n * @module ol/Observable\n */\nimport EventTarget from './events/Target.js';\nimport EventType from './events/EventType.js';\nimport {listen, listenOnce, unlistenByKey} from './events.js';\n\n/***\n * @template {string} Type\n * @template {Event|import(\"./events/Event.js\").default} EventClass\n * @template Return\n * @typedef {(type: Type, listener: (event: EventClass) => ?) => Return} OnSignature\n */\n\n/***\n * @template {string} Type\n * @template Return\n * @typedef {(type: Type[], listener: (event: Event|import(\"./events/Event\").default) => ?) => Return extends void ? void : Return[]} CombinedOnSignature\n */\n\n/**\n * @typedef {'change'|'error'} EventTypes\n */\n\n/***\n * @template Return\n * @typedef {OnSignature & CombinedOnSignature} ObservableOnSignature\n */\n\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * An event target providing convenient methods for listener registration\n * and unregistration. A generic `change` event is always available through\n * {@link module:ol/Observable~Observable#changed}.\n *\n * @fires import(\"./events/Event.js\").default\n * @api\n */\nclass Observable extends EventTarget {\n constructor() {\n super();\n\n this.on =\n /** @type {ObservableOnSignature} */ (\n this.onInternal\n );\n\n this.once =\n /** @type {ObservableOnSignature} */ (\n this.onceInternal\n );\n\n this.un = /** @type {ObservableOnSignature} */ (this.unInternal);\n\n /**\n * @private\n * @type {number}\n */\n this.revision_ = 0;\n }\n\n /**\n * Increases the revision counter and dispatches a 'change' event.\n * @api\n */\n changed() {\n ++this.revision_;\n this.dispatchEvent(EventType.CHANGE);\n }\n\n /**\n * Get the version number for this object. Each time the object is modified,\n * its version number will be incremented.\n * @return {number} Revision.\n * @api\n */\n getRevision() {\n return this.revision_;\n }\n\n /**\n * @param {string|Array} type Type.\n * @param {function((Event|import(\"./events/Event\").default)): ?} listener Listener.\n * @return {import(\"./events.js\").EventsKey|Array} Event key.\n * @protected\n */\n onInternal(type, listener) {\n if (Array.isArray(type)) {\n const len = type.length;\n const keys = new Array(len);\n for (let i = 0; i < len; ++i) {\n keys[i] = listen(this, type[i], listener);\n }\n return keys;\n }\n return listen(this, /** @type {string} */ (type), listener);\n }\n\n /**\n * @param {string|Array} type Type.\n * @param {function((Event|import(\"./events/Event\").default)): ?} listener Listener.\n * @return {import(\"./events.js\").EventsKey|Array} Event key.\n * @protected\n */\n onceInternal(type, listener) {\n let key;\n if (Array.isArray(type)) {\n const len = type.length;\n key = new Array(len);\n for (let i = 0; i < len; ++i) {\n key[i] = listenOnce(this, type[i], listener);\n }\n } else {\n key = listenOnce(this, /** @type {string} */ (type), listener);\n }\n /** @type {Object} */ (listener).ol_key = key;\n return key;\n }\n\n /**\n * Unlisten for a certain type of event.\n * @param {string|Array} type Type.\n * @param {function((Event|import(\"./events/Event\").default)): ?} listener Listener.\n * @protected\n */\n unInternal(type, listener) {\n const key = /** @type {Object} */ (listener).ol_key;\n if (key) {\n unByKey(key);\n } else if (Array.isArray(type)) {\n for (let i = 0, ii = type.length; i < ii; ++i) {\n this.removeEventListener(type[i], listener);\n }\n } else {\n this.removeEventListener(type, listener);\n }\n }\n}\n\n/**\n * Listen for a certain type of event.\n * @function\n * @param {string|Array} type The event type or array of event types.\n * @param {function((Event|import(\"./events/Event\").default)): ?} listener The listener function.\n * @return {import(\"./events.js\").EventsKey|Array} Unique key for the listener. If\n * called with an array of event types as the first argument, the return\n * will be an array of keys.\n * @api\n */\nObservable.prototype.on;\n\n/**\n * Listen once for a certain type of event.\n * @function\n * @param {string|Array} type The event type or array of event types.\n * @param {function((Event|import(\"./events/Event\").default)): ?} listener The listener function.\n * @return {import(\"./events.js\").EventsKey|Array} Unique key for the listener. If\n * called with an array of event types as the first argument, the return\n * will be an array of keys.\n * @api\n */\nObservable.prototype.once;\n\n/**\n * Unlisten for a certain type of event.\n * @function\n * @param {string|Array} type The event type or array of event types.\n * @param {function((Event|import(\"./events/Event\").default)): ?} listener The listener function.\n * @api\n */\nObservable.prototype.un;\n\n/**\n * Removes an event listener using the key returned by `on()` or `once()`.\n * @param {import(\"./events.js\").EventsKey|Array} key The key returned by `on()`\n * or `once()` (or an array of keys).\n * @api\n */\nexport function unByKey(key) {\n if (Array.isArray(key)) {\n for (let i = 0, ii = key.length; i < ii; ++i) {\n unlistenByKey(key[i]);\n }\n } else {\n unlistenByKey(/** @type {import(\"./events.js\").EventsKey} */ (key));\n }\n}\n\nexport default Observable;\n","/**\n * @module ol/Tile\n */\nimport EventTarget from './events/Target.js';\nimport EventType from './events/EventType.js';\nimport TileState from './TileState.js';\nimport {abstract} from './util.js';\nimport {easeIn} from './easing.js';\n\n/**\n * A function that takes a {@link module:ol/Tile~Tile} for the tile and a\n * `{string}` for the url as arguments. The default is\n * ```js\n * source.setTileLoadFunction(function(tile, src) {\n * tile.getImage().src = src;\n * });\n * ```\n * For more fine grained control, the load function can use fetch or XMLHttpRequest and involve\n * error handling:\n *\n * ```js\n * import TileState from 'ol/TileState.js';\n *\n * source.setTileLoadFunction(function(tile, src) {\n * const xhr = new XMLHttpRequest();\n * xhr.responseType = 'blob';\n * xhr.addEventListener('loadend', function (evt) {\n * const data = this.response;\n * if (data !== undefined) {\n * tile.getImage().src = URL.createObjectURL(data);\n * } else {\n * tile.setState(TileState.ERROR);\n * }\n * });\n * xhr.addEventListener('error', function () {\n * tile.setState(TileState.ERROR);\n * });\n * xhr.open('GET', src);\n * xhr.send();\n * });\n * ```\n *\n * @typedef {function(Tile, string): void} LoadFunction\n * @api\n */\n\n/**\n * {@link module:ol/source/Tile~TileSource} sources use a function of this type to get\n * the url that provides a tile for a given tile coordinate.\n *\n * This function takes a {@link module:ol/tilecoord~TileCoord} for the tile\n * coordinate, a `{number}` representing the pixel ratio and a\n * {@link module:ol/proj/Projection~Projection} for the projection as arguments\n * and returns a `{string}` representing the tile URL, or undefined if no tile\n * should be requested for the passed tile coordinate.\n *\n * @typedef {function(import(\"./tilecoord.js\").TileCoord, number,\n * import(\"./proj/Projection.js\").default): (string|undefined)} UrlFunction\n * @api\n */\n\n/**\n * @typedef {Object} Options\n * @property {number} [transition=250] A duration for tile opacity\n * transitions in milliseconds. A duration of 0 disables the opacity transition.\n * @property {boolean} [interpolate=false] Use interpolated values when resampling. By default,\n * the nearest neighbor is used when resampling.\n * @api\n */\n\n/**\n * @classdesc\n * Base class for tiles.\n *\n * @abstract\n */\nclass Tile extends EventTarget {\n /**\n * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @param {import(\"./TileState.js\").default} state State.\n * @param {Options} [options] Tile options.\n */\n constructor(tileCoord, state, options) {\n super();\n\n options = options ? options : {};\n\n /**\n * @type {import(\"./tilecoord.js\").TileCoord}\n */\n this.tileCoord = tileCoord;\n\n /**\n * @protected\n * @type {import(\"./TileState.js\").default}\n */\n this.state = state;\n\n /**\n * A key assigned to the tile. This is used in conjunction with a source key\n * to determine if a cached version of this tile may be used by the renderer.\n * @type {string}\n */\n this.key = '';\n\n /**\n * The duration for the opacity transition.\n * @private\n * @type {number}\n */\n this.transition_ =\n options.transition === undefined ? 250 : options.transition;\n\n /**\n * Lookup of start times for rendering transitions. If the start time is\n * equal to -1, the transition is complete.\n * @private\n * @type {Object}\n */\n this.transitionStarts_ = {};\n\n /**\n * @type {boolean}\n */\n this.interpolate = !!options.interpolate;\n }\n\n /**\n * @protected\n */\n changed() {\n this.dispatchEvent(EventType.CHANGE);\n }\n\n /**\n * Called by the tile cache when the tile is removed from the cache due to expiry\n */\n release() {\n if (this.state === TileState.ERROR) {\n // to remove the `change` listener on this tile in `ol/TileQueue#handleTileChange`\n this.setState(TileState.EMPTY);\n }\n }\n\n /**\n * @return {string} Key.\n */\n getKey() {\n return this.key + '/' + this.tileCoord;\n }\n\n /**\n * Get the tile coordinate for this tile.\n * @return {import(\"./tilecoord.js\").TileCoord} The tile coordinate.\n * @api\n */\n getTileCoord() {\n return this.tileCoord;\n }\n\n /**\n * @return {import(\"./TileState.js\").default} State.\n */\n getState() {\n return this.state;\n }\n\n /**\n * Sets the state of this tile. If you write your own {@link module:ol/Tile~LoadFunction tileLoadFunction} ,\n * it is important to set the state correctly to {@link module:ol/TileState~ERROR}\n * when the tile cannot be loaded. Otherwise the tile cannot be removed from\n * the tile queue and will block other requests.\n * @param {import(\"./TileState.js\").default} state State.\n * @api\n */\n setState(state) {\n if (this.state !== TileState.ERROR && this.state > state) {\n throw new Error('Tile load sequence violation');\n }\n this.state = state;\n this.changed();\n }\n\n /**\n * Load the image or retry if loading previously failed.\n * Loading is taken care of by the tile queue, and calling this method is\n * only needed for preloading or for reloading in case of an error.\n * @abstract\n * @api\n */\n load() {\n abstract();\n }\n\n /**\n * Get the alpha value for rendering.\n * @param {string} id An id for the renderer.\n * @param {number} time The render frame time.\n * @return {number} A number between 0 and 1.\n */\n getAlpha(id, time) {\n if (!this.transition_) {\n return 1;\n }\n\n let start = this.transitionStarts_[id];\n if (!start) {\n start = time;\n this.transitionStarts_[id] = start;\n } else if (start === -1) {\n return 1;\n }\n\n const delta = time - start + 1000 / 60; // avoid rendering at 0\n if (delta >= this.transition_) {\n return 1;\n }\n return easeIn(delta / this.transition_);\n }\n\n /**\n * Determine if a tile is in an alpha transition. A tile is considered in\n * transition if tile.getAlpha() has not yet been called or has been called\n * and returned 1.\n * @param {string} id An id for the renderer.\n * @return {boolean} The tile is in transition.\n */\n inTransition(id) {\n if (!this.transition_) {\n return false;\n }\n return this.transitionStarts_[id] !== -1;\n }\n\n /**\n * Mark a transition as complete.\n * @param {string} id An id for the renderer.\n */\n endTransition(id) {\n if (this.transition_) {\n this.transitionStarts_[id] = -1;\n }\n }\n}\n\nexport default Tile;\n","/**\n * @module ol/structs/PriorityQueue\n */\nimport {assert} from '../asserts.js';\nimport {clear} from '../obj.js';\n\n/**\n * @type {number}\n */\nexport const DROP = Infinity;\n\n/**\n * @classdesc\n * Priority queue.\n *\n * The implementation is inspired from the Closure Library's Heap class and\n * Python's heapq module.\n *\n * See https://github.com/google/closure-library/blob/master/closure/goog/structs/heap.js\n * and https://hg.python.org/cpython/file/2.7/Lib/heapq.py.\n *\n * @template T\n */\nclass PriorityQueue {\n /**\n * @param {function(T): number} priorityFunction Priority function.\n * @param {function(T): string} keyFunction Key function.\n */\n constructor(priorityFunction, keyFunction) {\n /**\n * @type {function(T): number}\n * @private\n */\n this.priorityFunction_ = priorityFunction;\n\n /**\n * @type {function(T): string}\n * @private\n */\n this.keyFunction_ = keyFunction;\n\n /**\n * @type {Array}\n * @private\n */\n this.elements_ = [];\n\n /**\n * @type {Array}\n * @private\n */\n this.priorities_ = [];\n\n /**\n * @type {!Object}\n * @private\n */\n this.queuedElements_ = {};\n }\n\n /**\n * FIXME empty description for jsdoc\n */\n clear() {\n this.elements_.length = 0;\n this.priorities_.length = 0;\n clear(this.queuedElements_);\n }\n\n /**\n * Remove and return the highest-priority element. O(log N).\n * @return {T} Element.\n */\n dequeue() {\n const elements = this.elements_;\n const priorities = this.priorities_;\n const element = elements[0];\n if (elements.length == 1) {\n elements.length = 0;\n priorities.length = 0;\n } else {\n elements[0] = /** @type {T} */ (elements.pop());\n priorities[0] = /** @type {number} */ (priorities.pop());\n this.siftUp_(0);\n }\n const elementKey = this.keyFunction_(element);\n delete this.queuedElements_[elementKey];\n return element;\n }\n\n /**\n * Enqueue an element. O(log N).\n * @param {T} element Element.\n * @return {boolean} The element was added to the queue.\n */\n enqueue(element) {\n assert(\n !(this.keyFunction_(element) in this.queuedElements_),\n 'Tried to enqueue an `element` that was already added to the queue',\n );\n const priority = this.priorityFunction_(element);\n if (priority != DROP) {\n this.elements_.push(element);\n this.priorities_.push(priority);\n this.queuedElements_[this.keyFunction_(element)] = true;\n this.siftDown_(0, this.elements_.length - 1);\n return true;\n }\n return false;\n }\n\n /**\n * @return {number} Count.\n */\n getCount() {\n return this.elements_.length;\n }\n\n /**\n * Gets the index of the left child of the node at the given index.\n * @param {number} index The index of the node to get the left child for.\n * @return {number} The index of the left child.\n * @private\n */\n getLeftChildIndex_(index) {\n return index * 2 + 1;\n }\n\n /**\n * Gets the index of the right child of the node at the given index.\n * @param {number} index The index of the node to get the right child for.\n * @return {number} The index of the right child.\n * @private\n */\n getRightChildIndex_(index) {\n return index * 2 + 2;\n }\n\n /**\n * Gets the index of the parent of the node at the given index.\n * @param {number} index The index of the node to get the parent for.\n * @return {number} The index of the parent.\n * @private\n */\n getParentIndex_(index) {\n return (index - 1) >> 1;\n }\n\n /**\n * Make this a heap. O(N).\n * @private\n */\n heapify_() {\n let i;\n for (i = (this.elements_.length >> 1) - 1; i >= 0; i--) {\n this.siftUp_(i);\n }\n }\n\n /**\n * @return {boolean} Is empty.\n */\n isEmpty() {\n return this.elements_.length === 0;\n }\n\n /**\n * @param {string} key Key.\n * @return {boolean} Is key queued.\n */\n isKeyQueued(key) {\n return key in this.queuedElements_;\n }\n\n /**\n * @param {T} element Element.\n * @return {boolean} Is queued.\n */\n isQueued(element) {\n return this.isKeyQueued(this.keyFunction_(element));\n }\n\n /**\n * @param {number} index The index of the node to move down.\n * @private\n */\n siftUp_(index) {\n const elements = this.elements_;\n const priorities = this.priorities_;\n const count = elements.length;\n const element = elements[index];\n const priority = priorities[index];\n const startIndex = index;\n\n while (index < count >> 1) {\n const lIndex = this.getLeftChildIndex_(index);\n const rIndex = this.getRightChildIndex_(index);\n\n const smallerChildIndex =\n rIndex < count && priorities[rIndex] < priorities[lIndex]\n ? rIndex\n : lIndex;\n\n elements[index] = elements[smallerChildIndex];\n priorities[index] = priorities[smallerChildIndex];\n index = smallerChildIndex;\n }\n\n elements[index] = element;\n priorities[index] = priority;\n this.siftDown_(startIndex, index);\n }\n\n /**\n * @param {number} startIndex The index of the root.\n * @param {number} index The index of the node to move up.\n * @private\n */\n siftDown_(startIndex, index) {\n const elements = this.elements_;\n const priorities = this.priorities_;\n const element = elements[index];\n const priority = priorities[index];\n\n while (index > startIndex) {\n const parentIndex = this.getParentIndex_(index);\n if (priorities[parentIndex] > priority) {\n elements[index] = elements[parentIndex];\n priorities[index] = priorities[parentIndex];\n index = parentIndex;\n } else {\n break;\n }\n }\n elements[index] = element;\n priorities[index] = priority;\n }\n\n /**\n * FIXME empty description for jsdoc\n */\n reprioritize() {\n const priorityFunction = this.priorityFunction_;\n const elements = this.elements_;\n const priorities = this.priorities_;\n let index = 0;\n const n = elements.length;\n let element, i, priority;\n for (i = 0; i < n; ++i) {\n element = elements[i];\n priority = priorityFunction(element);\n if (priority == DROP) {\n delete this.queuedElements_[this.keyFunction_(element)];\n } else {\n priorities[index] = priority;\n elements[index++] = element;\n }\n }\n elements.length = index;\n priorities.length = index;\n this.heapify_();\n }\n}\n\nexport default PriorityQueue;\n","/**\n * @module ol/TileQueue\n */\nimport EventType from './events/EventType.js';\nimport PriorityQueue, {DROP} from './structs/PriorityQueue.js';\nimport TileState from './TileState.js';\n\n/**\n * @typedef {function(import(\"./Tile.js\").default, string, import(\"./coordinate.js\").Coordinate, number): number} PriorityFunction\n */\n\nclass TileQueue extends PriorityQueue {\n /**\n * @param {PriorityFunction} tilePriorityFunction Tile priority function.\n * @param {function(): ?} tileChangeCallback Function called on each tile change event.\n */\n constructor(tilePriorityFunction, tileChangeCallback) {\n super(\n /**\n * @param {Array} element Element.\n * @return {number} Priority.\n */\n function (element) {\n return tilePriorityFunction.apply(null, element);\n },\n /**\n * @param {Array} element Element.\n * @return {string} Key.\n */\n function (element) {\n return /** @type {import(\"./Tile.js\").default} */ (element[0]).getKey();\n },\n );\n\n /** @private */\n this.boundHandleTileChange_ = this.handleTileChange.bind(this);\n\n /**\n * @private\n * @type {function(): ?}\n */\n this.tileChangeCallback_ = tileChangeCallback;\n\n /**\n * @private\n * @type {number}\n */\n this.tilesLoading_ = 0;\n\n /**\n * @private\n * @type {!Object}\n */\n this.tilesLoadingKeys_ = {};\n }\n\n /**\n * @param {Array} element Element.\n * @return {boolean} The element was added to the queue.\n * @override\n */\n enqueue(element) {\n const added = super.enqueue(element);\n if (added) {\n const tile = element[0];\n tile.addEventListener(EventType.CHANGE, this.boundHandleTileChange_);\n }\n return added;\n }\n\n /**\n * @return {number} Number of tiles loading.\n */\n getTilesLoading() {\n return this.tilesLoading_;\n }\n\n /**\n * @param {import(\"./events/Event.js\").default} event Event.\n * @protected\n */\n handleTileChange(event) {\n const tile = /** @type {import(\"./Tile.js\").default} */ (event.target);\n const state = tile.getState();\n if (\n state === TileState.LOADED ||\n state === TileState.ERROR ||\n state === TileState.EMPTY\n ) {\n if (state !== TileState.ERROR) {\n tile.removeEventListener(EventType.CHANGE, this.boundHandleTileChange_);\n }\n const tileKey = tile.getKey();\n if (tileKey in this.tilesLoadingKeys_) {\n delete this.tilesLoadingKeys_[tileKey];\n --this.tilesLoading_;\n }\n this.tileChangeCallback_();\n }\n }\n\n /**\n * @param {number} maxTotalLoading Maximum number tiles to load simultaneously.\n * @param {number} maxNewLoads Maximum number of new tiles to load.\n */\n loadMoreTiles(maxTotalLoading, maxNewLoads) {\n let newLoads = 0;\n while (\n this.tilesLoading_ < maxTotalLoading &&\n newLoads < maxNewLoads &&\n this.getCount() > 0\n ) {\n /**\n * @type {import(\"./Tile.js\").default}\n */\n const tile = this.dequeue()[0];\n const tileKey = tile.getKey();\n const state = tile.getState();\n if (state === TileState.IDLE && !(tileKey in this.tilesLoadingKeys_)) {\n this.tilesLoadingKeys_[tileKey] = true;\n ++this.tilesLoading_;\n ++newLoads;\n tile.load();\n }\n }\n }\n}\n\nexport default TileQueue;\n\n/**\n * @param {import('./Map.js').FrameState} frameState Frame state.\n * @param {import(\"./Tile.js\").default} tile Tile.\n * @param {string} tileSourceKey Tile source key.\n * @param {import(\"./coordinate.js\").Coordinate} tileCenter Tile center.\n * @param {number} tileResolution Tile resolution.\n * @return {number} Tile priority.\n */\nexport function getTilePriority(\n frameState,\n tile,\n tileSourceKey,\n tileCenter,\n tileResolution,\n) {\n // Filter out tiles at higher zoom levels than the current zoom level, or that\n // are outside the visible extent.\n if (!frameState || !(tileSourceKey in frameState.wantedTiles)) {\n return DROP;\n }\n if (!frameState.wantedTiles[tileSourceKey][tile.getKey()]) {\n return DROP;\n }\n // Prioritize the highest zoom level tiles closest to the focus.\n // Tiles at higher zoom levels are prioritized using Math.log(tileResolution).\n // Within a zoom level, tiles are prioritized by the distance in pixels between\n // the center of the tile and the center of the viewport. The factor of 65536\n // means that the prioritization should behave as desired for tiles up to\n // 65536 * Math.log(2) = 45426 pixels from the focus.\n const center = frameState.viewState.center;\n const deltaX = tileCenter[0] - center[0];\n const deltaY = tileCenter[1] - center[1];\n return (\n 65536 * Math.log(tileResolution) +\n Math.sqrt(deltaX * deltaX + deltaY * deltaY) / tileResolution\n );\n}\n","/**\n * @module ol/TileRange\n */\n\n/**\n * A representation of a contiguous block of tiles. A tile range is specified\n * by its min/max tile coordinates and is inclusive of coordinates.\n */\nclass TileRange {\n /**\n * @param {number} minX Minimum X.\n * @param {number} maxX Maximum X.\n * @param {number} minY Minimum Y.\n * @param {number} maxY Maximum Y.\n */\n constructor(minX, maxX, minY, maxY) {\n /**\n * @type {number}\n */\n this.minX = minX;\n\n /**\n * @type {number}\n */\n this.maxX = maxX;\n\n /**\n * @type {number}\n */\n this.minY = minY;\n\n /**\n * @type {number}\n */\n this.maxY = maxY;\n }\n\n /**\n * @param {import(\"./tilecoord.js\").TileCoord} tileCoord Tile coordinate.\n * @return {boolean} Contains tile coordinate.\n */\n contains(tileCoord) {\n return this.containsXY(tileCoord[1], tileCoord[2]);\n }\n\n /**\n * @param {TileRange} tileRange Tile range.\n * @return {boolean} Contains.\n */\n containsTileRange(tileRange) {\n return (\n this.minX <= tileRange.minX &&\n tileRange.maxX <= this.maxX &&\n this.minY <= tileRange.minY &&\n tileRange.maxY <= this.maxY\n );\n }\n\n /**\n * @param {number} x Tile coordinate x.\n * @param {number} y Tile coordinate y.\n * @return {boolean} Contains coordinate.\n */\n containsXY(x, y) {\n return this.minX <= x && x <= this.maxX && this.minY <= y && y <= this.maxY;\n }\n\n /**\n * @param {TileRange} tileRange Tile range.\n * @return {boolean} Equals.\n */\n equals(tileRange) {\n return (\n this.minX == tileRange.minX &&\n this.minY == tileRange.minY &&\n this.maxX == tileRange.maxX &&\n this.maxY == tileRange.maxY\n );\n }\n\n /**\n * @param {TileRange} tileRange Tile range.\n */\n extend(tileRange) {\n if (tileRange.minX < this.minX) {\n this.minX = tileRange.minX;\n }\n if (tileRange.maxX > this.maxX) {\n this.maxX = tileRange.maxX;\n }\n if (tileRange.minY < this.minY) {\n this.minY = tileRange.minY;\n }\n if (tileRange.maxY > this.maxY) {\n this.maxY = tileRange.maxY;\n }\n }\n\n /**\n * @return {number} Height.\n */\n getHeight() {\n return this.maxY - this.minY + 1;\n }\n\n /**\n * @return {import(\"./size.js\").Size} Size.\n */\n getSize() {\n return [this.getWidth(), this.getHeight()];\n }\n\n /**\n * @return {number} Width.\n */\n getWidth() {\n return this.maxX - this.minX + 1;\n }\n\n /**\n * @param {TileRange} tileRange Tile range.\n * @return {boolean} Intersects.\n */\n intersects(tileRange) {\n return (\n this.minX <= tileRange.maxX &&\n this.maxX >= tileRange.minX &&\n this.minY <= tileRange.maxY &&\n this.maxY >= tileRange.minY\n );\n }\n}\n\n/**\n * @param {number} minX Minimum X.\n * @param {number} maxX Maximum X.\n * @param {number} minY Minimum Y.\n * @param {number} maxY Maximum Y.\n * @param {TileRange} [tileRange] TileRange.\n * @return {TileRange} Tile range.\n */\nexport function createOrUpdate(minX, maxX, minY, maxY, tileRange) {\n if (tileRange !== undefined) {\n tileRange.minX = minX;\n tileRange.maxX = maxX;\n tileRange.minY = minY;\n tileRange.maxY = maxY;\n return tileRange;\n }\n return new TileRange(minX, maxX, minY, maxY);\n}\n\nexport default TileRange;\n","/**\n * @module ol/TileState\n */\n\n/**\n * @enum {number}\n */\nexport default {\n IDLE: 0,\n LOADING: 1,\n LOADED: 2,\n /**\n * Indicates that tile loading failed\n * @type {number}\n */\n ERROR: 3,\n EMPTY: 4,\n};\n","/**\n * @module ol/ViewProperty\n */\n\n/**\n * @enum {string}\n */\nexport default {\n CENTER: 'center',\n RESOLUTION: 'resolution',\n ROTATION: 'rotation',\n};\n","/**\n * @module ol/centerconstraint\n */\nimport {clamp} from './math.js';\n\n/**\n * @typedef {function((import(\"./coordinate.js\").Coordinate|undefined), number, import(\"./size.js\").Size, boolean=, Array=): (import(\"./coordinate.js\").Coordinate|undefined)} Type\n */\n\n/**\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {boolean} onlyCenter If true, the constraint will only apply to the view center.\n * @param {boolean} smooth If true, the view will be able to go slightly out of the given extent\n * (only during interaction and animation).\n * @return {Type} The constraint.\n */\nexport function createExtent(extent, onlyCenter, smooth) {\n return (\n /**\n * @param {import(\"./coordinate.js\").Coordinate|undefined} center Center.\n * @param {number|undefined} resolution Resolution.\n * @param {import(\"./size.js\").Size} size Viewport size; unused if `onlyCenter` was specified.\n * @param {boolean} [isMoving] True if an interaction or animation is in progress.\n * @param {Array} [centerShift] Shift between map center and viewport center.\n * @return {import(\"./coordinate.js\").Coordinate|undefined} Center.\n */\n function (center, resolution, size, isMoving, centerShift) {\n if (!center) {\n return undefined;\n }\n if (!resolution && !onlyCenter) {\n return center;\n }\n const viewWidth = onlyCenter ? 0 : size[0] * resolution;\n const viewHeight = onlyCenter ? 0 : size[1] * resolution;\n const shiftX = centerShift ? centerShift[0] : 0;\n const shiftY = centerShift ? centerShift[1] : 0;\n let minX = extent[0] + viewWidth / 2 + shiftX;\n let maxX = extent[2] - viewWidth / 2 + shiftX;\n let minY = extent[1] + viewHeight / 2 + shiftY;\n let maxY = extent[3] - viewHeight / 2 + shiftY;\n\n // note: when zooming out of bounds, min and max values for x and y may\n // end up inverted (min > max); this has to be accounted for\n if (minX > maxX) {\n minX = (maxX + minX) / 2;\n maxX = minX;\n }\n if (minY > maxY) {\n minY = (maxY + minY) / 2;\n maxY = minY;\n }\n\n let x = clamp(center[0], minX, maxX);\n let y = clamp(center[1], minY, maxY);\n\n // during an interaction, allow some overscroll\n if (isMoving && smooth && resolution) {\n const ratio = 30 * resolution;\n x +=\n -ratio * Math.log(1 + Math.max(0, minX - center[0]) / ratio) +\n ratio * Math.log(1 + Math.max(0, center[0] - maxX) / ratio);\n y +=\n -ratio * Math.log(1 + Math.max(0, minY - center[1]) / ratio) +\n ratio * Math.log(1 + Math.max(0, center[1] - maxY) / ratio);\n }\n\n return [x, y];\n }\n );\n}\n\n/**\n * @param {import(\"./coordinate.js\").Coordinate} [center] Center.\n * @return {import(\"./coordinate.js\").Coordinate|undefined} Center.\n */\nexport function none(center) {\n return center;\n}\n","/**\n * @module ol/resolutionconstraint\n */\nimport {clamp} from './math.js';\nimport {getHeight, getWidth} from './extent.js';\nimport {linearFindNearest} from './array.js';\n\n/**\n * @typedef {function((number|undefined), number, import(\"./size.js\").Size, boolean=): (number|undefined)} Type\n */\n\n/**\n * Returns a modified resolution taking into account the viewport size and maximum\n * allowed extent.\n * @param {number} resolution Resolution\n * @param {import(\"./extent.js\").Extent} maxExtent Maximum allowed extent.\n * @param {import(\"./size.js\").Size} viewportSize Viewport size.\n * @param {boolean} showFullExtent Whether to show the full extent.\n * @return {number} Capped resolution.\n */\nfunction getViewportClampedResolution(\n resolution,\n maxExtent,\n viewportSize,\n showFullExtent,\n) {\n const xResolution = getWidth(maxExtent) / viewportSize[0];\n const yResolution = getHeight(maxExtent) / viewportSize[1];\n\n if (showFullExtent) {\n return Math.min(resolution, Math.max(xResolution, yResolution));\n }\n return Math.min(resolution, Math.min(xResolution, yResolution));\n}\n\n/**\n * Returns a modified resolution to be between maxResolution and minResolution while\n * still allowing the value to be slightly out of bounds.\n * Note: the computation is based on the logarithm function (ln):\n * - at 1, ln(x) is 0\n * - above 1, ln(x) keeps increasing but at a much slower pace than x\n * The final result is clamped to prevent getting too far away from bounds.\n * @param {number} resolution Resolution.\n * @param {number} maxResolution Max resolution.\n * @param {number} minResolution Min resolution.\n * @return {number} Smoothed resolution.\n */\nfunction getSmoothClampedResolution(resolution, maxResolution, minResolution) {\n let result = Math.min(resolution, maxResolution);\n const ratio = 50;\n\n result *=\n Math.log(1 + ratio * Math.max(0, resolution / maxResolution - 1)) / ratio +\n 1;\n if (minResolution) {\n result = Math.max(result, minResolution);\n result /=\n Math.log(1 + ratio * Math.max(0, minResolution / resolution - 1)) /\n ratio +\n 1;\n }\n return clamp(result, minResolution / 2, maxResolution * 2);\n}\n\n/**\n * @param {Array} resolutions Resolutions.\n * @param {boolean} [smooth] If true, the view will be able to slightly exceed resolution limits. Default: true.\n * @param {import(\"./extent.js\").Extent} [maxExtent] Maximum allowed extent.\n * @param {boolean} [showFullExtent] If true, allows us to show the full extent. Default: false.\n * @return {Type} Zoom function.\n */\nexport function createSnapToResolutions(\n resolutions,\n smooth,\n maxExtent,\n showFullExtent,\n) {\n smooth = smooth !== undefined ? smooth : true;\n return (\n /**\n * @param {number|undefined} resolution Resolution.\n * @param {number} direction Direction.\n * @param {import(\"./size.js\").Size} size Viewport size.\n * @param {boolean} [isMoving] True if an interaction or animation is in progress.\n * @return {number|undefined} Resolution.\n */\n function (resolution, direction, size, isMoving) {\n if (resolution !== undefined) {\n const maxResolution = resolutions[0];\n const minResolution = resolutions[resolutions.length - 1];\n const cappedMaxRes = maxExtent\n ? getViewportClampedResolution(\n maxResolution,\n maxExtent,\n size,\n showFullExtent,\n )\n : maxResolution;\n\n // during interacting or animating, allow intermediary values\n if (isMoving) {\n if (!smooth) {\n return clamp(resolution, minResolution, cappedMaxRes);\n }\n return getSmoothClampedResolution(\n resolution,\n cappedMaxRes,\n minResolution,\n );\n }\n\n const capped = Math.min(cappedMaxRes, resolution);\n const z = Math.floor(linearFindNearest(resolutions, capped, direction));\n if (resolutions[z] > cappedMaxRes && z < resolutions.length - 1) {\n return resolutions[z + 1];\n }\n return resolutions[z];\n }\n return undefined;\n }\n );\n}\n\n/**\n * @param {number} power Power.\n * @param {number} maxResolution Maximum resolution.\n * @param {number} [minResolution] Minimum resolution.\n * @param {boolean} [smooth] If true, the view will be able to slightly exceed resolution limits. Default: true.\n * @param {import(\"./extent.js\").Extent} [maxExtent] Maximum allowed extent.\n * @param {boolean} [showFullExtent] If true, allows us to show the full extent. Default: false.\n * @return {Type} Zoom function.\n */\nexport function createSnapToPower(\n power,\n maxResolution,\n minResolution,\n smooth,\n maxExtent,\n showFullExtent,\n) {\n smooth = smooth !== undefined ? smooth : true;\n minResolution = minResolution !== undefined ? minResolution : 0;\n\n return (\n /**\n * @param {number|undefined} resolution Resolution.\n * @param {number} direction Direction.\n * @param {import(\"./size.js\").Size} size Viewport size.\n * @param {boolean} [isMoving] True if an interaction or animation is in progress.\n * @return {number|undefined} Resolution.\n */\n function (resolution, direction, size, isMoving) {\n if (resolution !== undefined) {\n const cappedMaxRes = maxExtent\n ? getViewportClampedResolution(\n maxResolution,\n maxExtent,\n size,\n showFullExtent,\n )\n : maxResolution;\n\n // during interacting or animating, allow intermediary values\n if (isMoving) {\n if (!smooth) {\n return clamp(resolution, minResolution, cappedMaxRes);\n }\n return getSmoothClampedResolution(\n resolution,\n cappedMaxRes,\n minResolution,\n );\n }\n\n const tolerance = 1e-9;\n const minZoomLevel = Math.ceil(\n Math.log(maxResolution / cappedMaxRes) / Math.log(power) - tolerance,\n );\n const offset = -direction * (0.5 - tolerance) + 0.5;\n const capped = Math.min(cappedMaxRes, resolution);\n const cappedZoomLevel = Math.floor(\n Math.log(maxResolution / capped) / Math.log(power) + offset,\n );\n const zoomLevel = Math.max(minZoomLevel, cappedZoomLevel);\n const newResolution = maxResolution / Math.pow(power, zoomLevel);\n return clamp(newResolution, minResolution, cappedMaxRes);\n }\n return undefined;\n }\n );\n}\n\n/**\n * @param {number} maxResolution Max resolution.\n * @param {number} minResolution Min resolution.\n * @param {boolean} [smooth] If true, the view will be able to slightly exceed resolution limits. Default: true.\n * @param {import(\"./extent.js\").Extent} [maxExtent] Maximum allowed extent.\n * @param {boolean} [showFullExtent] If true, allows us to show the full extent. Default: false.\n * @return {Type} Zoom function.\n */\nexport function createMinMaxResolution(\n maxResolution,\n minResolution,\n smooth,\n maxExtent,\n showFullExtent,\n) {\n smooth = smooth !== undefined ? smooth : true;\n\n return (\n /**\n * @param {number|undefined} resolution Resolution.\n * @param {number} direction Direction.\n * @param {import(\"./size.js\").Size} size Viewport size.\n * @param {boolean} [isMoving] True if an interaction or animation is in progress.\n * @return {number|undefined} Resolution.\n */\n function (resolution, direction, size, isMoving) {\n if (resolution !== undefined) {\n const cappedMaxRes = maxExtent\n ? getViewportClampedResolution(\n maxResolution,\n maxExtent,\n size,\n showFullExtent,\n )\n : maxResolution;\n\n if (!smooth || !isMoving) {\n return clamp(resolution, minResolution, cappedMaxRes);\n }\n return getSmoothClampedResolution(\n resolution,\n cappedMaxRes,\n minResolution,\n );\n }\n return undefined;\n }\n );\n}\n","/**\n * @module ol/View\n */\nimport BaseObject from './Object.js';\nimport ViewHint from './ViewHint.js';\nimport ViewProperty from './ViewProperty.js';\nimport {DEFAULT_TILE_SIZE} from './tilegrid/common.js';\nimport {\n METERS_PER_UNIT,\n createProjection,\n disableCoordinateWarning,\n fromUserCoordinate,\n fromUserExtent,\n getUserProjection,\n toUserCoordinate,\n toUserExtent,\n} from './proj.js';\nimport {VOID} from './functions.js';\nimport {\n add as addCoordinate,\n equals as coordinatesEqual,\n equals,\n rotate as rotateCoordinate,\n} from './coordinate.js';\nimport {assert} from './asserts.js';\nimport {none as centerNone, createExtent} from './centerconstraint.js';\nimport {clamp, modulo} from './math.js';\nimport {\n createMinMaxResolution,\n createSnapToPower,\n createSnapToResolutions,\n} from './resolutionconstraint.js';\nimport {\n createSnapToN,\n createSnapToZero,\n disable,\n none as rotationNone,\n} from './rotationconstraint.js';\nimport {easeOut, inAndOut} from './easing.js';\nimport {\n getCenter,\n getForViewAndSize,\n getHeight,\n getWidth,\n isEmpty,\n} from './extent.js';\nimport {linearFindNearest} from './array.js';\nimport {fromExtent as polygonFromExtent} from './geom/Polygon.js';\n\n/**\n * An animation configuration\n *\n * @typedef {Object} Animation\n * @property {import(\"./coordinate.js\").Coordinate} [sourceCenter] Source center.\n * @property {import(\"./coordinate.js\").Coordinate} [targetCenter] Target center.\n * @property {number} [sourceResolution] Source resolution.\n * @property {number} [targetResolution] Target resolution.\n * @property {number} [sourceRotation] Source rotation.\n * @property {number} [targetRotation] Target rotation.\n * @property {import(\"./coordinate.js\").Coordinate} [anchor] Anchor.\n * @property {number} start Start.\n * @property {number} duration Duration.\n * @property {boolean} complete Complete.\n * @property {function(number):number} easing Easing.\n * @property {function(boolean):void} callback Callback.\n */\n\n/**\n * @typedef {Object} Constraints\n * @property {import(\"./centerconstraint.js\").Type} center Center.\n * @property {import(\"./resolutionconstraint.js\").Type} resolution Resolution.\n * @property {import(\"./rotationconstraint.js\").Type} rotation Rotation.\n */\n\n/**\n * @typedef {Object} FitOptions\n * @property {import(\"./size.js\").Size} [size] The size in pixels of the box to\n * fit the extent into. Defaults to the size of the map the view is associated with.\n * If no map or multiple maps are connected to the view, provide the desired box size\n * (e.g. `map.getSize()`).\n * @property {!Array} [padding=[0, 0, 0, 0]] Padding (in pixels) to be\n * cleared inside the view. Values in the array are top, right, bottom and left\n * padding.\n * @property {boolean} [nearest=false] If the view `constrainResolution` option is `true`,\n * get the nearest extent instead of the closest that actually fits the view.\n * @property {number} [minResolution=0] Minimum resolution that we zoom to.\n * @property {number} [maxZoom] Maximum zoom level that we zoom to. If\n * `minResolution` is given, this property is ignored.\n * @property {number} [duration] The duration of the animation in milliseconds.\n * By default, there is no animation to the target extent.\n * @property {function(number):number} [easing] The easing function used during\n * the animation (defaults to {@link module:ol/easing.inAndOut}).\n * The function will be called for each frame with a number representing a\n * fraction of the animation's duration. The function should return a number\n * between 0 and 1 representing the progress toward the destination state.\n * @property {function(boolean):void} [callback] Function called when the view is in\n * its final position. The callback will be called with `true` if the animation\n * series completed on its own or `false` if it was cancelled.\n */\n\n/**\n * @typedef {Object} ViewOptions\n * @property {import(\"./coordinate.js\").Coordinate} [center] The initial center for\n * the view. If a user projection is not set, the coordinate system for the center is\n * specified with the `projection` option. Layer sources will not be fetched if this\n * is not set, but the center can be set later with {@link #setCenter}.\n * @property {boolean|number} [constrainRotation=true] Rotation constraint.\n * `false` means no constraint. `true` means no constraint, but snap to zero\n * near zero. A number constrains the rotation to that number of values. For\n * example, `4` will constrain the rotation to 0, 90, 180, and 270 degrees.\n * @property {boolean} [enableRotation=true] Enable rotation.\n * If `false`, a rotation constraint that always sets the rotation to zero is\n * used. The `constrainRotation` option has no effect if `enableRotation` is\n * `false`.\n * @property {import(\"./extent.js\").Extent} [extent] The extent that constrains the\n * view, in other words, nothing outside of this extent can be visible on the map.\n * @property {boolean} [constrainOnlyCenter=false] If true, the extent\n * constraint will only apply to the view center and not the whole extent.\n * @property {boolean} [smoothExtentConstraint=true] If true, the extent\n * constraint will be applied smoothly, i.e. allow the view to go slightly outside\n * of the given `extent`.\n * @property {number} [maxResolution] The maximum resolution used to determine\n * the resolution constraint. It is used together with `minResolution` (or\n * `maxZoom`) and `zoomFactor`. If unspecified it is calculated in such a way\n * that the projection's validity extent fits in a 256x256 px tile. If the\n * projection is Spherical Mercator (the default) then `maxResolution` defaults\n * to `40075016.68557849 / 256 = 156543.03392804097`.\n * @property {number} [minResolution] The minimum resolution used to determine\n * the resolution constraint. It is used together with `maxResolution` (or\n * `minZoom`) and `zoomFactor`. If unspecified it is calculated assuming 29\n * zoom levels (with a factor of 2). If the projection is Spherical Mercator\n * (the default) then `minResolution` defaults to\n * `40075016.68557849 / 256 / Math.pow(2, 28) = 0.0005831682455839253`.\n * @property {number} [maxZoom=28] The maximum zoom level used to determine the\n * resolution constraint. It is used together with `minZoom` (or\n * `maxResolution`) and `zoomFactor`. Note that if `minResolution` is also\n * provided, it is given precedence over `maxZoom`.\n * @property {number} [minZoom=0] The minimum zoom level used to determine the\n * resolution constraint. It is used together with `maxZoom` (or\n * `minResolution`) and `zoomFactor`. Note that if `maxResolution` is also\n * provided, it is given precedence over `minZoom`.\n * @property {boolean} [multiWorld=false] If `false` the view is constrained so\n * only one world is visible, and you cannot pan off the edge. If `true` the map\n * may show multiple worlds at low zoom levels. Only used if the `projection` is\n * global. Note that if `extent` is also provided it is given precedence.\n * @property {boolean} [constrainResolution=false] If true, the view will always\n * animate to the closest zoom level after an interaction; false means\n * intermediary zoom levels are allowed.\n * @property {boolean} [smoothResolutionConstraint=true] If true, the resolution\n * min/max values will be applied smoothly, i. e. allow the view to exceed slightly\n * the given resolution or zoom bounds.\n * @property {boolean} [showFullExtent=false] Allow the view to be zoomed out to\n * show the full configured extent. By default, when a view is configured with an\n * extent, users will not be able to zoom out so the viewport exceeds the extent in\n * either dimension. This means the full extent may not be visible if the viewport\n * is taller or wider than the aspect ratio of the configured extent. If\n * showFullExtent is true, the user will be able to zoom out so that the viewport\n * exceeds the height or width of the configured extent, but not both, allowing the\n * full extent to be shown.\n * @property {import(\"./proj.js\").ProjectionLike} [projection='EPSG:3857'] The\n * projection. The default is Spherical Mercator.\n * @property {number} [resolution] The initial resolution for the view. The\n * units are `projection` units per pixel (e.g. meters per pixel). An\n * alternative to setting this is to set `zoom`. Layer sources will not be\n * fetched if neither this nor `zoom` are defined, but they can be set later\n * with {@link #setZoom} or {@link #setResolution}.\n * @property {Array} [resolutions] Resolutions that determine the\n * zoom levels if specified. The index in the array corresponds to the zoom level,\n * therefore the resolution values have to be in descending order. It also constrains\n * the resolution by the minimum and maximum value. If set the `maxResolution`,\n * `minResolution`, `minZoom`, `maxZoom`, and `zoomFactor` options are ignored.\n * @property {number} [rotation=0] The initial rotation for the view in radians\n * (positive rotation clockwise, 0 means North).\n * @property {number} [zoom] Only used if `resolution` is not defined. Zoom\n * level used to calculate the initial resolution for the view.\n * @property {number} [zoomFactor=2] The zoom factor used to compute the\n * corresponding resolution.\n * @property {!Array} [padding=[0, 0, 0, 0]] Padding (in css pixels).\n * If the map viewport is partially covered with other content (overlays) along\n * its edges, this setting allows to shift the center of the viewport away from\n * that content. The order of the values is top, right, bottom, left.\n */\n\n/**\n * @typedef {Object} AnimationOptions\n * @property {import(\"./coordinate.js\").Coordinate} [center] The center of the view at the end of\n * the animation.\n * @property {number} [zoom] The zoom level of the view at the end of the\n * animation. This takes precedence over `resolution`.\n * @property {number} [resolution] The resolution of the view at the end\n * of the animation. If `zoom` is also provided, this option will be ignored.\n * @property {number} [rotation] The rotation of the view at the end of\n * the animation.\n * @property {import(\"./coordinate.js\").Coordinate} [anchor] Optional anchor to remain fixed\n * during a rotation or resolution animation.\n * @property {number} [duration=1000] The duration of the animation in milliseconds.\n * @property {function(number):number} [easing] The easing function used\n * during the animation (defaults to {@link module:ol/easing.inAndOut}).\n * The function will be called for each frame with a number representing a\n * fraction of the animation's duration. The function should return a number\n * between 0 and 1 representing the progress toward the destination state.\n */\n\n/**\n * @typedef {Object} State\n * @property {import(\"./coordinate.js\").Coordinate} center Center (in view projection coordinates).\n * @property {import(\"./proj/Projection.js\").default} projection Projection.\n * @property {number} resolution Resolution.\n * @property {import(\"./coordinate.js\").Coordinate} [nextCenter] The next center during an animation series.\n * @property {number} [nextResolution] The next resolution during an animation series.\n * @property {number} [nextRotation] The next rotation during an animation series.\n * @property {number} rotation Rotation.\n * @property {number} zoom Zoom.\n */\n\n/**\n * Like {@link import(\"./Map.js\").FrameState}, but just `viewState` and `extent`.\n * @typedef {Object} ViewStateLayerStateExtent\n * @property {State} viewState View state.\n * @property {import(\"./extent.js\").Extent} extent Extent (in user projection coordinates).\n * @property {Array} [layerStatesArray] Layer states.\n */\n\n/**\n * Default min zoom level for the map view.\n * @type {number}\n */\nconst DEFAULT_MIN_ZOOM = 0;\n\n/**\n * @typedef {import(\"./ObjectEventType\").Types|'change:center'|'change:resolution'|'change:rotation'} ViewObjectEventTypes\n */\n\n/***\n * @template Return\n * @typedef {import(\"./Observable\").OnSignature &\n * import(\"./Observable\").OnSignature &\n * import(\"./Observable\").CombinedOnSignature} ViewOnSignature\n */\n\n/**\n * @classdesc\n * A View object represents a simple 2D view of the map.\n *\n * This is the object to act upon to change the center, resolution,\n * and rotation of the map.\n *\n * A View has a `projection`. The projection determines the\n * coordinate system of the center, and its units determine the units of the\n * resolution (projection units per pixel). The default projection is\n * Web Mercator (EPSG:3857).\n *\n * ### The view states\n *\n * A View is determined by three states: `center`, `resolution`,\n * and `rotation`. Each state has a corresponding getter and setter, e.g.\n * `getCenter` and `setCenter` for the `center` state.\n *\n * The `zoom` state is actually not saved on the view: all computations\n * internally use the `resolution` state. Still, the `setZoom` and `getZoom`\n * methods are available, as well as `getResolutionForZoom` and\n * `getZoomForResolution` to switch from one system to the other.\n *\n * ### The constraints\n *\n * `setCenter`, `setResolution` and `setRotation` can be used to change the\n * states of the view, but any constraint defined in the constructor will\n * be applied along the way.\n *\n * A View object can have a *resolution constraint*, a *rotation constraint*\n * and a *center constraint*.\n *\n * The *resolution constraint* typically restricts min/max values and\n * snaps to specific resolutions. It is determined by the following\n * options: `resolutions`, `maxResolution`, `maxZoom` and `zoomFactor`.\n * If `resolutions` is set, the other three options are ignored. See\n * documentation for each option for more information. By default, the view\n * only has a min/max restriction and allow intermediary zoom levels when\n * pinch-zooming for example.\n *\n * The *rotation constraint* snaps to specific angles. It is determined\n * by the following options: `enableRotation` and `constrainRotation`.\n * By default rotation is allowed and its value is snapped to zero when approaching the\n * horizontal.\n *\n * The *center constraint* is determined by the `extent` option. By\n * default the view center is not constrained at all.\n *\n * ### Changing the view state\n *\n * It is important to note that `setZoom`, `setResolution`, `setCenter` and\n * `setRotation` are subject to the above mentioned constraints. As such, it\n * may sometimes not be possible to know in advance the resulting state of the\n * View. For example, calling `setResolution(10)` does not guarantee that\n * `getResolution()` will return `10`.\n *\n * A consequence of this is that, when applying a delta on the view state, one\n * should use `adjustCenter`, `adjustRotation`, `adjustZoom` and `adjustResolution`\n * rather than the corresponding setters. This will let view do its internal\n * computations. Besides, the `adjust*` methods also take an `anchor`\n * argument which allows specifying an origin for the transformation.\n *\n * ### Interacting with the view\n *\n * View constraints are usually only applied when the view is *at rest*, meaning that\n * no interaction or animation is ongoing. As such, if the user puts the view in a\n * state that is not equivalent to a constrained one (e.g. rotating the view when\n * the snap angle is 0), an animation will be triggered at the interaction end to\n * put back the view to a stable state;\n *\n * @api\n */\nclass View extends BaseObject {\n /**\n * @param {ViewOptions} [options] View options.\n */\n constructor(options) {\n super();\n\n /***\n * @type {ViewOnSignature}\n */\n this.on;\n\n /***\n * @type {ViewOnSignature}\n */\n this.once;\n\n /***\n * @type {ViewOnSignature}\n */\n this.un;\n\n options = Object.assign({}, options);\n\n /**\n * @private\n * @type {Array}\n */\n this.hints_ = [0, 0];\n\n /**\n * @private\n * @type {Array>}\n */\n this.animations_ = [];\n\n /**\n * @private\n * @type {number|undefined}\n */\n this.updateAnimationKey_;\n\n /**\n * @private\n * @const\n * @type {import(\"./proj/Projection.js\").default}\n */\n this.projection_ = createProjection(options.projection, 'EPSG:3857');\n\n /**\n * @private\n * @type {import(\"./size.js\").Size}\n */\n this.viewportSize_ = [100, 100];\n\n /**\n * @private\n * @type {import(\"./coordinate.js\").Coordinate|undefined}\n */\n this.targetCenter_ = null;\n\n /**\n * @private\n * @type {number|undefined}\n */\n this.targetResolution_;\n\n /**\n * @private\n * @type {number|undefined}\n */\n this.targetRotation_;\n\n /**\n * @private\n * @type {import(\"./coordinate.js\").Coordinate}\n */\n this.nextCenter_ = null;\n\n /**\n * @private\n * @type {number}\n */\n this.nextResolution_;\n\n /**\n * @private\n * @type {number}\n */\n this.nextRotation_;\n\n /**\n * @private\n * @type {import(\"./coordinate.js\").Coordinate|undefined}\n */\n this.cancelAnchor_ = undefined;\n\n if (options.projection) {\n disableCoordinateWarning();\n }\n if (options.center) {\n options.center = fromUserCoordinate(options.center, this.projection_);\n }\n if (options.extent) {\n options.extent = fromUserExtent(options.extent, this.projection_);\n }\n\n this.applyOptions_(options);\n }\n\n /**\n * Set up the view with the given options.\n * @param {ViewOptions} options View options.\n */\n applyOptions_(options) {\n const properties = Object.assign({}, options);\n for (const key in ViewProperty) {\n delete properties[key];\n }\n this.setProperties(properties, true);\n\n const resolutionConstraintInfo = createResolutionConstraint(options);\n\n /**\n * @private\n * @type {number}\n */\n this.maxResolution_ = resolutionConstraintInfo.maxResolution;\n\n /**\n * @private\n * @type {number}\n */\n this.minResolution_ = resolutionConstraintInfo.minResolution;\n\n /**\n * @private\n * @type {number}\n */\n this.zoomFactor_ = resolutionConstraintInfo.zoomFactor;\n\n /**\n * @private\n * @type {Array|undefined}\n */\n this.resolutions_ = options.resolutions;\n\n /**\n * @type {Array|undefined}\n * @private\n */\n this.padding_ = options.padding;\n\n /**\n * @private\n * @type {number}\n */\n this.minZoom_ = resolutionConstraintInfo.minZoom;\n\n const centerConstraint = createCenterConstraint(options);\n const resolutionConstraint = resolutionConstraintInfo.constraint;\n const rotationConstraint = createRotationConstraint(options);\n\n /**\n * @private\n * @type {Constraints}\n */\n this.constraints_ = {\n center: centerConstraint,\n resolution: resolutionConstraint,\n rotation: rotationConstraint,\n };\n\n this.setRotation(options.rotation !== undefined ? options.rotation : 0);\n this.setCenterInternal(\n options.center !== undefined ? options.center : null,\n );\n if (options.resolution !== undefined) {\n this.setResolution(options.resolution);\n } else if (options.zoom !== undefined) {\n this.setZoom(options.zoom);\n }\n }\n\n /**\n * Padding (in css pixels).\n * If the map viewport is partially covered with other content (overlays) along\n * its edges, this setting allows to shift the center of the viewport away from that\n * content. The order of the values in the array is top, right, bottom, left.\n * The default is no padding, which is equivalent to `[0, 0, 0, 0]`.\n * @type {Array|undefined}\n * @api\n */\n get padding() {\n return this.padding_;\n }\n set padding(padding) {\n let oldPadding = this.padding_;\n this.padding_ = padding;\n const center = this.getCenterInternal();\n if (center) {\n const newPadding = padding || [0, 0, 0, 0];\n oldPadding = oldPadding || [0, 0, 0, 0];\n const resolution = this.getResolution();\n const offsetX =\n (resolution / 2) *\n (newPadding[3] - oldPadding[3] + oldPadding[1] - newPadding[1]);\n const offsetY =\n (resolution / 2) *\n (newPadding[0] - oldPadding[0] + oldPadding[2] - newPadding[2]);\n this.setCenterInternal([center[0] + offsetX, center[1] - offsetY]);\n }\n }\n\n /**\n * Get an updated version of the view options used to construct the view. The\n * current resolution (or zoom), center, and rotation are applied to any stored\n * options. The provided options can be used to apply new min/max zoom or\n * resolution limits.\n * @param {ViewOptions} newOptions New options to be applied.\n * @return {ViewOptions} New options updated with the current view state.\n */\n getUpdatedOptions_(newOptions) {\n const options = this.getProperties();\n\n // preserve resolution (or zoom)\n if (options.resolution !== undefined) {\n options.resolution = this.getResolution();\n } else {\n options.zoom = this.getZoom();\n }\n\n // preserve center\n options.center = this.getCenterInternal();\n\n // preserve rotation\n options.rotation = this.getRotation();\n\n return Object.assign({}, options, newOptions);\n }\n\n /**\n * Animate the view. The view's center, zoom (or resolution), and rotation\n * can be animated for smooth transitions between view states. For example,\n * to animate the view to a new zoom level:\n *\n * view.animate({zoom: view.getZoom() + 1});\n *\n * By default, the animation lasts one second and uses in-and-out easing. You\n * can customize this behavior by including `duration` (in milliseconds) and\n * `easing` options (see {@link module:ol/easing}).\n *\n * To chain together multiple animations, call the method with multiple\n * animation objects. For example, to first zoom and then pan:\n *\n * view.animate({zoom: 10}, {center: [0, 0]});\n *\n * If you provide a function as the last argument to the animate method, it\n * will get called at the end of an animation series. The callback will be\n * called with `true` if the animation series completed on its own or `false`\n * if it was cancelled.\n *\n * Animations are cancelled by user interactions (e.g. dragging the map) or by\n * calling `view.setCenter()`, `view.setResolution()`, or `view.setRotation()`\n * (or another method that calls one of these).\n *\n * @param {...(AnimationOptions|function(boolean): void)} var_args Animation\n * options. Multiple animations can be run in series by passing multiple\n * options objects. To run multiple animations in parallel, call the method\n * multiple times. An optional callback can be provided as a final\n * argument. The callback will be called with a boolean indicating whether\n * the animation completed without being cancelled.\n * @api\n */\n animate(var_args) {\n if (this.isDef() && !this.getAnimating()) {\n this.resolveConstraints(0);\n }\n const args = new Array(arguments.length);\n for (let i = 0; i < args.length; ++i) {\n let options = arguments[i];\n if (options.center) {\n options = Object.assign({}, options);\n options.center = fromUserCoordinate(\n options.center,\n this.getProjection(),\n );\n }\n if (options.anchor) {\n options = Object.assign({}, options);\n options.anchor = fromUserCoordinate(\n options.anchor,\n this.getProjection(),\n );\n }\n args[i] = options;\n }\n this.animateInternal.apply(this, args);\n }\n\n /**\n * @param {...(AnimationOptions|function(boolean): void)} var_args Animation options.\n */\n animateInternal(var_args) {\n let animationCount = arguments.length;\n let callback;\n if (\n animationCount > 1 &&\n typeof arguments[animationCount - 1] === 'function'\n ) {\n callback = arguments[animationCount - 1];\n --animationCount;\n }\n\n let i = 0;\n for (; i < animationCount && !this.isDef(); ++i) {\n // if view properties are not yet set, shortcut to the final state\n const state = arguments[i];\n if (state.center) {\n this.setCenterInternal(state.center);\n }\n if (state.zoom !== undefined) {\n this.setZoom(state.zoom);\n } else if (state.resolution) {\n this.setResolution(state.resolution);\n }\n if (state.rotation !== undefined) {\n this.setRotation(state.rotation);\n }\n }\n if (i === animationCount) {\n if (callback) {\n animationCallback(callback, true);\n }\n return;\n }\n\n let start = Date.now();\n let center = this.targetCenter_.slice();\n let resolution = this.targetResolution_;\n let rotation = this.targetRotation_;\n const series = [];\n for (; i < animationCount; ++i) {\n const options = /** @type {AnimationOptions} */ (arguments[i]);\n\n const animation = {\n start: start,\n complete: false,\n anchor: options.anchor,\n duration: options.duration !== undefined ? options.duration : 1000,\n easing: options.easing || inAndOut,\n callback: callback,\n };\n\n if (options.center) {\n animation.sourceCenter = center;\n animation.targetCenter = options.center.slice();\n center = animation.targetCenter;\n }\n\n if (options.zoom !== undefined) {\n animation.sourceResolution = resolution;\n animation.targetResolution = this.getResolutionForZoom(options.zoom);\n resolution = animation.targetResolution;\n } else if (options.resolution) {\n animation.sourceResolution = resolution;\n animation.targetResolution = options.resolution;\n resolution = animation.targetResolution;\n }\n\n if (options.rotation !== undefined) {\n animation.sourceRotation = rotation;\n const delta =\n modulo(options.rotation - rotation + Math.PI, 2 * Math.PI) - Math.PI;\n animation.targetRotation = rotation + delta;\n rotation = animation.targetRotation;\n }\n\n // check if animation is a no-op\n if (isNoopAnimation(animation)) {\n animation.complete = true;\n // we still push it onto the series for callback handling\n } else {\n start += animation.duration;\n }\n series.push(animation);\n }\n this.animations_.push(series);\n this.setHint(ViewHint.ANIMATING, 1);\n this.updateAnimations_();\n }\n\n /**\n * Determine if the view is being animated.\n * @return {boolean} The view is being animated.\n * @api\n */\n getAnimating() {\n return this.hints_[ViewHint.ANIMATING] > 0;\n }\n\n /**\n * Determine if the user is interacting with the view, such as panning or zooming.\n * @return {boolean} The view is being interacted with.\n * @api\n */\n getInteracting() {\n return this.hints_[ViewHint.INTERACTING] > 0;\n }\n\n /**\n * Cancel any ongoing animations.\n * @api\n */\n cancelAnimations() {\n this.setHint(ViewHint.ANIMATING, -this.hints_[ViewHint.ANIMATING]);\n let anchor;\n for (let i = 0, ii = this.animations_.length; i < ii; ++i) {\n const series = this.animations_[i];\n if (series[0].callback) {\n animationCallback(series[0].callback, false);\n }\n if (!anchor) {\n for (let j = 0, jj = series.length; j < jj; ++j) {\n const animation = series[j];\n if (!animation.complete) {\n anchor = animation.anchor;\n break;\n }\n }\n }\n }\n this.animations_.length = 0;\n this.cancelAnchor_ = anchor;\n this.nextCenter_ = null;\n this.nextResolution_ = NaN;\n this.nextRotation_ = NaN;\n }\n\n /**\n * Update all animations.\n */\n updateAnimations_() {\n if (this.updateAnimationKey_ !== undefined) {\n cancelAnimationFrame(this.updateAnimationKey_);\n this.updateAnimationKey_ = undefined;\n }\n if (!this.getAnimating()) {\n return;\n }\n const now = Date.now();\n let more = false;\n for (let i = this.animations_.length - 1; i >= 0; --i) {\n const series = this.animations_[i];\n let seriesComplete = true;\n for (let j = 0, jj = series.length; j < jj; ++j) {\n const animation = series[j];\n if (animation.complete) {\n continue;\n }\n const elapsed = now - animation.start;\n let fraction =\n animation.duration > 0 ? elapsed / animation.duration : 1;\n if (fraction >= 1) {\n animation.complete = true;\n fraction = 1;\n } else {\n seriesComplete = false;\n }\n const progress = animation.easing(fraction);\n if (animation.sourceCenter) {\n const x0 = animation.sourceCenter[0];\n const y0 = animation.sourceCenter[1];\n const x1 = animation.targetCenter[0];\n const y1 = animation.targetCenter[1];\n this.nextCenter_ = animation.targetCenter;\n const x = x0 + progress * (x1 - x0);\n const y = y0 + progress * (y1 - y0);\n this.targetCenter_ = [x, y];\n }\n if (animation.sourceResolution && animation.targetResolution) {\n const resolution =\n progress === 1\n ? animation.targetResolution\n : animation.sourceResolution +\n progress *\n (animation.targetResolution - animation.sourceResolution);\n if (animation.anchor) {\n const size = this.getViewportSize_(this.getRotation());\n const constrainedResolution = this.constraints_.resolution(\n resolution,\n 0,\n size,\n true,\n );\n this.targetCenter_ = this.calculateCenterZoom(\n constrainedResolution,\n animation.anchor,\n );\n }\n this.nextResolution_ = animation.targetResolution;\n this.targetResolution_ = resolution;\n this.applyTargetState_(true);\n }\n if (\n animation.sourceRotation !== undefined &&\n animation.targetRotation !== undefined\n ) {\n const rotation =\n progress === 1\n ? modulo(animation.targetRotation + Math.PI, 2 * Math.PI) -\n Math.PI\n : animation.sourceRotation +\n progress *\n (animation.targetRotation - animation.sourceRotation);\n if (animation.anchor) {\n const constrainedRotation = this.constraints_.rotation(\n rotation,\n true,\n );\n this.targetCenter_ = this.calculateCenterRotate(\n constrainedRotation,\n animation.anchor,\n );\n }\n this.nextRotation_ = animation.targetRotation;\n this.targetRotation_ = rotation;\n }\n this.applyTargetState_(true);\n more = true;\n if (!animation.complete) {\n break;\n }\n }\n if (seriesComplete) {\n this.animations_[i] = null;\n this.setHint(ViewHint.ANIMATING, -1);\n this.nextCenter_ = null;\n this.nextResolution_ = NaN;\n this.nextRotation_ = NaN;\n const callback = series[0].callback;\n if (callback) {\n animationCallback(callback, true);\n }\n }\n }\n // prune completed series\n this.animations_ = this.animations_.filter(Boolean);\n if (more && this.updateAnimationKey_ === undefined) {\n this.updateAnimationKey_ = requestAnimationFrame(\n this.updateAnimations_.bind(this),\n );\n }\n }\n\n /**\n * @param {number} rotation Target rotation.\n * @param {import(\"./coordinate.js\").Coordinate} anchor Rotation anchor.\n * @return {import(\"./coordinate.js\").Coordinate|undefined} Center for rotation and anchor.\n */\n calculateCenterRotate(rotation, anchor) {\n let center;\n const currentCenter = this.getCenterInternal();\n if (currentCenter !== undefined) {\n center = [currentCenter[0] - anchor[0], currentCenter[1] - anchor[1]];\n rotateCoordinate(center, rotation - this.getRotation());\n addCoordinate(center, anchor);\n }\n return center;\n }\n\n /**\n * @param {number} resolution Target resolution.\n * @param {import(\"./coordinate.js\").Coordinate} anchor Zoom anchor.\n * @return {import(\"./coordinate.js\").Coordinate|undefined} Center for resolution and anchor.\n */\n calculateCenterZoom(resolution, anchor) {\n let center;\n const currentCenter = this.getCenterInternal();\n const currentResolution = this.getResolution();\n if (currentCenter !== undefined && currentResolution !== undefined) {\n const x =\n anchor[0] -\n (resolution * (anchor[0] - currentCenter[0])) / currentResolution;\n const y =\n anchor[1] -\n (resolution * (anchor[1] - currentCenter[1])) / currentResolution;\n center = [x, y];\n }\n return center;\n }\n\n /**\n * Returns the current viewport size.\n * @private\n * @param {number} [rotation] Take into account the rotation of the viewport when giving the size\n * @return {import(\"./size.js\").Size} Viewport size or `[100, 100]` when no viewport is found.\n */\n getViewportSize_(rotation) {\n const size = this.viewportSize_;\n if (rotation) {\n const w = size[0];\n const h = size[1];\n return [\n Math.abs(w * Math.cos(rotation)) + Math.abs(h * Math.sin(rotation)),\n Math.abs(w * Math.sin(rotation)) + Math.abs(h * Math.cos(rotation)),\n ];\n }\n return size;\n }\n\n /**\n * Stores the viewport size on the view. The viewport size is not read every time from the DOM\n * to avoid performance hit and layout reflow.\n * This should be done on map size change.\n * Note: the constraints are not resolved during an animation to avoid stopping it\n * @param {import(\"./size.js\").Size} [size] Viewport size; if undefined, [100, 100] is assumed\n */\n setViewportSize(size) {\n this.viewportSize_ = Array.isArray(size) ? size.slice() : [100, 100];\n if (!this.getAnimating()) {\n this.resolveConstraints(0);\n }\n }\n\n /**\n * Get the view center.\n * @return {import(\"./coordinate.js\").Coordinate|undefined} The center of the view.\n * @observable\n * @api\n */\n getCenter() {\n const center = this.getCenterInternal();\n if (!center) {\n return center;\n }\n return toUserCoordinate(center, this.getProjection());\n }\n\n /**\n * Get the view center without transforming to user projection.\n * @return {import(\"./coordinate.js\").Coordinate|undefined} The center of the view.\n */\n getCenterInternal() {\n return /** @type {import(\"./coordinate.js\").Coordinate|undefined} */ (\n this.get(ViewProperty.CENTER)\n );\n }\n\n /**\n * @return {Constraints} Constraints.\n */\n getConstraints() {\n return this.constraints_;\n }\n\n /**\n * @return {boolean} Resolution constraint is set\n */\n getConstrainResolution() {\n return this.get('constrainResolution');\n }\n\n /**\n * @param {Array} [hints] Destination array.\n * @return {Array} Hint.\n */\n getHints(hints) {\n if (hints !== undefined) {\n hints[0] = this.hints_[0];\n hints[1] = this.hints_[1];\n return hints;\n }\n return this.hints_.slice();\n }\n\n /**\n * Calculate the extent for the current view state and the passed box size.\n * @param {import(\"./size.js\").Size} [size] The pixel dimensions of the box\n * into which the calculated extent should fit. Defaults to the size of the\n * map the view is associated with.\n * If no map or multiple maps are connected to the view, provide the desired\n * box size (e.g. `map.getSize()`).\n * @return {import(\"./extent.js\").Extent} Extent.\n * @api\n */\n calculateExtent(size) {\n const extent = this.calculateExtentInternal(size);\n return toUserExtent(extent, this.getProjection());\n }\n\n /**\n * @param {import(\"./size.js\").Size} [size] Box pixel size. If not provided,\n * the map's last known viewport size will be used.\n * @return {import(\"./extent.js\").Extent} Extent.\n */\n calculateExtentInternal(size) {\n size = size || this.getViewportSizeMinusPadding_();\n const center = /** @type {!import(\"./coordinate.js\").Coordinate} */ (\n this.getCenterInternal()\n );\n assert(center, 'The view center is not defined');\n const resolution = /** @type {!number} */ (this.getResolution());\n assert(resolution !== undefined, 'The view resolution is not defined');\n const rotation = /** @type {!number} */ (this.getRotation());\n assert(rotation !== undefined, 'The view rotation is not defined');\n\n return getForViewAndSize(center, resolution, rotation, size);\n }\n\n /**\n * Get the maximum resolution of the view.\n * @return {number} The maximum resolution of the view.\n * @api\n */\n getMaxResolution() {\n return this.maxResolution_;\n }\n\n /**\n * Get the minimum resolution of the view.\n * @return {number} The minimum resolution of the view.\n * @api\n */\n getMinResolution() {\n return this.minResolution_;\n }\n\n /**\n * Get the maximum zoom level for the view.\n * @return {number} The maximum zoom level.\n * @api\n */\n getMaxZoom() {\n return /** @type {number} */ (\n this.getZoomForResolution(this.minResolution_)\n );\n }\n\n /**\n * Set a new maximum zoom level for the view.\n * @param {number} zoom The maximum zoom level.\n * @api\n */\n setMaxZoom(zoom) {\n this.applyOptions_(this.getUpdatedOptions_({maxZoom: zoom}));\n }\n\n /**\n * Get the minimum zoom level for the view.\n * @return {number} The minimum zoom level.\n * @api\n */\n getMinZoom() {\n return /** @type {number} */ (\n this.getZoomForResolution(this.maxResolution_)\n );\n }\n\n /**\n * Set a new minimum zoom level for the view.\n * @param {number} zoom The minimum zoom level.\n * @api\n */\n setMinZoom(zoom) {\n this.applyOptions_(this.getUpdatedOptions_({minZoom: zoom}));\n }\n\n /**\n * Set whether the view should allow intermediary zoom levels.\n * @param {boolean} enabled Whether the resolution is constrained.\n * @api\n */\n setConstrainResolution(enabled) {\n this.applyOptions_(this.getUpdatedOptions_({constrainResolution: enabled}));\n }\n\n /**\n * Get the view projection.\n * @return {import(\"./proj/Projection.js\").default} The projection of the view.\n * @api\n */\n getProjection() {\n return this.projection_;\n }\n\n /**\n * Get the view resolution.\n * @return {number|undefined} The resolution of the view.\n * @observable\n * @api\n */\n getResolution() {\n return /** @type {number|undefined} */ (this.get(ViewProperty.RESOLUTION));\n }\n\n /**\n * Get the resolutions for the view. This returns the array of resolutions\n * passed to the constructor of the View, or undefined if none were given.\n * @return {Array|undefined} The resolutions of the view.\n * @api\n */\n getResolutions() {\n return this.resolutions_;\n }\n\n /**\n * Get the resolution for a provided extent (in map units) and size (in pixels).\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {import(\"./size.js\").Size} [size] Box pixel size.\n * @return {number} The resolution at which the provided extent will render at\n * the given size.\n * @api\n */\n getResolutionForExtent(extent, size) {\n return this.getResolutionForExtentInternal(\n fromUserExtent(extent, this.getProjection()),\n size,\n );\n }\n\n /**\n * Get the resolution for a provided extent (in map units) and size (in pixels).\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {import(\"./size.js\").Size} [size] Box pixel size.\n * @return {number} The resolution at which the provided extent will render at\n * the given size.\n */\n getResolutionForExtentInternal(extent, size) {\n size = size || this.getViewportSizeMinusPadding_();\n const xResolution = getWidth(extent) / size[0];\n const yResolution = getHeight(extent) / size[1];\n return Math.max(xResolution, yResolution);\n }\n\n /**\n * Return a function that returns a value between 0 and 1 for a\n * resolution. Exponential scaling is assumed.\n * @param {number} [power] Power.\n * @return {function(number): number} Resolution for value function.\n */\n getResolutionForValueFunction(power) {\n power = power || 2;\n const maxResolution = this.getConstrainedResolution(this.maxResolution_);\n const minResolution = this.minResolution_;\n const max = Math.log(maxResolution / minResolution) / Math.log(power);\n return (\n /**\n * @param {number} value Value.\n * @return {number} Resolution.\n */\n function (value) {\n const resolution = maxResolution / Math.pow(power, value * max);\n return resolution;\n }\n );\n }\n\n /**\n * Get the view rotation.\n * @return {number} The rotation of the view in radians.\n * @observable\n * @api\n */\n getRotation() {\n return /** @type {number} */ (this.get(ViewProperty.ROTATION));\n }\n\n /**\n * Return a function that returns a resolution for a value between\n * 0 and 1. Exponential scaling is assumed.\n * @param {number} [power] Power.\n * @return {function(number): number} Value for resolution function.\n */\n getValueForResolutionFunction(power) {\n const logPower = Math.log(power || 2);\n const maxResolution = this.getConstrainedResolution(this.maxResolution_);\n const minResolution = this.minResolution_;\n const max = Math.log(maxResolution / minResolution) / logPower;\n return (\n /**\n * @param {number} resolution Resolution.\n * @return {number} Value.\n */\n function (resolution) {\n const value = Math.log(maxResolution / resolution) / logPower / max;\n return value;\n }\n );\n }\n\n /**\n * Returns the size of the viewport minus padding.\n * @private\n * @param {number} [rotation] Take into account the rotation of the viewport when giving the size\n * @return {import(\"./size.js\").Size} Viewport size reduced by the padding.\n */\n getViewportSizeMinusPadding_(rotation) {\n let size = this.getViewportSize_(rotation);\n const padding = this.padding_;\n if (padding) {\n size = [\n size[0] - padding[1] - padding[3],\n size[1] - padding[0] - padding[2],\n ];\n }\n return size;\n }\n\n /**\n * @return {State} View state.\n */\n getState() {\n const projection = this.getProjection();\n const resolution = this.getResolution();\n const rotation = this.getRotation();\n let center = /** @type {import(\"./coordinate.js\").Coordinate} */ (\n this.getCenterInternal()\n );\n const padding = this.padding_;\n if (padding) {\n const reducedSize = this.getViewportSizeMinusPadding_();\n center = calculateCenterOn(\n center,\n this.getViewportSize_(),\n [reducedSize[0] / 2 + padding[3], reducedSize[1] / 2 + padding[0]],\n resolution,\n rotation,\n );\n }\n return {\n center: center.slice(0),\n projection: projection !== undefined ? projection : null,\n resolution: resolution,\n nextCenter: this.nextCenter_,\n nextResolution: this.nextResolution_,\n nextRotation: this.nextRotation_,\n rotation: rotation,\n zoom: this.getZoom(),\n };\n }\n\n /**\n * @return {ViewStateLayerStateExtent} Like `FrameState`, but just `viewState` and `extent`.\n */\n getViewStateAndExtent() {\n return {\n viewState: this.getState(),\n extent: this.calculateExtent(),\n };\n }\n\n /**\n * Get the current zoom level. This method may return non-integer zoom levels\n * if the view does not constrain the resolution, or if an interaction or\n * animation is underway.\n * @return {number|undefined} Zoom.\n * @api\n */\n getZoom() {\n let zoom;\n const resolution = this.getResolution();\n if (resolution !== undefined) {\n zoom = this.getZoomForResolution(resolution);\n }\n return zoom;\n }\n\n /**\n * Get the zoom level for a resolution.\n * @param {number} resolution The resolution.\n * @return {number|undefined} The zoom level for the provided resolution.\n * @api\n */\n getZoomForResolution(resolution) {\n let offset = this.minZoom_ || 0;\n let max, zoomFactor;\n if (this.resolutions_) {\n const nearest = linearFindNearest(this.resolutions_, resolution, 1);\n offset = nearest;\n max = this.resolutions_[nearest];\n if (nearest == this.resolutions_.length - 1) {\n zoomFactor = 2;\n } else {\n zoomFactor = max / this.resolutions_[nearest + 1];\n }\n } else {\n max = this.maxResolution_;\n zoomFactor = this.zoomFactor_;\n }\n return offset + Math.log(max / resolution) / Math.log(zoomFactor);\n }\n\n /**\n * Get the resolution for a zoom level.\n * @param {number} zoom Zoom level.\n * @return {number} The view resolution for the provided zoom level.\n * @api\n */\n getResolutionForZoom(zoom) {\n if (this.resolutions_) {\n if (this.resolutions_.length <= 1) {\n return 0;\n }\n const baseLevel = clamp(\n Math.floor(zoom),\n 0,\n this.resolutions_.length - 2,\n );\n const zoomFactor =\n this.resolutions_[baseLevel] / this.resolutions_[baseLevel + 1];\n return (\n this.resolutions_[baseLevel] /\n Math.pow(zoomFactor, clamp(zoom - baseLevel, 0, 1))\n );\n }\n return (\n this.maxResolution_ / Math.pow(this.zoomFactor_, zoom - this.minZoom_)\n );\n }\n\n /**\n * Fit the given geometry or extent based on the given map size and border.\n * The size is pixel dimensions of the box to fit the extent into.\n * In most cases you will want to use the map size, that is `map.getSize()`.\n * Takes care of the map angle.\n * @param {import(\"./geom/SimpleGeometry.js\").default|import(\"./extent.js\").Extent} geometryOrExtent The geometry or\n * extent to fit the view to.\n * @param {FitOptions} [options] Options.\n * @api\n */\n fit(geometryOrExtent, options) {\n /** @type {import(\"./geom/SimpleGeometry.js\").default} */\n let geometry;\n assert(\n Array.isArray(geometryOrExtent) ||\n typeof (/** @type {?} */ (geometryOrExtent).getSimplifiedGeometry) ===\n 'function',\n 'Invalid extent or geometry provided as `geometry`',\n );\n if (Array.isArray(geometryOrExtent)) {\n assert(\n !isEmpty(geometryOrExtent),\n 'Cannot fit empty extent provided as `geometry`',\n );\n const extent = fromUserExtent(geometryOrExtent, this.getProjection());\n geometry = polygonFromExtent(extent);\n } else if (geometryOrExtent.getType() === 'Circle') {\n const extent = fromUserExtent(\n geometryOrExtent.getExtent(),\n this.getProjection(),\n );\n geometry = polygonFromExtent(extent);\n geometry.rotate(this.getRotation(), getCenter(extent));\n } else {\n const userProjection = getUserProjection();\n if (userProjection) {\n geometry = /** @type {import(\"./geom/SimpleGeometry.js\").default} */ (\n geometryOrExtent\n .clone()\n .transform(userProjection, this.getProjection())\n );\n } else {\n geometry = geometryOrExtent;\n }\n }\n\n this.fitInternal(geometry, options);\n }\n\n /**\n * Calculate rotated extent\n * @param {import(\"./geom/SimpleGeometry.js\").default} geometry The geometry.\n * @return {import(\"./extent\").Extent} The rotated extent for the geometry.\n */\n rotatedExtentForGeometry(geometry) {\n const rotation = this.getRotation();\n const cosAngle = Math.cos(rotation);\n const sinAngle = Math.sin(-rotation);\n const coords = geometry.getFlatCoordinates();\n const stride = geometry.getStride();\n let minRotX = +Infinity;\n let minRotY = +Infinity;\n let maxRotX = -Infinity;\n let maxRotY = -Infinity;\n for (let i = 0, ii = coords.length; i < ii; i += stride) {\n const rotX = coords[i] * cosAngle - coords[i + 1] * sinAngle;\n const rotY = coords[i] * sinAngle + coords[i + 1] * cosAngle;\n minRotX = Math.min(minRotX, rotX);\n minRotY = Math.min(minRotY, rotY);\n maxRotX = Math.max(maxRotX, rotX);\n maxRotY = Math.max(maxRotY, rotY);\n }\n return [minRotX, minRotY, maxRotX, maxRotY];\n }\n\n /**\n * @param {import(\"./geom/SimpleGeometry.js\").default} geometry The geometry.\n * @param {FitOptions} [options] Options.\n */\n fitInternal(geometry, options) {\n options = options || {};\n let size = options.size;\n if (!size) {\n size = this.getViewportSizeMinusPadding_();\n }\n const padding =\n options.padding !== undefined ? options.padding : [0, 0, 0, 0];\n const nearest = options.nearest !== undefined ? options.nearest : false;\n let minResolution;\n if (options.minResolution !== undefined) {\n minResolution = options.minResolution;\n } else if (options.maxZoom !== undefined) {\n minResolution = this.getResolutionForZoom(options.maxZoom);\n } else {\n minResolution = 0;\n }\n\n const rotatedExtent = this.rotatedExtentForGeometry(geometry);\n\n // calculate resolution\n let resolution = this.getResolutionForExtentInternal(rotatedExtent, [\n size[0] - padding[1] - padding[3],\n size[1] - padding[0] - padding[2],\n ]);\n resolution = isNaN(resolution)\n ? minResolution\n : Math.max(resolution, minResolution);\n resolution = this.getConstrainedResolution(resolution, nearest ? 0 : 1);\n\n // calculate center\n const rotation = this.getRotation();\n const sinAngle = Math.sin(rotation);\n const cosAngle = Math.cos(rotation);\n const centerRot = getCenter(rotatedExtent);\n centerRot[0] += ((padding[1] - padding[3]) / 2) * resolution;\n centerRot[1] += ((padding[0] - padding[2]) / 2) * resolution;\n const centerX = centerRot[0] * cosAngle - centerRot[1] * sinAngle;\n const centerY = centerRot[1] * cosAngle + centerRot[0] * sinAngle;\n const center = this.getConstrainedCenter([centerX, centerY], resolution);\n const callback = options.callback ? options.callback : VOID;\n\n if (options.duration !== undefined) {\n this.animateInternal(\n {\n resolution: resolution,\n center: center,\n duration: options.duration,\n easing: options.easing,\n },\n callback,\n );\n } else {\n this.targetResolution_ = resolution;\n this.targetCenter_ = center;\n this.applyTargetState_(false, true);\n animationCallback(callback, true);\n }\n }\n\n /**\n * Center on coordinate and view position.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {import(\"./size.js\").Size} size Box pixel size.\n * @param {import(\"./pixel.js\").Pixel} position Position on the view to center on.\n * @api\n */\n centerOn(coordinate, size, position) {\n this.centerOnInternal(\n fromUserCoordinate(coordinate, this.getProjection()),\n size,\n position,\n );\n }\n\n /**\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {import(\"./size.js\").Size} size Box pixel size.\n * @param {import(\"./pixel.js\").Pixel} position Position on the view to center on.\n */\n centerOnInternal(coordinate, size, position) {\n this.setCenterInternal(\n calculateCenterOn(\n coordinate,\n size,\n position,\n this.getResolution(),\n this.getRotation(),\n ),\n );\n }\n\n /**\n * Calculates the shift between map and viewport center.\n * @param {import(\"./coordinate.js\").Coordinate} center Center.\n * @param {number} resolution Resolution.\n * @param {number} rotation Rotation.\n * @param {import(\"./size.js\").Size} size Size.\n * @return {Array|undefined} Center shift.\n */\n calculateCenterShift(center, resolution, rotation, size) {\n let centerShift;\n const padding = this.padding_;\n if (padding && center) {\n const reducedSize = this.getViewportSizeMinusPadding_(-rotation);\n const shiftedCenter = calculateCenterOn(\n center,\n size,\n [reducedSize[0] / 2 + padding[3], reducedSize[1] / 2 + padding[0]],\n resolution,\n rotation,\n );\n centerShift = [\n center[0] - shiftedCenter[0],\n center[1] - shiftedCenter[1],\n ];\n }\n return centerShift;\n }\n\n /**\n * @return {boolean} Is defined.\n */\n isDef() {\n return !!this.getCenterInternal() && this.getResolution() !== undefined;\n }\n\n /**\n * Adds relative coordinates to the center of the view. Any extent constraint will apply.\n * @param {import(\"./coordinate.js\").Coordinate} deltaCoordinates Relative value to add.\n * @api\n */\n adjustCenter(deltaCoordinates) {\n const center = toUserCoordinate(this.targetCenter_, this.getProjection());\n this.setCenter([\n center[0] + deltaCoordinates[0],\n center[1] + deltaCoordinates[1],\n ]);\n }\n\n /**\n * Adds relative coordinates to the center of the view. Any extent constraint will apply.\n * @param {import(\"./coordinate.js\").Coordinate} deltaCoordinates Relative value to add.\n */\n adjustCenterInternal(deltaCoordinates) {\n const center = this.targetCenter_;\n this.setCenterInternal([\n center[0] + deltaCoordinates[0],\n center[1] + deltaCoordinates[1],\n ]);\n }\n\n /**\n * Multiply the view resolution by a ratio, optionally using an anchor. Any resolution\n * constraint will apply.\n * @param {number} ratio The ratio to apply on the view resolution.\n * @param {import(\"./coordinate.js\").Coordinate} [anchor] The origin of the transformation.\n * @api\n */\n adjustResolution(ratio, anchor) {\n anchor = anchor && fromUserCoordinate(anchor, this.getProjection());\n this.adjustResolutionInternal(ratio, anchor);\n }\n\n /**\n * Multiply the view resolution by a ratio, optionally using an anchor. Any resolution\n * constraint will apply.\n * @param {number} ratio The ratio to apply on the view resolution.\n * @param {import(\"./coordinate.js\").Coordinate} [anchor] The origin of the transformation.\n */\n adjustResolutionInternal(ratio, anchor) {\n const isMoving = this.getAnimating() || this.getInteracting();\n const size = this.getViewportSize_(this.getRotation());\n const newResolution = this.constraints_.resolution(\n this.targetResolution_ * ratio,\n 0,\n size,\n isMoving,\n );\n\n if (anchor) {\n this.targetCenter_ = this.calculateCenterZoom(newResolution, anchor);\n }\n\n this.targetResolution_ *= ratio;\n this.applyTargetState_();\n }\n\n /**\n * Adds a value to the view zoom level, optionally using an anchor. Any resolution\n * constraint will apply.\n * @param {number} delta Relative value to add to the zoom level.\n * @param {import(\"./coordinate.js\").Coordinate} [anchor] The origin of the transformation.\n * @api\n */\n adjustZoom(delta, anchor) {\n this.adjustResolution(Math.pow(this.zoomFactor_, -delta), anchor);\n }\n\n /**\n * Adds a value to the view rotation, optionally using an anchor. Any rotation\n * constraint will apply.\n * @param {number} delta Relative value to add to the zoom rotation, in radians.\n * @param {import(\"./coordinate.js\").Coordinate} [anchor] The rotation center.\n * @api\n */\n adjustRotation(delta, anchor) {\n if (anchor) {\n anchor = fromUserCoordinate(anchor, this.getProjection());\n }\n this.adjustRotationInternal(delta, anchor);\n }\n\n /**\n * @param {number} delta Relative value to add to the zoom rotation, in radians.\n * @param {import(\"./coordinate.js\").Coordinate} [anchor] The rotation center.\n */\n adjustRotationInternal(delta, anchor) {\n const isMoving = this.getAnimating() || this.getInteracting();\n const newRotation = this.constraints_.rotation(\n this.targetRotation_ + delta,\n isMoving,\n );\n if (anchor) {\n this.targetCenter_ = this.calculateCenterRotate(newRotation, anchor);\n }\n this.targetRotation_ += delta;\n this.applyTargetState_();\n }\n\n /**\n * Set the center of the current view. Any extent constraint will apply.\n * @param {import(\"./coordinate.js\").Coordinate|undefined} center The center of the view.\n * @observable\n * @api\n */\n setCenter(center) {\n this.setCenterInternal(\n center ? fromUserCoordinate(center, this.getProjection()) : center,\n );\n }\n\n /**\n * Set the center using the view projection (not the user projection).\n * @param {import(\"./coordinate.js\").Coordinate|undefined} center The center of the view.\n */\n setCenterInternal(center) {\n this.targetCenter_ = center;\n this.applyTargetState_();\n }\n\n /**\n * @param {import(\"./ViewHint.js\").default} hint Hint.\n * @param {number} delta Delta.\n * @return {number} New value.\n */\n setHint(hint, delta) {\n this.hints_[hint] += delta;\n this.changed();\n return this.hints_[hint];\n }\n\n /**\n * Set the resolution for this view. Any resolution constraint will apply.\n * @param {number|undefined} resolution The resolution of the view.\n * @observable\n * @api\n */\n setResolution(resolution) {\n this.targetResolution_ = resolution;\n this.applyTargetState_();\n }\n\n /**\n * Set the rotation for this view. Any rotation constraint will apply.\n * @param {number} rotation The rotation of the view in radians.\n * @observable\n * @api\n */\n setRotation(rotation) {\n this.targetRotation_ = rotation;\n this.applyTargetState_();\n }\n\n /**\n * Zoom to a specific zoom level. Any resolution constrain will apply.\n * @param {number} zoom Zoom level.\n * @api\n */\n setZoom(zoom) {\n this.setResolution(this.getResolutionForZoom(zoom));\n }\n\n /**\n * Recompute rotation/resolution/center based on target values.\n * Note: we have to compute rotation first, then resolution and center considering that\n * parameters can influence one another in case a view extent constraint is present.\n * @param {boolean} [doNotCancelAnims] Do not cancel animations.\n * @param {boolean} [forceMoving] Apply constraints as if the view is moving.\n * @private\n */\n applyTargetState_(doNotCancelAnims, forceMoving) {\n const isMoving =\n this.getAnimating() || this.getInteracting() || forceMoving;\n\n // compute rotation\n const newRotation = this.constraints_.rotation(\n this.targetRotation_,\n isMoving,\n );\n const size = this.getViewportSize_(newRotation);\n const newResolution = this.constraints_.resolution(\n this.targetResolution_,\n 0,\n size,\n isMoving,\n );\n const newCenter = this.constraints_.center(\n this.targetCenter_,\n newResolution,\n size,\n isMoving,\n this.calculateCenterShift(\n this.targetCenter_,\n newResolution,\n newRotation,\n size,\n ),\n );\n\n if (this.get(ViewProperty.ROTATION) !== newRotation) {\n this.set(ViewProperty.ROTATION, newRotation);\n }\n if (this.get(ViewProperty.RESOLUTION) !== newResolution) {\n this.set(ViewProperty.RESOLUTION, newResolution);\n this.set('zoom', this.getZoom(), true);\n }\n if (\n !newCenter ||\n !this.get(ViewProperty.CENTER) ||\n !equals(this.get(ViewProperty.CENTER), newCenter)\n ) {\n this.set(ViewProperty.CENTER, newCenter);\n }\n\n if (this.getAnimating() && !doNotCancelAnims) {\n this.cancelAnimations();\n }\n this.cancelAnchor_ = undefined;\n }\n\n /**\n * If any constraints need to be applied, an animation will be triggered.\n * This is typically done on interaction end.\n * Note: calling this with a duration of 0 will apply the constrained values straight away,\n * without animation.\n * @param {number} [duration] The animation duration in ms.\n * @param {number} [resolutionDirection] Which direction to zoom.\n * @param {import(\"./coordinate.js\").Coordinate} [anchor] The origin of the transformation.\n */\n resolveConstraints(duration, resolutionDirection, anchor) {\n duration = duration !== undefined ? duration : 200;\n const direction = resolutionDirection || 0;\n\n const newRotation = this.constraints_.rotation(this.targetRotation_);\n const size = this.getViewportSize_(newRotation);\n const newResolution = this.constraints_.resolution(\n this.targetResolution_,\n direction,\n size,\n );\n const newCenter = this.constraints_.center(\n this.targetCenter_,\n newResolution,\n size,\n false,\n this.calculateCenterShift(\n this.targetCenter_,\n newResolution,\n newRotation,\n size,\n ),\n );\n\n if (duration === 0 && !this.cancelAnchor_) {\n this.targetResolution_ = newResolution;\n this.targetRotation_ = newRotation;\n this.targetCenter_ = newCenter;\n this.applyTargetState_();\n return;\n }\n\n anchor = anchor || (duration === 0 ? this.cancelAnchor_ : undefined);\n this.cancelAnchor_ = undefined;\n\n if (\n this.getResolution() !== newResolution ||\n this.getRotation() !== newRotation ||\n !this.getCenterInternal() ||\n !equals(this.getCenterInternal(), newCenter)\n ) {\n if (this.getAnimating()) {\n this.cancelAnimations();\n }\n\n this.animateInternal({\n rotation: newRotation,\n center: newCenter,\n resolution: newResolution,\n duration: duration,\n easing: easeOut,\n anchor: anchor,\n });\n }\n }\n\n /**\n * Notify the View that an interaction has started.\n * The view state will be resolved to a stable one if needed\n * (depending on its constraints).\n * @api\n */\n beginInteraction() {\n this.resolveConstraints(0);\n\n this.setHint(ViewHint.INTERACTING, 1);\n }\n\n /**\n * Notify the View that an interaction has ended. The view state will be resolved\n * to a stable one if needed (depending on its constraints).\n * @param {number} [duration] Animation duration in ms.\n * @param {number} [resolutionDirection] Which direction to zoom.\n * @param {import(\"./coordinate.js\").Coordinate} [anchor] The origin of the transformation.\n * @api\n */\n endInteraction(duration, resolutionDirection, anchor) {\n anchor = anchor && fromUserCoordinate(anchor, this.getProjection());\n this.endInteractionInternal(duration, resolutionDirection, anchor);\n }\n\n /**\n * Notify the View that an interaction has ended. The view state will be resolved\n * to a stable one if needed (depending on its constraints).\n * @param {number} [duration] Animation duration in ms.\n * @param {number} [resolutionDirection] Which direction to zoom.\n * @param {import(\"./coordinate.js\").Coordinate} [anchor] The origin of the transformation.\n */\n endInteractionInternal(duration, resolutionDirection, anchor) {\n if (!this.getInteracting()) {\n return;\n }\n this.setHint(ViewHint.INTERACTING, -1);\n this.resolveConstraints(duration, resolutionDirection, anchor);\n }\n\n /**\n * Get a valid position for the view center according to the current constraints.\n * @param {import(\"./coordinate.js\").Coordinate|undefined} targetCenter Target center position.\n * @param {number} [targetResolution] Target resolution. If not supplied, the current one will be used.\n * This is useful to guess a valid center position at a different zoom level.\n * @return {import(\"./coordinate.js\").Coordinate|undefined} Valid center position.\n */\n getConstrainedCenter(targetCenter, targetResolution) {\n const size = this.getViewportSize_(this.getRotation());\n return this.constraints_.center(\n targetCenter,\n targetResolution || this.getResolution(),\n size,\n );\n }\n\n /**\n * Get a valid zoom level according to the current view constraints.\n * @param {number|undefined} targetZoom Target zoom.\n * @param {number} [direction=0] Indicate which resolution should be used\n * by a renderer if the view resolution does not match any resolution of the tile source.\n * If 0, the nearest resolution will be used. If 1, the nearest lower resolution\n * will be used. If -1, the nearest higher resolution will be used.\n * @return {number|undefined} Valid zoom level.\n */\n getConstrainedZoom(targetZoom, direction) {\n const targetRes = this.getResolutionForZoom(targetZoom);\n return this.getZoomForResolution(\n this.getConstrainedResolution(targetRes, direction),\n );\n }\n\n /**\n * Get a valid resolution according to the current view constraints.\n * @param {number|undefined} targetResolution Target resolution.\n * @param {number} [direction=0] Indicate which resolution should be used\n * by a renderer if the view resolution does not match any resolution of the tile source.\n * If 0, the nearest resolution will be used. If 1, the nearest lower resolution\n * will be used. If -1, the nearest higher resolution will be used.\n * @return {number|undefined} Valid resolution.\n */\n getConstrainedResolution(targetResolution, direction) {\n direction = direction || 0;\n const size = this.getViewportSize_(this.getRotation());\n\n return this.constraints_.resolution(targetResolution, direction, size);\n }\n}\n\n/**\n * @param {Function} callback Callback.\n * @param {*} returnValue Return value.\n */\nfunction animationCallback(callback, returnValue) {\n setTimeout(function () {\n callback(returnValue);\n }, 0);\n}\n\n/**\n * @param {ViewOptions} options View options.\n * @return {import(\"./centerconstraint.js\").Type} The constraint.\n */\nexport function createCenterConstraint(options) {\n if (options.extent !== undefined) {\n const smooth =\n options.smoothExtentConstraint !== undefined\n ? options.smoothExtentConstraint\n : true;\n return createExtent(options.extent, options.constrainOnlyCenter, smooth);\n }\n\n const projection = createProjection(options.projection, 'EPSG:3857');\n if (options.multiWorld !== true && projection.isGlobal()) {\n const extent = projection.getExtent().slice();\n extent[0] = -Infinity;\n extent[2] = Infinity;\n return createExtent(extent, false, false);\n }\n\n return centerNone;\n}\n\n/**\n * @param {ViewOptions} options View options.\n * @return {{constraint: import(\"./resolutionconstraint.js\").Type, maxResolution: number,\n * minResolution: number, minZoom: number, zoomFactor: number}} The constraint.\n */\nexport function createResolutionConstraint(options) {\n let resolutionConstraint;\n let maxResolution;\n let minResolution;\n\n // TODO: move these to be ol constants\n // see https://github.com/openlayers/openlayers/issues/2076\n const defaultMaxZoom = 28;\n const defaultZoomFactor = 2;\n\n let minZoom =\n options.minZoom !== undefined ? options.minZoom : DEFAULT_MIN_ZOOM;\n\n let maxZoom =\n options.maxZoom !== undefined ? options.maxZoom : defaultMaxZoom;\n\n const zoomFactor =\n options.zoomFactor !== undefined ? options.zoomFactor : defaultZoomFactor;\n\n const multiWorld =\n options.multiWorld !== undefined ? options.multiWorld : false;\n\n const smooth =\n options.smoothResolutionConstraint !== undefined\n ? options.smoothResolutionConstraint\n : true;\n\n const showFullExtent =\n options.showFullExtent !== undefined ? options.showFullExtent : false;\n\n const projection = createProjection(options.projection, 'EPSG:3857');\n const projExtent = projection.getExtent();\n let constrainOnlyCenter = options.constrainOnlyCenter;\n let extent = options.extent;\n if (!multiWorld && !extent && projection.isGlobal()) {\n constrainOnlyCenter = false;\n extent = projExtent;\n }\n\n if (options.resolutions !== undefined) {\n const resolutions = options.resolutions;\n maxResolution = resolutions[minZoom];\n minResolution =\n resolutions[maxZoom] !== undefined\n ? resolutions[maxZoom]\n : resolutions[resolutions.length - 1];\n\n if (options.constrainResolution) {\n resolutionConstraint = createSnapToResolutions(\n resolutions,\n smooth,\n !constrainOnlyCenter && extent,\n showFullExtent,\n );\n } else {\n resolutionConstraint = createMinMaxResolution(\n maxResolution,\n minResolution,\n smooth,\n !constrainOnlyCenter && extent,\n showFullExtent,\n );\n }\n } else {\n // calculate the default min and max resolution\n const size = !projExtent\n ? // use an extent that can fit the whole world if need be\n (360 * METERS_PER_UNIT.degrees) / projection.getMetersPerUnit()\n : Math.max(getWidth(projExtent), getHeight(projExtent));\n\n const defaultMaxResolution =\n size / DEFAULT_TILE_SIZE / Math.pow(defaultZoomFactor, DEFAULT_MIN_ZOOM);\n\n const defaultMinResolution =\n defaultMaxResolution /\n Math.pow(defaultZoomFactor, defaultMaxZoom - DEFAULT_MIN_ZOOM);\n\n // user provided maxResolution takes precedence\n maxResolution = options.maxResolution;\n if (maxResolution !== undefined) {\n minZoom = 0;\n } else {\n maxResolution = defaultMaxResolution / Math.pow(zoomFactor, minZoom);\n }\n\n // user provided minResolution takes precedence\n minResolution = options.minResolution;\n if (minResolution === undefined) {\n if (options.maxZoom !== undefined) {\n if (options.maxResolution !== undefined) {\n minResolution = maxResolution / Math.pow(zoomFactor, maxZoom);\n } else {\n minResolution = defaultMaxResolution / Math.pow(zoomFactor, maxZoom);\n }\n } else {\n minResolution = defaultMinResolution;\n }\n }\n\n // given discrete zoom levels, minResolution may be different than provided\n maxZoom =\n minZoom +\n Math.floor(\n Math.log(maxResolution / minResolution) / Math.log(zoomFactor),\n );\n minResolution = maxResolution / Math.pow(zoomFactor, maxZoom - minZoom);\n\n if (options.constrainResolution) {\n resolutionConstraint = createSnapToPower(\n zoomFactor,\n maxResolution,\n minResolution,\n smooth,\n !constrainOnlyCenter && extent,\n showFullExtent,\n );\n } else {\n resolutionConstraint = createMinMaxResolution(\n maxResolution,\n minResolution,\n smooth,\n !constrainOnlyCenter && extent,\n showFullExtent,\n );\n }\n }\n return {\n constraint: resolutionConstraint,\n maxResolution: maxResolution,\n minResolution: minResolution,\n minZoom: minZoom,\n zoomFactor: zoomFactor,\n };\n}\n\n/**\n * @param {ViewOptions} options View options.\n * @return {import(\"./rotationconstraint.js\").Type} Rotation constraint.\n */\nexport function createRotationConstraint(options) {\n const enableRotation =\n options.enableRotation !== undefined ? options.enableRotation : true;\n if (enableRotation) {\n const constrainRotation = options.constrainRotation;\n if (constrainRotation === undefined || constrainRotation === true) {\n return createSnapToZero();\n }\n if (constrainRotation === false) {\n return rotationNone;\n }\n if (typeof constrainRotation === 'number') {\n return createSnapToN(constrainRotation);\n }\n return rotationNone;\n }\n return disable;\n}\n\n/**\n * Determine if an animation involves no view change.\n * @param {Animation} animation The animation.\n * @return {boolean} The animation involves no view change.\n */\nexport function isNoopAnimation(animation) {\n if (animation.sourceCenter && animation.targetCenter) {\n if (!coordinatesEqual(animation.sourceCenter, animation.targetCenter)) {\n return false;\n }\n }\n if (animation.sourceResolution !== animation.targetResolution) {\n return false;\n }\n if (animation.sourceRotation !== animation.targetRotation) {\n return false;\n }\n return true;\n}\n\n/**\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {import(\"./size.js\").Size} size Box pixel size.\n * @param {import(\"./pixel.js\").Pixel} position Position on the view to center on.\n * @param {number} resolution Resolution.\n * @param {number} rotation Rotation.\n * @return {import(\"./coordinate.js\").Coordinate} Shifted center.\n */\nfunction calculateCenterOn(coordinate, size, position, resolution, rotation) {\n // calculate rotated position\n const cosAngle = Math.cos(-rotation);\n let sinAngle = Math.sin(-rotation);\n let rotX = coordinate[0] * cosAngle - coordinate[1] * sinAngle;\n let rotY = coordinate[1] * cosAngle + coordinate[0] * sinAngle;\n rotX += (size[0] / 2 - position[0]) * resolution;\n rotY += (position[1] - size[1] / 2) * resolution;\n\n // go back to original angle\n sinAngle = -sinAngle; // go back to original rotation\n const centerX = rotX * cosAngle - rotY * sinAngle;\n const centerY = rotY * cosAngle + rotX * sinAngle;\n\n return [centerX, centerY];\n}\n\nexport default View;\n","/**\n * @module ol/ViewHint\n */\n\n/**\n * @enum {number}\n */\nexport default {\n ANIMATING: 0,\n INTERACTING: 1,\n};\n","/**\n * @module ol/array\n */\n\n/**\n * Performs a binary search on the provided sorted list and returns the index of the item if found. If it can't be found it'll return -1.\n * https://github.com/darkskyapp/binary-search\n *\n * @param {Array<*>} haystack Items to search through.\n * @param {*} needle The item to look for.\n * @param {Function} [comparator] Comparator function.\n * @return {number} The index of the item if found, -1 if not.\n */\nexport function binarySearch(haystack, needle, comparator) {\n let mid, cmp;\n comparator = comparator || ascending;\n let low = 0;\n let high = haystack.length;\n let found = false;\n\n while (low < high) {\n /* Note that \"(low + high) >>> 1\" may overflow, and results in a typecast\n * to double (which gives the wrong results). */\n mid = low + ((high - low) >> 1);\n cmp = +comparator(haystack[mid], needle);\n\n if (cmp < 0.0) {\n /* Too low. */\n low = mid + 1;\n } else {\n /* Key found or too high */\n high = mid;\n found = !cmp;\n }\n }\n\n /* Key not found. */\n return found ? low : ~low;\n}\n\n/**\n * Compare function sorting arrays in ascending order. Safe to use for numeric values.\n * @param {*} a The first object to be compared.\n * @param {*} b The second object to be compared.\n * @return {number} A negative number, zero, or a positive number as the first\n * argument is less than, equal to, or greater than the second.\n */\nexport function ascending(a, b) {\n return a > b ? 1 : a < b ? -1 : 0;\n}\n\n/**\n * Compare function sorting arrays in descending order. Safe to use for numeric values.\n * @param {*} a The first object to be compared.\n * @param {*} b The second object to be compared.\n * @return {number} A negative number, zero, or a positive number as the first\n * argument is greater than, equal to, or less than the second.\n */\nexport function descending(a, b) {\n return a < b ? 1 : a > b ? -1 : 0;\n}\n\n/**\n * {@link module:ol/tilegrid/TileGrid~TileGrid#getZForResolution} can use a function\n * of this type to determine which nearest resolution to use.\n *\n * This function takes a `{number}` representing a value between two array entries,\n * a `{number}` representing the value of the nearest higher entry and\n * a `{number}` representing the value of the nearest lower entry\n * as arguments and returns a `{number}`. If a negative number or zero is returned\n * the lower value will be used, if a positive number is returned the higher value\n * will be used.\n * @typedef {function(number, number, number): number} NearestDirectionFunction\n * @api\n */\n\n/**\n * @param {Array} arr Array in descending order.\n * @param {number} target Target.\n * @param {number|NearestDirectionFunction} direction\n * 0 means return the nearest,\n * > 0 means return the largest nearest,\n * < 0 means return the smallest nearest.\n * @return {number} Index.\n */\nexport function linearFindNearest(arr, target, direction) {\n if (arr[0] <= target) {\n return 0;\n }\n\n const n = arr.length;\n if (target <= arr[n - 1]) {\n return n - 1;\n }\n\n if (typeof direction === 'function') {\n for (let i = 1; i < n; ++i) {\n const candidate = arr[i];\n if (candidate === target) {\n return i;\n }\n if (candidate < target) {\n if (direction(target, arr[i - 1], candidate) > 0) {\n return i - 1;\n }\n return i;\n }\n }\n return n - 1;\n }\n\n if (direction > 0) {\n for (let i = 1; i < n; ++i) {\n if (arr[i] < target) {\n return i - 1;\n }\n }\n return n - 1;\n }\n\n if (direction < 0) {\n for (let i = 1; i < n; ++i) {\n if (arr[i] <= target) {\n return i;\n }\n }\n return n - 1;\n }\n\n for (let i = 1; i < n; ++i) {\n if (arr[i] == target) {\n return i;\n }\n if (arr[i] < target) {\n if (arr[i - 1] - target < target - arr[i]) {\n return i - 1;\n }\n return i;\n }\n }\n return n - 1;\n}\n\n/**\n * @param {Array<*>} arr Array.\n * @param {number} begin Begin index.\n * @param {number} end End index.\n */\nexport function reverseSubArray(arr, begin, end) {\n while (begin < end) {\n const tmp = arr[begin];\n arr[begin] = arr[end];\n arr[end] = tmp;\n ++begin;\n --end;\n }\n}\n\n/**\n * @param {Array} arr The array to modify.\n * @param {!Array|VALUE} data The elements or arrays of elements to add to arr.\n * @template VALUE\n */\nexport function extend(arr, data) {\n const extension = Array.isArray(data) ? data : [data];\n const length = extension.length;\n for (let i = 0; i < length; i++) {\n arr[arr.length] = extension[i];\n }\n}\n\n/**\n * @param {Array} arr The array to modify.\n * @param {VALUE} obj The element to remove.\n * @template VALUE\n * @return {boolean} If the element was removed.\n */\nexport function remove(arr, obj) {\n const i = arr.indexOf(obj);\n const found = i > -1;\n if (found) {\n arr.splice(i, 1);\n }\n return found;\n}\n\n/**\n * @param {Array|Uint8ClampedArray} arr1 The first array to compare.\n * @param {Array|Uint8ClampedArray} arr2 The second array to compare.\n * @return {boolean} Whether the two arrays are equal.\n */\nexport function equals(arr1, arr2) {\n const len1 = arr1.length;\n if (len1 !== arr2.length) {\n return false;\n }\n for (let i = 0; i < len1; i++) {\n if (arr1[i] !== arr2[i]) {\n return false;\n }\n }\n return true;\n}\n\n/**\n * Sort the passed array such that the relative order of equal elements is preserved.\n * See https://en.wikipedia.org/wiki/Sorting_algorithm#Stability for details.\n * @param {Array<*>} arr The array to sort (modifies original).\n * @param {!function(*, *): number} compareFnc Comparison function.\n * @api\n */\nexport function stableSort(arr, compareFnc) {\n const length = arr.length;\n const tmp = Array(arr.length);\n let i;\n for (i = 0; i < length; i++) {\n tmp[i] = {index: i, value: arr[i]};\n }\n tmp.sort(function (a, b) {\n return compareFnc(a.value, b.value) || a.index - b.index;\n });\n for (i = 0; i < arr.length; i++) {\n arr[i] = tmp[i].value;\n }\n}\n\n/**\n * @param {Array<*>} arr The array to test.\n * @param {Function} [func] Comparison function.\n * @param {boolean} [strict] Strictly sorted (default false).\n * @return {boolean} Return index.\n */\nexport function isSorted(arr, func, strict) {\n const compare = func || ascending;\n return arr.every(function (currentVal, index) {\n if (index === 0) {\n return true;\n }\n const res = compare(arr[index - 1], currentVal);\n return !(res > 0 || (strict && res === 0));\n });\n}\n","/**\n * @module ol/asserts\n */\n\n/**\n * @param {*} assertion Assertion we expected to be truthy.\n * @param {string} errorMessage Error message.\n */\nexport function assert(assertion, errorMessage) {\n if (!assertion) {\n throw new Error(errorMessage);\n }\n}\n","/**\n * RGB space.\n *\n * @module color-space/rgb\n */\n\nexport default {\n\tname: 'rgb',\n\tmin: [0,0,0],\n\tmax: [255,255,255],\n\tchannel: ['red', 'green', 'blue'],\n\talias: ['RGB']\n};\n","/**\n * CIE XYZ\n *\n * @module color-space/xyz\n */\nimport rgb from './rgb.js';\n\nvar xyz = {\n\tname: 'xyz',\n\tmin: [0,0,0],\n\tchannel: ['X','Y','Z'],\n\talias: ['XYZ', 'ciexyz', 'cie1931']\n};\n\n\n/**\n * Whitepoint reference values with observer/illuminant\n *\n * http://en.wikipedia.org/wiki/Standard_illuminant\n */\nxyz.whitepoint = {\n\t//1931 2°\n\t2: {\n\t\t//incadescent\n\t\tA:[109.85, 100, 35.585],\n\t\t// B:[],\n\t\tC: [98.074, 100, 118.232],\n\t\tD50: [96.422, 100, 82.521],\n\t\tD55: [95.682, 100, 92.149],\n\t\t//daylight\n\t\tD65: [95.045592705167, 100, 108.9057750759878],\n\t\tD75: [94.972, 100, 122.638],\n\t\t//flourescent\n\t\t// F1: [],\n\t\tF2: [99.187, 100, 67.395],\n\t\t// F3: [],\n\t\t// F4: [],\n\t\t// F5: [],\n\t\t// F6:[],\n\t\tF7: [95.044, 100, 108.755],\n\t\t// F8: [],\n\t\t// F9: [],\n\t\t// F10: [],\n\t\tF11: [100.966, 100, 64.370],\n\t\t// F12: [],\n\t\tE: [100,100,100]\n\t},\n\n\t//1964 10°\n\t10: {\n\t\t//incadescent\n\t\tA:[111.144, 100, 35.200],\n\t\tC: [97.285, 100, 116.145],\n\t\tD50: [96.720, 100, 81.427],\n\t\tD55: [95.799, 100, 90.926],\n\t\t//daylight\n\t\tD65: [94.811, 100, 107.304],\n\t\tD75: [94.416, 100, 120.641],\n\t\t//flourescent\n\t\tF2: [103.280, 100, 69.026],\n\t\tF7: [95.792, 100, 107.687],\n\t\tF11: [103.866, 100, 65.627],\n\t\tE: [100,100,100]\n\t}\n};\n\n\n/**\n * Top values are the whitepoint’s top values, default are D65\n */\nxyz.max = xyz.whitepoint[2].D65;\n\n\n/**\n * Transform xyz to rgb\n *\n * @param {Array} xyz Array of xyz values\n *\n * @return {Array} RGB values\n */\nxyz.rgb = function (_xyz, white) {\n\t//FIXME: make sure we have to divide like this. Probably we have to replace matrix as well then\n\twhite = white || xyz.whitepoint[2].E;\n\n\tvar x = _xyz[0] / white[0],\n\t\ty = _xyz[1] / white[1],\n\t\tz = _xyz[2] / white[2],\n\t\tr, g, b;\n\n\t// assume sRGB\n\t// http://www.brucelindbloom.com/index.html?Eqn_RGB_XYZ_Matrix.html\n\tr = (x * 3.240969941904521) + (y * -1.537383177570093) + (z * -0.498610760293);\n\tg = (x * -0.96924363628087) + (y * 1.87596750150772) + (z * 0.041555057407175);\n\tb = (x * 0.055630079696993) + (y * -0.20397695888897) + (z * 1.056971514242878);\n\n\tr = r > 0.0031308 ? ((1.055 * Math.pow(r, 1.0 / 2.4)) - 0.055)\n\t\t: r = (r * 12.92);\n\n\tg = g > 0.0031308 ? ((1.055 * Math.pow(g, 1.0 / 2.4)) - 0.055)\n\t\t: g = (g * 12.92);\n\n\tb = b > 0.0031308 ? ((1.055 * Math.pow(b, 1.0 / 2.4)) - 0.055)\n\t\t: b = (b * 12.92);\n\n\tr = Math.min(Math.max(0, r), 1);\n\tg = Math.min(Math.max(0, g), 1);\n\tb = Math.min(Math.max(0, b), 1);\n\n\treturn [r * 255, g * 255, b * 255];\n}\n\n\n\n/**\n * RGB to XYZ\n *\n * @param {Array} rgb RGB channels\n *\n * @return {Array} XYZ channels\n */\nrgb.xyz = function(rgb, white) {\n\tvar r = rgb[0] / 255,\n\t\t\tg = rgb[1] / 255,\n\t\t\tb = rgb[2] / 255;\n\n\t// assume sRGB\n\tr = r > 0.04045 ? Math.pow(((r + 0.055) / 1.055), 2.4) : (r / 12.92);\n\tg = g > 0.04045 ? Math.pow(((g + 0.055) / 1.055), 2.4) : (g / 12.92);\n\tb = b > 0.04045 ? Math.pow(((b + 0.055) / 1.055), 2.4) : (b / 12.92);\n\n\tvar x = (r * 0.41239079926595) + (g * 0.35758433938387) + (b * 0.18048078840183);\n\tvar y = (r * 0.21263900587151) + (g * 0.71516867876775) + (b * 0.072192315360733);\n\tvar z = (r * 0.019330818715591) + (g * 0.11919477979462) + (b * 0.95053215224966);\n\n\twhite = white || xyz.whitepoint[2].E;\n\n\treturn [x * white[0], y * white[1], z * white[2]];\n};\n\n\n\nexport default xyz;\n","/**\n * CIE LUV (C'est la vie)\n *\n * @module color-space/luv\n */\n import xyz from './xyz.js';\n\nexport default {\n\tname: 'luv',\n\t//NOTE: luv has no rigidly defined limits\n\t//easyrgb fails to get proper coords\n\t//boronine states no rigid limits\n\t//colorMine refers this ones:\n\tmin: [0,-134,-140],\n\tmax: [100,224,122],\n\tchannel: ['lightness', 'u', 'v'],\n\talias: ['LUV', 'cieluv', 'cie1976'],\n\n\txyz: function(arg, i, o){\n\t\tvar _u, _v, l, u, v, x, y, z, xn, yn, zn, un, vn;\n\t\tl = arg[0], u = arg[1], v = arg[2];\n\n\t\tif (l === 0) return [0,0,0];\n\n\t\t//get constants\n\t\t//var e = 0.008856451679035631; //(6/29)^3\n\t\tvar k = 0.0011070564598794539; //(3/29)^3\n\n\t\t//get illuminant/observer\n\t\ti = i || 'D65';\n\t\to = o || 2;\n\n\t\txn = xyz.whitepoint[o][i][0];\n\t\tyn = xyz.whitepoint[o][i][1];\n\t\tzn = xyz.whitepoint[o][i][2];\n\n\t\tun = (4 * xn) / (xn + (15 * yn) + (3 * zn));\n\t\tvn = (9 * yn) / (xn + (15 * yn) + (3 * zn));\n\t\t// un = 0.19783000664283;\n\t\t// vn = 0.46831999493879;\n\n\n\t\t_u = u / (13 * l) + un || 0;\n\t\t_v = v / (13 * l) + vn || 0;\n\n\t\ty = l > 8 ? yn * Math.pow( (l + 16) / 116 , 3) : yn * l * k;\n\n\t\t//wikipedia method\n\t\tx = y * 9 * _u / (4 * _v) || 0;\n\t\tz = y * (12 - 3 * _u - 20 * _v) / (4 * _v) || 0;\n\n\t\t//boronine method\n\t\t//https://github.com/boronine/husl/blob/master/husl.coffee#L201\n\t\t// x = 0 - (9 * y * _u) / ((_u - 4) * _v - _u * _v);\n\t\t// z = (9 * y - (15 * _v * y) - (_v * x)) / (3 * _v);\n\n\t\treturn [x, y, z];\n\t}\n};\n\n// http://www.brucelindbloom.com/index.html?Equations.html\n// https://github.com/boronine/husl/blob/master/husl.coffee\n//i - illuminant\n//o - observer\nxyz.luv = function(arg, i, o) {\n\tvar _u, _v, l, u, v, x, y, z, xn, yn, zn, un, vn;\n\n\t//get constants\n\tvar e = 0.008856451679035631; //(6/29)^3\n\tvar k = 903.2962962962961; //(29/3)^3\n\n\t//get illuminant/observer coords\n\ti = i || 'D65';\n\to = o || 2;\n\n\txn = xyz.whitepoint[o][i][0];\n\tyn = xyz.whitepoint[o][i][1];\n\tzn = xyz.whitepoint[o][i][2];\n\n\tun = (4 * xn) / (xn + (15 * yn) + (3 * zn));\n\tvn = (9 * yn) / (xn + (15 * yn) + (3 * zn));\n\n\n\tx = arg[0], y = arg[1], z = arg[2];\n\n\n\t_u = (4 * x) / (x + (15 * y) + (3 * z)) || 0;\n\t_v = (9 * y) / (x + (15 * y) + (3 * z)) || 0;\n\n\tvar yr = y/yn;\n\n\tl = yr <= e ? k * yr : 116 * Math.pow(yr, 1/3) - 16;\n\n\tu = 13 * l * (_u - un);\n\tv = 13 * l * (_v - vn);\n\n\treturn [l, u, v];\n};\n","/**\n * Cylindrical CIE LUV\n *\n * @module color-space/lchuv\n */\nimport luv from './luv.js';\nimport xyz from './xyz.js';\n\n//cylindrical luv\nvar lchuv = {\n\tname: 'lchuv',\n\tchannel: ['lightness', 'chroma', 'hue'],\n\talias: ['LCHuv', 'cielchuv'],\n\tmin: [0,0,0],\n\tmax: [100,100,360],\n\n\tluv: function(luv){\n\t\tvar l = luv[0],\n\t\tc = luv[1],\n\t\th = luv[2],\n\t\tu, v, hr;\n\n\t\thr = h / 360 * 2 * Math.PI;\n\t\tu = c * Math.cos(hr);\n\t\tv = c * Math.sin(hr);\n\t\treturn [l, u, v];\n\t},\n\n\txyz: function(arg) {\n\t\treturn luv.xyz(lchuv.luv(arg));\n\t}\n};\n\nexport default lchuv;\n\nluv.lchuv = function(luv){\n\tvar l = luv[0], u = luv[1], v = luv[2];\n\n\tvar c = Math.sqrt(u*u + v*v);\n\tvar hr = Math.atan2(v,u);\n\tvar h = hr * 360 / 2 / Math.PI;\n\tif (h < 0) {\n\t\th += 360;\n\t}\n\n\treturn [l,c,h]\n};\n\nxyz.lchuv = function(arg){\n return luv.lchuv(xyz.luv(arg));\n};\n","export default {\n\taliceblue: [240, 248, 255],\n\tantiquewhite: [250, 235, 215],\n\taqua: [0, 255, 255],\n\taquamarine: [127, 255, 212],\n\tazure: [240, 255, 255],\n\tbeige: [245, 245, 220],\n\tbisque: [255, 228, 196],\n\tblack: [0, 0, 0],\n\tblanchedalmond: [255, 235, 205],\n\tblue: [0, 0, 255],\n\tblueviolet: [138, 43, 226],\n\tbrown: [165, 42, 42],\n\tburlywood: [222, 184, 135],\n\tcadetblue: [95, 158, 160],\n\tchartreuse: [127, 255, 0],\n\tchocolate: [210, 105, 30],\n\tcoral: [255, 127, 80],\n\tcornflowerblue: [100, 149, 237],\n\tcornsilk: [255, 248, 220],\n\tcrimson: [220, 20, 60],\n\tcyan: [0, 255, 255],\n\tdarkblue: [0, 0, 139],\n\tdarkcyan: [0, 139, 139],\n\tdarkgoldenrod: [184, 134, 11],\n\tdarkgray: [169, 169, 169],\n\tdarkgreen: [0, 100, 0],\n\tdarkgrey: [169, 169, 169],\n\tdarkkhaki: [189, 183, 107],\n\tdarkmagenta: [139, 0, 139],\n\tdarkolivegreen: [85, 107, 47],\n\tdarkorange: [255, 140, 0],\n\tdarkorchid: [153, 50, 204],\n\tdarkred: [139, 0, 0],\n\tdarksalmon: [233, 150, 122],\n\tdarkseagreen: [143, 188, 143],\n\tdarkslateblue: [72, 61, 139],\n\tdarkslategray: [47, 79, 79],\n\tdarkslategrey: [47, 79, 79],\n\tdarkturquoise: [0, 206, 209],\n\tdarkviolet: [148, 0, 211],\n\tdeeppink: [255, 20, 147],\n\tdeepskyblue: [0, 191, 255],\n\tdimgray: [105, 105, 105],\n\tdimgrey: [105, 105, 105],\n\tdodgerblue: [30, 144, 255],\n\tfirebrick: [178, 34, 34],\n\tfloralwhite: [255, 250, 240],\n\tforestgreen: [34, 139, 34],\n\tfuchsia: [255, 0, 255],\n\tgainsboro: [220, 220, 220],\n\tghostwhite: [248, 248, 255],\n\tgold: [255, 215, 0],\n\tgoldenrod: [218, 165, 32],\n\tgray: [128, 128, 128],\n\tgreen: [0, 128, 0],\n\tgreenyellow: [173, 255, 47],\n\tgrey: [128, 128, 128],\n\thoneydew: [240, 255, 240],\n\thotpink: [255, 105, 180],\n\tindianred: [205, 92, 92],\n\tindigo: [75, 0, 130],\n\tivory: [255, 255, 240],\n\tkhaki: [240, 230, 140],\n\tlavender: [230, 230, 250],\n\tlavenderblush: [255, 240, 245],\n\tlawngreen: [124, 252, 0],\n\tlemonchiffon: [255, 250, 205],\n\tlightblue: [173, 216, 230],\n\tlightcoral: [240, 128, 128],\n\tlightcyan: [224, 255, 255],\n\tlightgoldenrodyellow: [250, 250, 210],\n\tlightgray: [211, 211, 211],\n\tlightgreen: [144, 238, 144],\n\tlightgrey: [211, 211, 211],\n\tlightpink: [255, 182, 193],\n\tlightsalmon: [255, 160, 122],\n\tlightseagreen: [32, 178, 170],\n\tlightskyblue: [135, 206, 250],\n\tlightslategray: [119, 136, 153],\n\tlightslategrey: [119, 136, 153],\n\tlightsteelblue: [176, 196, 222],\n\tlightyellow: [255, 255, 224],\n\tlime: [0, 255, 0],\n\tlimegreen: [50, 205, 50],\n\tlinen: [250, 240, 230],\n\tmagenta: [255, 0, 255],\n\tmaroon: [128, 0, 0],\n\tmediumaquamarine: [102, 205, 170],\n\tmediumblue: [0, 0, 205],\n\tmediumorchid: [186, 85, 211],\n\tmediumpurple: [147, 112, 219],\n\tmediumseagreen: [60, 179, 113],\n\tmediumslateblue: [123, 104, 238],\n\tmediumspringgreen: [0, 250, 154],\n\tmediumturquoise: [72, 209, 204],\n\tmediumvioletred: [199, 21, 133],\n\tmidnightblue: [25, 25, 112],\n\tmintcream: [245, 255, 250],\n\tmistyrose: [255, 228, 225],\n\tmoccasin: [255, 228, 181],\n\tnavajowhite: [255, 222, 173],\n\tnavy: [0, 0, 128],\n\toldlace: [253, 245, 230],\n\tolive: [128, 128, 0],\n\tolivedrab: [107, 142, 35],\n\torange: [255, 165, 0],\n\torangered: [255, 69, 0],\n\torchid: [218, 112, 214],\n\tpalegoldenrod: [238, 232, 170],\n\tpalegreen: [152, 251, 152],\n\tpaleturquoise: [175, 238, 238],\n\tpalevioletred: [219, 112, 147],\n\tpapayawhip: [255, 239, 213],\n\tpeachpuff: [255, 218, 185],\n\tperu: [205, 133, 63],\n\tpink: [255, 192, 203],\n\tplum: [221, 160, 221],\n\tpowderblue: [176, 224, 230],\n\tpurple: [128, 0, 128],\n\trebeccapurple: [102, 51, 153],\n\tred: [255, 0, 0],\n\trosybrown: [188, 143, 143],\n\troyalblue: [65, 105, 225],\n\tsaddlebrown: [139, 69, 19],\n\tsalmon: [250, 128, 114],\n\tsandybrown: [244, 164, 96],\n\tseagreen: [46, 139, 87],\n\tseashell: [255, 245, 238],\n\tsienna: [160, 82, 45],\n\tsilver: [192, 192, 192],\n\tskyblue: [135, 206, 235],\n\tslateblue: [106, 90, 205],\n\tslategray: [112, 128, 144],\n\tslategrey: [112, 128, 144],\n\tsnow: [255, 250, 250],\n\tspringgreen: [0, 255, 127],\n\tsteelblue: [70, 130, 180],\n\ttan: [210, 180, 140],\n\tteal: [0, 128, 128],\n\tthistle: [216, 191, 216],\n\ttomato: [255, 99, 71],\n\tturquoise: [64, 224, 208],\n\tviolet: [238, 130, 238],\n\twheat: [245, 222, 179],\n\twhite: [255, 255, 255],\n\twhitesmoke: [245, 245, 245],\n\tyellow: [255, 255, 0],\n\tyellowgreen: [154, 205, 50]\n}\n","/**\n * @module color-parse\n */\nimport names from 'color-name'\n\nexport default parse\n\n/**\n * Base hues\n * http://dev.w3.org/csswg/css-color/#typedef-named-hue\n */\n//FIXME: use external hue detector\nvar baseHues = {\n\tred: 0,\n\torange: 60,\n\tyellow: 120,\n\tgreen: 180,\n\tblue: 240,\n\tpurple: 300\n}\n\n/**\n * Parse color from the string passed\n *\n * @return {Object} A space indicator `space`, an array `values` and `alpha`\n */\nfunction parse(cstr) {\n\tvar m, parts = [], alpha = 1, space\n\n\t//numeric case\n\tif (typeof cstr === 'number') {\n\t\treturn { space: 'rgb', values: [cstr >>> 16, (cstr & 0x00ff00) >>> 8, cstr & 0x0000ff], alpha: 1 }\n\t}\n\tif (typeof cstr === 'number') return { space: 'rgb', values: [cstr >>> 16, (cstr & 0x00ff00) >>> 8, cstr & 0x0000ff], alpha: 1 }\n\n\tcstr = String(cstr).toLowerCase();\n\n\t//keyword\n\tif (names[cstr]) {\n\t\tparts = names[cstr].slice()\n\t\tspace = 'rgb'\n\t}\n\n\t//reserved words\n\telse if (cstr === 'transparent') {\n\t\talpha = 0\n\t\tspace = 'rgb'\n\t\tparts = [0, 0, 0]\n\t}\n\n\t//hex\n\telse if (cstr[0] === '#') {\n\t\tvar base = cstr.slice(1)\n\t\tvar size = base.length\n\t\tvar isShort = size <= 4\n\t\talpha = 1\n\n\t\tif (isShort) {\n\t\t\tparts = [\n\t\t\t\tparseInt(base[0] + base[0], 16),\n\t\t\t\tparseInt(base[1] + base[1], 16),\n\t\t\t\tparseInt(base[2] + base[2], 16)\n\t\t\t]\n\t\t\tif (size === 4) {\n\t\t\t\talpha = parseInt(base[3] + base[3], 16) / 255\n\t\t\t}\n\t\t}\n\t\telse {\n\t\t\tparts = [\n\t\t\t\tparseInt(base[0] + base[1], 16),\n\t\t\t\tparseInt(base[2] + base[3], 16),\n\t\t\t\tparseInt(base[4] + base[5], 16)\n\t\t\t]\n\t\t\tif (size === 8) {\n\t\t\t\talpha = parseInt(base[6] + base[7], 16) / 255\n\t\t\t}\n\t\t}\n\n\t\tif (!parts[0]) parts[0] = 0\n\t\tif (!parts[1]) parts[1] = 0\n\t\tif (!parts[2]) parts[2] = 0\n\n\t\tspace = 'rgb'\n\t}\n\n\t// color space\n\telse if (m = /^((?:rgba?|hs[lvb]a?|hwba?|cmyk?|xy[zy]|gray|lab|lchu?v?|[ly]uv|lms|oklch|oklab|color))\\s*\\(([^\\)]*)\\)/.exec(cstr)) {\n\t\tvar name = m[1]\n\t\tspace = name.replace(/a$/, '')\n\t\tvar dims = space === 'cmyk' ? 4 : space === 'gray' ? 1 : 3\n\t\tparts = m[2].trim().split(/\\s*[,\\/]\\s*|\\s+/)\n\n\t\t// color(srgb-linear x x x) -> srgb-linear(x x x)\n\t\tif (space === 'color') space = parts.shift()\n\n\t\tparts = parts.map(function (x, i) {\n\t\t\t//\n\t\t\tif (x[x.length - 1] === '%') {\n\t\t\t\tx = parseFloat(x) / 100\n\t\t\t\t// alpha -> 0..1\n\t\t\t\tif (i === 3) return x\n\t\t\t\t// rgb -> 0..255\n\t\t\t\tif (space === 'rgb') return x * 255\n\t\t\t\t// hsl, hwb H -> 0..100\n\t\t\t\tif (space[0] === 'h') return x * 100\n\t\t\t\t// lch, lab L -> 0..100\n\t\t\t\tif (space[0] === 'l' && !i) return x * 100\n\t\t\t\t// lab A B -> -125..125\n\t\t\t\tif (space === 'lab') return x * 125\n\t\t\t\t// lch C -> 0..150, H -> 0..360\n\t\t\t\tif (space === 'lch') return i < 2 ? x * 150 : x * 360\n\t\t\t\t// oklch/oklab L -> 0..1\n\t\t\t\tif (space[0] === 'o' && !i) return x\n\t\t\t\t// oklab A B -> -0.4..0.4\n\t\t\t\tif (space === 'oklab') return x * 0.4\n\t\t\t\t// oklch C -> 0..0.4, H -> 0..360\n\t\t\t\tif (space === 'oklch') return i < 2 ? x * 0.4 : x * 360\n\t\t\t\t// color(xxx) -> 0..1\n\t\t\t\treturn x\n\t\t\t}\n\n\t\t\t//hue\n\t\t\tif (space[i] === 'h' || (i === 2 && space[space.length - 1] === 'h')) {\n\t\t\t\t//\n\t\t\t\tif (baseHues[x] !== undefined) return baseHues[x]\n\t\t\t\t//\n\t\t\t\tif (x.endsWith('deg')) return parseFloat(x)\n\t\t\t\t//\n\t\t\t\tif (x.endsWith('turn')) return parseFloat(x) * 360\n\t\t\t\tif (x.endsWith('grad')) return parseFloat(x) * 360 / 400\n\t\t\t\tif (x.endsWith('rad')) return parseFloat(x) * 180 / Math.PI\n\t\t\t}\n\t\t\tif (x === 'none') return 0\n\t\t\treturn parseFloat(x)\n\t\t});\n\n\t\talpha = parts.length > dims ? parts.pop() : 1\n\t}\n\n\t//named channels case\n\telse if (/[0-9](?:\\s|\\/|,)/.test(cstr)) {\n\t\tparts = cstr.match(/([0-9]+)/g).map(function (value) {\n\t\t\treturn parseFloat(value)\n\t\t})\n\n\t\tspace = cstr.match(/([a-z])/ig)?.join('')?.toLowerCase() || 'rgb'\n\t}\n\n\treturn {\n\t\tspace,\n\t\tvalues: parts,\n\t\talpha\n\t}\n}\n","/**\n * @module color-space/hsl\n */\nimport rgb from './rgb.js';\n\nexport default {\n\tname: 'hsl',\n\tmin: [0,0,0],\n\tmax: [360,100,100],\n\tchannel: ['hue', 'saturation', 'lightness'],\n\talias: ['HSL'],\n\n\trgb: function(hsl) {\n\t\tvar h = hsl[0]/360, s = hsl[1]/100, l = hsl[2]/100, t1, t2, t3, rgb, val, i=0;\n\n\t\tif (s === 0) return val = l * 255, [val, val, val];\n\n\t\tt2 = l < 0.5 ? l * (1 + s) : l + s - l * s;\n\t\tt1 = 2 * l - t2;\n\n\t\trgb = [0, 0, 0];\n\t\tfor (;i<3;) {\n\t\t\tt3 = h + 1 / 3 * - (i - 1);\n\t\t\tt3 < 0 ? t3++ : t3 > 1 && t3--;\n\t\t\tval = 6 * t3 < 1 ? t1 + (t2 - t1) * 6 * t3 :\n\t\t\t2 * t3 < 1 ? t2 :\n\t\t\t3 * t3 < 2 ? t1 + (t2 - t1) * (2 / 3 - t3) * 6 :\n\t\t\tt1;\n\t\t\trgb[i++] = val * 255;\n\t\t}\n\n\t\treturn rgb;\n\t}\n};\n\n\n//extend rgb\nrgb.hsl = function(rgb) {\n\tvar r = rgb[0]/255,\n\t\t\tg = rgb[1]/255,\n\t\t\tb = rgb[2]/255,\n\t\t\tmin = Math.min(r, g, b),\n\t\t\tmax = Math.max(r, g, b),\n\t\t\tdelta = max - min,\n\t\t\th, s, l;\n\n\tif (max === min) {\n\t\th = 0;\n\t}\n\telse if (r === max) {\n\t\th = (g - b) / delta;\n\t}\n\telse if (g === max) {\n\t\th = 2 + (b - r) / delta;\n\t}\n\telse if (b === max) {\n\t\th = 4 + (r - g)/ delta;\n\t}\n\n\th = Math.min(h * 60, 360);\n\n\tif (h < 0) {\n\t\th += 360;\n\t}\n\n\tl = (min + max) / 2;\n\n\tif (max === min) {\n\t\ts = 0;\n\t}\n\telse if (l <= 0.5) {\n\t\ts = delta / (max + min);\n\t}\n\telse {\n\t\ts = delta / (2 - max - min);\n\t}\n\n\treturn [h, s * 100, l * 100];\n};\n","/**\n * @module ol/color\n */\nimport lchuv from 'color-space/lchuv.js';\nimport parseRgba from 'color-rgba';\nimport rgb from 'color-space/rgb.js';\nimport xyz from 'color-space/xyz.js';\nimport {clamp} from './math.js';\n\n/**\n * A color represented as a short array [red, green, blue, alpha].\n * red, green, and blue should be integers in the range 0..255 inclusive.\n * alpha should be a float in the range 0..1 inclusive. If no alpha value is\n * given then `1` will be used.\n * @typedef {Array} Color\n * @api\n */\n\n/**\n * Return the color as an rgba string.\n * @param {Color|string} color Color.\n * @return {string} Rgba string.\n * @api\n */\nexport function asString(color) {\n if (typeof color === 'string') {\n return color;\n }\n return toString(color);\n}\n\n/**\n * @type {number}\n */\nconst MAX_CACHE_SIZE = 1024;\n\n/**\n * We maintain a small cache of parsed strings. Whenever the cache grows too large,\n * we delete an arbitrary set of the entries.\n *\n * @type {Object}\n */\nconst cache = {};\n\n/**\n * @type {number}\n */\nlet cacheSize = 0;\n\n/**\n * @param {Color} color A color that may or may not have an alpha channel.\n * @return {Color} The input color with an alpha channel. If the input color has\n * an alpha channel, the input color will be returned unchanged. Otherwise, a new\n * array will be returned with the input color and an alpha channel of 1.\n */\nexport function withAlpha(color) {\n if (color.length === 4) {\n return color;\n }\n const output = color.slice();\n output[3] = 1;\n return output;\n}\n\n/**\n * @param {Color} color RGBA color.\n * @return {Color} LCHuv color with alpha.\n */\nexport function rgbaToLcha(color) {\n const output = xyz.lchuv(rgb.xyz(color));\n output[3] = color[3];\n return output;\n}\n\n/**\n * @param {Color} color LCHuv color with alpha.\n * @return {Color} RGBA color.\n */\nexport function lchaToRgba(color) {\n const output = xyz.rgb(lchuv.xyz(color));\n output[3] = color[3];\n return output;\n}\n\n/**\n * @param {string} s String.\n * @return {Color} Color.\n */\nexport function fromString(s) {\n if (cache.hasOwnProperty(s)) {\n return cache[s];\n }\n if (cacheSize >= MAX_CACHE_SIZE) {\n let i = 0;\n for (const key in cache) {\n if ((i++ & 3) === 0) {\n delete cache[key];\n --cacheSize;\n }\n }\n }\n\n const color = parseRgba(s);\n if (color.length !== 4) {\n throw new Error('failed to parse \"' + s + '\" as color');\n }\n for (const c of color) {\n if (isNaN(c)) {\n throw new Error('failed to parse \"' + s + '\" as color');\n }\n }\n normalize(color);\n cache[s] = color;\n ++cacheSize;\n return color;\n}\n\n/**\n * Return the color as an array. This function maintains a cache of calculated\n * arrays which means the result should not be modified.\n * @param {Color|string} color Color.\n * @return {Color} Color.\n * @api\n */\nexport function asArray(color) {\n if (Array.isArray(color)) {\n return color;\n }\n return fromString(color);\n}\n\n/**\n * Exported for the tests.\n * @param {Color} color Color.\n * @return {Color} Clamped color.\n */\nexport function normalize(color) {\n color[0] = clamp((color[0] + 0.5) | 0, 0, 255);\n color[1] = clamp((color[1] + 0.5) | 0, 0, 255);\n color[2] = clamp((color[2] + 0.5) | 0, 0, 255);\n color[3] = clamp(color[3], 0, 1);\n return color;\n}\n\n/**\n * @param {Color} color Color.\n * @return {string} String.\n */\nexport function toString(color) {\n let r = color[0];\n if (r != (r | 0)) {\n r = (r + 0.5) | 0;\n }\n let g = color[1];\n if (g != (g | 0)) {\n g = (g + 0.5) | 0;\n }\n let b = color[2];\n if (b != (b | 0)) {\n b = (b + 0.5) | 0;\n }\n const a = color[3] === undefined ? 1 : Math.round(color[3] * 1000) / 1000;\n return 'rgba(' + r + ',' + g + ',' + b + ',' + a + ')';\n}\n\n/**\n * @param {string} s String.\n * @return {boolean} Whether the string is actually a valid color\n */\nexport function isStringColor(s) {\n try {\n fromString(s);\n return true;\n } catch (_) {\n return false;\n }\n}\n","/** @module color-rgba */\nimport parse from 'color-parse'\nimport rgb from 'color-space/rgb.js'\nimport hsl from 'color-space/hsl.js'\n\nexport default function rgba(color) {\n\t// template literals\n\tif (Array.isArray(color) && color.raw) color = String.raw(...arguments)\n\tif (color instanceof Number) color = +color\n\n\tvar values, i, l\n\n\t//attempt to parse non-array arguments\n\tvar parsed = parse(color)\n\n\tif (!parsed.space) return []\n\n\tconst min = parsed.space[0] === 'h' ? hsl.min : rgb.min\n\tconst max = parsed.space[0] === 'h' ? hsl.max : rgb.max\n\n\tvalues = Array(3)\n\tvalues[0] = Math.min(Math.max(parsed.values[0], min[0]), max[0])\n\tvalues[1] = Math.min(Math.max(parsed.values[1], min[1]), max[1])\n\tvalues[2] = Math.min(Math.max(parsed.values[2], min[2]), max[2])\n\n\tif (parsed.space[0] === 'h') {\n\t\tvalues = hsl.rgb(values)\n\t}\n\n\tvalues.push(Math.min(Math.max(parsed.alpha, 0), 1))\n\n\treturn values\n}\n","/**\n * @module ol/colorlike\n */\nimport ImageState from './ImageState.js';\nimport {createCanvasContext2D} from './dom.js';\nimport {get as getIconImage} from './style/IconImage.js';\nimport {shared as iconCache} from './style/IconImageCache.js';\nimport {toString} from './color.js';\n\n/**\n * @typedef {Object} PatternDescriptor\n * @property {string} src Pattern image URL\n * @property {import(\"./color.js\").Color|string} [color] Color to tint the pattern with.\n * @property {import(\"./size.js\").Size} [size] Size of the desired slice from the pattern image.\n * Use this together with `offset` when the pattern image is a sprite sheet.\n * @property {import(\"./size.js\").Size} [offset] Offset of the desired slice from the pattern image.\n * Use this together with `size` when the pattern image is a sprite sheet.\n */\n\n/**\n * A type accepted by CanvasRenderingContext2D.fillStyle\n * or CanvasRenderingContext2D.strokeStyle.\n * Represents a color, [CanvasPattern](https://developer.mozilla.org/en-US/docs/Web/API/CanvasPattern),\n * or [CanvasGradient](https://developer.mozilla.org/en-US/docs/Web/API/CanvasGradient). The origin for\n * patterns and gradients as fill style is an increment of 512 css pixels from map coordinate\n * `[0, 0]`. For seamless repeat patterns, width and height of the pattern image\n * must be a factor of two (2, 4, 8, ..., 512).\n *\n * @typedef {string|CanvasPattern|CanvasGradient} ColorLike\n * @api\n */\n\n/**\n * @param {import(\"./color.js\").Color|ColorLike|PatternDescriptor|null} color Color.\n * @return {ColorLike|null} The color as an {@link ol/colorlike~ColorLike}.\n * @api\n */\nexport function asColorLike(color) {\n if (!color) {\n return null;\n }\n if (Array.isArray(color)) {\n return toString(color);\n }\n if (typeof color === 'object' && 'src' in color) {\n return asCanvasPattern(color);\n }\n return color;\n}\n\n/**\n * @param {PatternDescriptor} pattern Pattern descriptor.\n * @return {CanvasPattern|null} Canvas pattern or null if the pattern referenced in the\n * PatternDescriptor was not found in the icon image cache.\n */\nfunction asCanvasPattern(pattern) {\n if (!pattern.offset || !pattern.size) {\n return iconCache.getPattern(pattern.src, 'anonymous', pattern.color);\n }\n\n const cacheKey = pattern.src + ':' + pattern.offset;\n\n const canvasPattern = iconCache.getPattern(\n cacheKey,\n undefined,\n pattern.color,\n );\n if (canvasPattern) {\n return canvasPattern;\n }\n\n const iconImage = iconCache.get(pattern.src, 'anonymous', null);\n if (iconImage.getImageState() !== ImageState.LOADED) {\n return null;\n }\n const patternCanvasContext = createCanvasContext2D(\n pattern.size[0],\n pattern.size[1],\n );\n patternCanvasContext.drawImage(\n iconImage.getImage(1),\n pattern.offset[0],\n pattern.offset[1],\n pattern.size[0],\n pattern.size[1],\n 0,\n 0,\n pattern.size[0],\n pattern.size[1],\n );\n getIconImage(\n patternCanvasContext.canvas,\n cacheKey,\n undefined,\n ImageState.LOADED,\n pattern.color,\n true,\n );\n return iconCache.getPattern(cacheKey, undefined, pattern.color);\n}\n","/**\n * @module ol/console\n */\n\n/**\n * @typedef {'info'|'warn'|'error'|'none'} Level\n */\n\n/**\n * @type {Object}\n */\nconst levels = {\n info: 1,\n warn: 2,\n error: 3,\n none: 4,\n};\n\n/**\n * @type {number}\n */\nlet level = levels.info;\n\n/**\n * Set the logging level. By default, the level is set to 'info' and all\n * messages will be logged. Set to 'warn' to only display warnings and errors.\n * Set to 'error' to only display errors. Set to 'none' to silence all messages.\n *\n * @param {Level} l The new level.\n */\nexport function setLevel(l) {\n level = levels[l];\n}\n\n/**\n * @param {...any} args Arguments to log\n */\nexport function log(...args) {\n if (level > levels.info) {\n return;\n }\n console.log(...args); // eslint-disable-line no-console\n}\n\n/**\n * @param {...any} args Arguments to log\n */\nexport function warn(...args) {\n if (level > levels.warn) {\n return;\n }\n console.warn(...args); // eslint-disable-line no-console\n}\n\n/**\n * @param {...any} args Arguments to log\n */\nexport function error(...args) {\n if (level > levels.error) {\n return;\n }\n console.error(...args); // eslint-disable-line no-console\n}\n","/**\n * @module ol/coordinate\n */\nimport {getWidth} from './extent.js';\nimport {modulo, toFixed} from './math.js';\nimport {padNumber} from './string.js';\n\n/**\n * An array of numbers representing an `xy`, `xyz` or `xyzm` coordinate.\n * Example: `[16, 48]`.\n * @typedef {Array} Coordinate\n * @api\n */\n\n/**\n * A function that takes a {@link module:ol/coordinate~Coordinate} and\n * transforms it into a `{string}`.\n *\n * @typedef {function((Coordinate|undefined)): string} CoordinateFormat\n * @api\n */\n\n/**\n * Add `delta` to `coordinate`. `coordinate` is modified in place and returned\n * by the function.\n *\n * Example:\n *\n * import {add} from 'ol/coordinate.js';\n *\n * const coord = [7.85, 47.983333];\n * add(coord, [-2, 4]);\n * // coord is now [5.85, 51.983333]\n *\n * @param {Coordinate} coordinate Coordinate.\n * @param {Coordinate} delta Delta.\n * @return {Coordinate} The input coordinate adjusted by\n * the given delta.\n * @api\n */\nexport function add(coordinate, delta) {\n coordinate[0] += +delta[0];\n coordinate[1] += +delta[1];\n return coordinate;\n}\n\n/**\n * Calculates the point closest to the passed coordinate on the passed circle.\n *\n * @param {Coordinate} coordinate The coordinate.\n * @param {import(\"./geom/Circle.js\").default} circle The circle.\n * @return {Coordinate} Closest point on the circumference.\n */\nexport function closestOnCircle(coordinate, circle) {\n const r = circle.getRadius();\n const center = circle.getCenter();\n const x0 = center[0];\n const y0 = center[1];\n const x1 = coordinate[0];\n const y1 = coordinate[1];\n\n let dx = x1 - x0;\n const dy = y1 - y0;\n if (dx === 0 && dy === 0) {\n dx = 1;\n }\n const d = Math.sqrt(dx * dx + dy * dy);\n\n const x = x0 + (r * dx) / d;\n const y = y0 + (r * dy) / d;\n\n return [x, y];\n}\n\n/**\n * Calculates the point closest to the passed coordinate on the passed segment.\n * This is the foot of the perpendicular of the coordinate to the segment when\n * the foot is on the segment, or the closest segment coordinate when the foot\n * is outside the segment.\n *\n * @param {Coordinate} coordinate The coordinate.\n * @param {Array} segment The two coordinates\n * of the segment.\n * @return {Coordinate} The foot of the perpendicular of\n * the coordinate to the segment.\n */\nexport function closestOnSegment(coordinate, segment) {\n const x0 = coordinate[0];\n const y0 = coordinate[1];\n const start = segment[0];\n const end = segment[1];\n const x1 = start[0];\n const y1 = start[1];\n const x2 = end[0];\n const y2 = end[1];\n const dx = x2 - x1;\n const dy = y2 - y1;\n const along =\n dx === 0 && dy === 0\n ? 0\n : (dx * (x0 - x1) + dy * (y0 - y1)) / (dx * dx + dy * dy || 0);\n let x, y;\n if (along <= 0) {\n x = x1;\n y = y1;\n } else if (along >= 1) {\n x = x2;\n y = y2;\n } else {\n x = x1 + along * dx;\n y = y1 + along * dy;\n }\n return [x, y];\n}\n\n/**\n * Returns a {@link module:ol/coordinate~CoordinateFormat} function that can be\n * used to format\n * a {Coordinate} to a string.\n *\n * Example without specifying the fractional digits:\n *\n * import {createStringXY} from 'ol/coordinate.js';\n *\n * const coord = [7.85, 47.983333];\n * const stringifyFunc = createStringXY();\n * const out = stringifyFunc(coord);\n * // out is now '8, 48'\n *\n * Example with explicitly specifying 2 fractional digits:\n *\n * import {createStringXY} from 'ol/coordinate.js';\n *\n * const coord = [7.85, 47.983333];\n * const stringifyFunc = createStringXY(2);\n * const out = stringifyFunc(coord);\n * // out is now '7.85, 47.98'\n *\n * @param {number} [fractionDigits] The number of digits to include\n * after the decimal point. Default is `0`.\n * @return {CoordinateFormat} Coordinate format.\n * @api\n */\nexport function createStringXY(fractionDigits) {\n return (\n /**\n * @param {Coordinate} coordinate Coordinate.\n * @return {string} String XY.\n */\n function (coordinate) {\n return toStringXY(coordinate, fractionDigits);\n }\n );\n}\n\n/**\n * @param {string} hemispheres Hemispheres.\n * @param {number} degrees Degrees.\n * @param {number} [fractionDigits] The number of digits to include\n * after the decimal point. Default is `0`.\n * @return {string} String.\n */\nexport function degreesToStringHDMS(hemispheres, degrees, fractionDigits) {\n const normalizedDegrees = modulo(degrees + 180, 360) - 180;\n const x = Math.abs(3600 * normalizedDegrees);\n const decimals = fractionDigits || 0;\n\n let deg = Math.floor(x / 3600);\n let min = Math.floor((x - deg * 3600) / 60);\n let sec = toFixed(x - deg * 3600 - min * 60, decimals);\n\n if (sec >= 60) {\n sec = 0;\n min += 1;\n }\n\n if (min >= 60) {\n min = 0;\n deg += 1;\n }\n\n let hdms = deg + '\\u00b0';\n if (min !== 0 || sec !== 0) {\n hdms += ' ' + padNumber(min, 2) + '\\u2032';\n }\n if (sec !== 0) {\n hdms += ' ' + padNumber(sec, 2, decimals) + '\\u2033';\n }\n if (normalizedDegrees !== 0) {\n hdms += ' ' + hemispheres.charAt(normalizedDegrees < 0 ? 1 : 0);\n }\n\n return hdms;\n}\n\n/**\n * Transforms the given {@link module:ol/coordinate~Coordinate} to a string\n * using the given string template. The strings `{x}` and `{y}` in the template\n * will be replaced with the first and second coordinate values respectively.\n *\n * Example without specifying the fractional digits:\n *\n * import {format} from 'ol/coordinate.js';\n *\n * const coord = [7.85, 47.983333];\n * const template = 'Coordinate is ({x}|{y}).';\n * const out = format(coord, template);\n * // out is now 'Coordinate is (8|48).'\n *\n * Example explicitly specifying the fractional digits:\n *\n * import {format} from 'ol/coordinate.js';\n *\n * const coord = [7.85, 47.983333];\n * const template = 'Coordinate is ({x}|{y}).';\n * const out = format(coord, template, 2);\n * // out is now 'Coordinate is (7.85|47.98).'\n *\n * @param {Coordinate} coordinate Coordinate.\n * @param {string} template A template string with `{x}` and `{y}` placeholders\n * that will be replaced by first and second coordinate values.\n * @param {number} [fractionDigits] The number of digits to include\n * after the decimal point. Default is `0`.\n * @return {string} Formatted coordinate.\n * @api\n */\nexport function format(coordinate, template, fractionDigits) {\n if (coordinate) {\n return template\n .replace('{x}', coordinate[0].toFixed(fractionDigits))\n .replace('{y}', coordinate[1].toFixed(fractionDigits));\n }\n return '';\n}\n\n/**\n * @param {Coordinate} coordinate1 First coordinate.\n * @param {Coordinate} coordinate2 Second coordinate.\n * @return {boolean} The two coordinates are equal.\n */\nexport function equals(coordinate1, coordinate2) {\n let equals = true;\n for (let i = coordinate1.length - 1; i >= 0; --i) {\n if (coordinate1[i] != coordinate2[i]) {\n equals = false;\n break;\n }\n }\n return equals;\n}\n\n/**\n * Rotate `coordinate` by `angle`. `coordinate` is modified in place and\n * returned by the function.\n *\n * Example:\n *\n * import {rotate} from 'ol/coordinate.js';\n *\n * const coord = [7.85, 47.983333];\n * const rotateRadians = Math.PI / 2; // 90 degrees\n * rotate(coord, rotateRadians);\n * // coord is now [-47.983333, 7.85]\n *\n * @param {Coordinate} coordinate Coordinate.\n * @param {number} angle Angle in radian.\n * @return {Coordinate} Coordinate.\n * @api\n */\nexport function rotate(coordinate, angle) {\n const cosAngle = Math.cos(angle);\n const sinAngle = Math.sin(angle);\n const x = coordinate[0] * cosAngle - coordinate[1] * sinAngle;\n const y = coordinate[1] * cosAngle + coordinate[0] * sinAngle;\n coordinate[0] = x;\n coordinate[1] = y;\n return coordinate;\n}\n\n/**\n * Scale `coordinate` by `scale`. `coordinate` is modified in place and returned\n * by the function.\n *\n * Example:\n *\n * import {scale as scaleCoordinate} from 'ol/coordinate.js';\n *\n * const coord = [7.85, 47.983333];\n * const scale = 1.2;\n * scaleCoordinate(coord, scale);\n * // coord is now [9.42, 57.5799996]\n *\n * @param {Coordinate} coordinate Coordinate.\n * @param {number} scale Scale factor.\n * @return {Coordinate} Coordinate.\n */\nexport function scale(coordinate, scale) {\n coordinate[0] *= scale;\n coordinate[1] *= scale;\n return coordinate;\n}\n\n/**\n * @param {Coordinate} coord1 First coordinate.\n * @param {Coordinate} coord2 Second coordinate.\n * @return {number} Squared distance between coord1 and coord2.\n */\nexport function squaredDistance(coord1, coord2) {\n const dx = coord1[0] - coord2[0];\n const dy = coord1[1] - coord2[1];\n return dx * dx + dy * dy;\n}\n\n/**\n * @param {Coordinate} coord1 First coordinate.\n * @param {Coordinate} coord2 Second coordinate.\n * @return {number} Distance between coord1 and coord2.\n */\nexport function distance(coord1, coord2) {\n return Math.sqrt(squaredDistance(coord1, coord2));\n}\n\n/**\n * Calculate the squared distance from a coordinate to a line segment.\n *\n * @param {Coordinate} coordinate Coordinate of the point.\n * @param {Array} segment Line segment (2\n * coordinates).\n * @return {number} Squared distance from the point to the line segment.\n */\nexport function squaredDistanceToSegment(coordinate, segment) {\n return squaredDistance(coordinate, closestOnSegment(coordinate, segment));\n}\n\n/**\n * Format a geographic coordinate with the hemisphere, degrees, minutes, and\n * seconds.\n *\n * Example without specifying fractional digits:\n *\n * import {toStringHDMS} from 'ol/coordinate.js';\n *\n * const coord = [7.85, 47.983333];\n * const out = toStringHDMS(coord);\n * // out is now '47° 58′ 60″ N 7° 50′ 60″ E'\n *\n * Example explicitly specifying 1 fractional digit:\n *\n * import {toStringHDMS} from 'ol/coordinate.js';\n *\n * const coord = [7.85, 47.983333];\n * const out = toStringHDMS(coord, 1);\n * // out is now '47° 58′ 60.0″ N 7° 50′ 60.0″ E'\n *\n * @param {Coordinate} coordinate Coordinate.\n * @param {number} [fractionDigits] The number of digits to include\n * after the decimal point. Default is `0`.\n * @return {string} Hemisphere, degrees, minutes and seconds.\n * @api\n */\nexport function toStringHDMS(coordinate, fractionDigits) {\n if (coordinate) {\n return (\n degreesToStringHDMS('NS', coordinate[1], fractionDigits) +\n ' ' +\n degreesToStringHDMS('EW', coordinate[0], fractionDigits)\n );\n }\n return '';\n}\n\n/**\n * Format a coordinate as a comma delimited string.\n *\n * Example without specifying fractional digits:\n *\n * import {toStringXY} from 'ol/coordinate.js';\n *\n * const coord = [7.85, 47.983333];\n * const out = toStringXY(coord);\n * // out is now '8, 48'\n *\n * Example explicitly specifying 1 fractional digit:\n *\n * import {toStringXY} from 'ol/coordinate.js';\n *\n * const coord = [7.85, 47.983333];\n * const out = toStringXY(coord, 1);\n * // out is now '7.8, 48.0'\n *\n * @param {Coordinate} coordinate Coordinate.\n * @param {number} [fractionDigits] The number of digits to include\n * after the decimal point. Default is `0`.\n * @return {string} XY.\n * @api\n */\nexport function toStringXY(coordinate, fractionDigits) {\n return format(coordinate, '{x}, {y}', fractionDigits);\n}\n\n/**\n * Modifies the provided coordinate in-place to be within the real world\n * extent. The lower projection extent boundary is inclusive, the upper one\n * exclusive.\n *\n * @param {Coordinate} coordinate Coordinate.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @return {Coordinate} The coordinate within the real world extent.\n */\nexport function wrapX(coordinate, projection) {\n if (projection.canWrapX()) {\n const worldWidth = getWidth(projection.getExtent());\n const worldsAway = getWorldsAway(coordinate, projection, worldWidth);\n if (worldsAway) {\n coordinate[0] -= worldsAway * worldWidth;\n }\n }\n return coordinate;\n}\n/**\n * @param {Coordinate} coordinate Coordinate.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @param {number} [sourceExtentWidth] Width of the source extent.\n * @return {number} Offset in world widths.\n */\nexport function getWorldsAway(coordinate, projection, sourceExtentWidth) {\n const projectionExtent = projection.getExtent();\n let worldsAway = 0;\n if (\n projection.canWrapX() &&\n (coordinate[0] < projectionExtent[0] || coordinate[0] > projectionExtent[2])\n ) {\n sourceExtentWidth = sourceExtentWidth || getWidth(projectionExtent);\n worldsAway = Math.floor(\n (coordinate[0] - projectionExtent[0]) / sourceExtentWidth,\n );\n }\n return worldsAway;\n}\n","/**\n * @module ol/css\n */\n\n/**\n * @typedef {Object} FontParameters\n * @property {string} style Style.\n * @property {string} variant Variant.\n * @property {string} weight Weight.\n * @property {string} size Size.\n * @property {string} lineHeight LineHeight.\n * @property {string} family Family.\n * @property {Array} families Families.\n */\n\n/**\n * The CSS class for hidden feature.\n *\n * @const\n * @type {string}\n */\nexport const CLASS_HIDDEN = 'ol-hidden';\n\n/**\n * The CSS class that we'll give the DOM elements to have them selectable.\n *\n * @const\n * @type {string}\n */\nexport const CLASS_SELECTABLE = 'ol-selectable';\n\n/**\n * The CSS class that we'll give the DOM elements to have them unselectable.\n *\n * @const\n * @type {string}\n */\nexport const CLASS_UNSELECTABLE = 'ol-unselectable';\n\n/**\n * The CSS class for unsupported feature.\n *\n * @const\n * @type {string}\n */\nexport const CLASS_UNSUPPORTED = 'ol-unsupported';\n\n/**\n * The CSS class for controls.\n *\n * @const\n * @type {string}\n */\nexport const CLASS_CONTROL = 'ol-control';\n\n/**\n * The CSS class that we'll give the DOM elements that are collapsed, i.e.\n * to those elements which usually can be expanded.\n *\n * @const\n * @type {string}\n */\nexport const CLASS_COLLAPSED = 'ol-collapsed';\n\n/**\n * From https://stackoverflow.com/questions/10135697/regex-to-parse-any-css-font\n * @type {RegExp}\n */\nconst fontRegEx = new RegExp(\n [\n '^\\\\s*(?=(?:(?:[-a-z]+\\\\s*){0,2}(italic|oblique))?)',\n '(?=(?:(?:[-a-z]+\\\\s*){0,2}(small-caps))?)',\n '(?=(?:(?:[-a-z]+\\\\s*){0,2}(bold(?:er)?|lighter|[1-9]00 ))?)',\n '(?:(?:normal|\\\\1|\\\\2|\\\\3)\\\\s*){0,3}((?:xx?-)?',\n '(?:small|large)|medium|smaller|larger|[\\\\.\\\\d]+(?:\\\\%|in|[cem]m|ex|p[ctx]))',\n '(?:\\\\s*\\\\/\\\\s*(normal|[\\\\.\\\\d]+(?:\\\\%|in|[cem]m|ex|p[ctx])?))',\n '?\\\\s*([-,\\\\\"\\\\\\'\\\\sa-z]+?)\\\\s*$',\n ].join(''),\n 'i',\n);\n/** @type {Array<'style'|'variant'|'weight'|'size'|'lineHeight'|'family'>} */\nconst fontRegExMatchIndex = [\n 'style',\n 'variant',\n 'weight',\n 'size',\n 'lineHeight',\n 'family',\n];\n\n/**\n * Get the list of font families from a font spec. Note that this doesn't work\n * for font families that have commas in them.\n * @param {string} fontSpec The CSS font property.\n * @return {FontParameters|null} The font parameters (or null if the input spec is invalid).\n */\nexport const getFontParameters = function (fontSpec) {\n const match = fontSpec.match(fontRegEx);\n if (!match) {\n return null;\n }\n const style = /** @type {FontParameters} */ ({\n lineHeight: 'normal',\n size: '1.2em',\n style: 'normal',\n weight: 'normal',\n variant: 'normal',\n });\n for (let i = 0, ii = fontRegExMatchIndex.length; i < ii; ++i) {\n const value = match[i + 1];\n if (value !== undefined) {\n style[fontRegExMatchIndex[i]] = value;\n }\n }\n style.families = style.family.split(/,\\s?/);\n return style;\n};\n","import {WORKER_OFFSCREEN_CANVAS} from './has.js';\n\n/**\n * @module ol/dom\n */\n\n//FIXME Move this function to the canvas module\n/**\n * Create an html canvas element and returns its 2d context.\n * @param {number} [width] Canvas width.\n * @param {number} [height] Canvas height.\n * @param {Array} [canvasPool] Canvas pool to take existing canvas from.\n * @param {CanvasRenderingContext2DSettings} [settings] CanvasRenderingContext2DSettings\n * @return {CanvasRenderingContext2D} The context.\n */\nexport function createCanvasContext2D(width, height, canvasPool, settings) {\n /** @type {HTMLCanvasElement|OffscreenCanvas} */\n let canvas;\n if (canvasPool && canvasPool.length) {\n canvas = /** @type {HTMLCanvasElement} */ (canvasPool.shift());\n } else if (WORKER_OFFSCREEN_CANVAS) {\n canvas = new OffscreenCanvas(width || 300, height || 300);\n } else {\n canvas = document.createElement('canvas');\n }\n if (width) {\n canvas.width = width;\n }\n if (height) {\n canvas.height = height;\n }\n //FIXME Allow OffscreenCanvasRenderingContext2D as return type\n return /** @type {CanvasRenderingContext2D} */ (\n canvas.getContext('2d', settings)\n );\n}\n\n/** @type {CanvasRenderingContext2D} */\nlet sharedCanvasContext;\n\n/**\n * @return {CanvasRenderingContext2D} Shared canvas context.\n */\nexport function getSharedCanvasContext2D() {\n if (!sharedCanvasContext) {\n sharedCanvasContext = createCanvasContext2D(1, 1);\n }\n return sharedCanvasContext;\n}\n\n/**\n * Releases canvas memory to avoid exceeding memory limits in Safari.\n * See https://pqina.nl/blog/total-canvas-memory-use-exceeds-the-maximum-limit/\n * @param {CanvasRenderingContext2D} context Context.\n */\nexport function releaseCanvas(context) {\n const canvas = context.canvas;\n canvas.width = 1;\n canvas.height = 1;\n context.clearRect(0, 0, 1, 1);\n}\n\n/**\n * Get the current computed width for the given element including margin,\n * padding and border.\n * Equivalent to jQuery's `$(el).outerWidth(true)`.\n * @param {!HTMLElement} element Element.\n * @return {number} The width.\n */\nexport function outerWidth(element) {\n let width = element.offsetWidth;\n const style = getComputedStyle(element);\n width += parseInt(style.marginLeft, 10) + parseInt(style.marginRight, 10);\n\n return width;\n}\n\n/**\n * Get the current computed height for the given element including margin,\n * padding and border.\n * Equivalent to jQuery's `$(el).outerHeight(true)`.\n * @param {!HTMLElement} element Element.\n * @return {number} The height.\n */\nexport function outerHeight(element) {\n let height = element.offsetHeight;\n const style = getComputedStyle(element);\n height += parseInt(style.marginTop, 10) + parseInt(style.marginBottom, 10);\n\n return height;\n}\n\n/**\n * @param {Node} newNode Node to replace old node\n * @param {Node} oldNode The node to be replaced\n */\nexport function replaceNode(newNode, oldNode) {\n const parent = oldNode.parentNode;\n if (parent) {\n parent.replaceChild(newNode, oldNode);\n }\n}\n\n/**\n * @param {Node} node The node to remove the children from.\n */\nexport function removeChildren(node) {\n while (node.lastChild) {\n node.lastChild.remove();\n }\n}\n\n/**\n * Transform the children of a parent node so they match the\n * provided list of children. This function aims to efficiently\n * remove, add, and reorder child nodes while maintaining a simple\n * implementation (it is not guaranteed to minimize DOM operations).\n * @param {Node} node The parent node whose children need reworking.\n * @param {Array} children The desired children.\n */\nexport function replaceChildren(node, children) {\n const oldChildren = node.childNodes;\n\n for (let i = 0; true; ++i) {\n const oldChild = oldChildren[i];\n const newChild = children[i];\n\n // check if our work is done\n if (!oldChild && !newChild) {\n break;\n }\n\n // check if children match\n if (oldChild === newChild) {\n continue;\n }\n\n // check if a new child needs to be added\n if (!oldChild) {\n node.appendChild(newChild);\n continue;\n }\n\n // check if an old child needs to be removed\n if (!newChild) {\n node.removeChild(oldChild);\n --i;\n continue;\n }\n\n // reorder\n node.insertBefore(newChild, oldChild);\n }\n}\n","/**\n * @module ol/easing\n */\n\n/**\n * Start slow and speed up.\n * @param {number} t Input between 0 and 1.\n * @return {number} Output between 0 and 1.\n * @api\n */\nexport function easeIn(t) {\n return Math.pow(t, 3);\n}\n\n/**\n * Start fast and slow down.\n * @param {number} t Input between 0 and 1.\n * @return {number} Output between 0 and 1.\n * @api\n */\nexport function easeOut(t) {\n return 1 - easeIn(1 - t);\n}\n\n/**\n * Start slow, speed up, and then slow down again.\n * @param {number} t Input between 0 and 1.\n * @return {number} Output between 0 and 1.\n * @api\n */\nexport function inAndOut(t) {\n return 3 * t * t - 2 * t * t * t;\n}\n\n/**\n * Maintain a constant speed over time.\n * @param {number} t Input between 0 and 1.\n * @return {number} Output between 0 and 1.\n * @api\n */\nexport function linear(t) {\n return t;\n}\n\n/**\n * Start slow, speed up, and at the very end slow down again. This has the\n * same general behavior as {@link module:ol/easing.inAndOut}, but the final\n * slowdown is delayed.\n * @param {number} t Input between 0 and 1.\n * @return {number} Output between 0 and 1.\n * @api\n */\nexport function upAndDown(t) {\n if (t < 0.5) {\n return inAndOut(2 * t);\n }\n return 1 - inAndOut(2 * (t - 0.5));\n}\n","/**\n * @module ol/events\n */\nimport {clear} from './obj.js';\n\n/**\n * Key to use with {@link module:ol/Observable.unByKey}.\n * @typedef {Object} EventsKey\n * @property {ListenerFunction} listener Listener.\n * @property {import(\"./events/Target.js\").EventTargetLike} target Target.\n * @property {string} type Type.\n * @api\n */\n\n/**\n * Listener function. This function is called with an event object as argument.\n * When the function returns `false`, event propagation will stop.\n *\n * @typedef {function((Event|import(\"./events/Event.js\").default)): (void|boolean)} ListenerFunction\n * @api\n */\n\n/**\n * @typedef {Object} ListenerObject\n * @property {ListenerFunction} handleEvent HandleEvent listener function.\n */\n\n/**\n * @typedef {ListenerFunction|ListenerObject} Listener\n */\n\n/**\n * Registers an event listener on an event target. Inspired by\n * https://google.github.io/closure-library/api/source/closure/goog/events/events.js.src.html\n *\n * This function efficiently binds a `listener` to a `this` object, and returns\n * a key for use with {@link module:ol/events.unlistenByKey}.\n *\n * @param {import(\"./events/Target.js\").EventTargetLike} target Event target.\n * @param {string} type Event type.\n * @param {ListenerFunction} listener Listener.\n * @param {Object} [thisArg] Object referenced by the `this` keyword in the\n * listener. Default is the `target`.\n * @param {boolean} [once] If true, add the listener as one-off listener.\n * @return {EventsKey} Unique key for the listener.\n */\nexport function listen(target, type, listener, thisArg, once) {\n if (once) {\n const originalListener = listener;\n /**\n * @this {typeof target}\n */\n listener = function () {\n target.removeEventListener(type, listener);\n originalListener.apply(thisArg ?? this, arguments);\n };\n } else if (thisArg && thisArg !== target) {\n listener = listener.bind(thisArg);\n }\n const eventsKey = {\n target: target,\n type: type,\n listener: listener,\n };\n target.addEventListener(type, listener);\n return eventsKey;\n}\n\n/**\n * Registers a one-off event listener on an event target. Inspired by\n * https://google.github.io/closure-library/api/source/closure/goog/events/events.js.src.html\n *\n * This function efficiently binds a `listener` as self-unregistering listener\n * to a `this` object, and returns a key for use with\n * {@link module:ol/events.unlistenByKey} in case the listener needs to be\n * unregistered before it is called.\n *\n * When {@link module:ol/events.listen} is called with the same arguments after this\n * function, the self-unregistering listener will be turned into a permanent\n * listener.\n *\n * @param {import(\"./events/Target.js\").EventTargetLike} target Event target.\n * @param {string} type Event type.\n * @param {ListenerFunction} listener Listener.\n * @param {Object} [thisArg] Object referenced by the `this` keyword in the\n * listener. Default is the `target`.\n * @return {EventsKey} Key for unlistenByKey.\n */\nexport function listenOnce(target, type, listener, thisArg) {\n return listen(target, type, listener, thisArg, true);\n}\n\n/**\n * Unregisters event listeners on an event target. Inspired by\n * https://google.github.io/closure-library/api/source/closure/goog/events/events.js.src.html\n *\n * The argument passed to this function is the key returned from\n * {@link module:ol/events.listen} or {@link module:ol/events.listenOnce}.\n *\n * @param {EventsKey} key The key.\n */\nexport function unlistenByKey(key) {\n if (key && key.target) {\n key.target.removeEventListener(key.type, key.listener);\n clear(key);\n }\n}\n","/**\n * @module ol/events/Event\n */\n\n/**\n * @classdesc\n * Stripped down implementation of the W3C DOM Level 2 Event interface.\n * See https://www.w3.org/TR/DOM-Level-2-Events/events.html#Events-interface.\n *\n * This implementation only provides `type` and `target` properties, and\n * `stopPropagation` and `preventDefault` methods. It is meant as base class\n * for higher level events defined in the library, and works with\n * {@link module:ol/events/Target~Target}.\n */\nclass BaseEvent {\n /**\n * @param {string} type Type.\n */\n constructor(type) {\n /**\n * @type {boolean}\n */\n this.propagationStopped;\n\n /**\n * @type {boolean}\n */\n this.defaultPrevented;\n\n /**\n * The event type.\n * @type {string}\n * @api\n */\n this.type = type;\n\n /**\n * The event target.\n * @type {Object}\n * @api\n */\n this.target = null;\n }\n\n /**\n * Prevent default. This means that no emulated `click`, `singleclick` or `doubleclick` events\n * will be fired.\n * @api\n */\n preventDefault() {\n this.defaultPrevented = true;\n }\n\n /**\n * Stop event propagation.\n * @api\n */\n stopPropagation() {\n this.propagationStopped = true;\n }\n}\n\n/**\n * @param {Event|import(\"./Event.js\").default} evt Event\n */\nexport function stopPropagation(evt) {\n evt.stopPropagation();\n}\n\n/**\n * @param {Event|import(\"./Event.js\").default} evt Event\n */\nexport function preventDefault(evt) {\n evt.preventDefault();\n}\n\nexport default BaseEvent;\n","/**\n * @module ol/events/EventType\n */\n\n/**\n * @enum {string}\n * @const\n */\nexport default {\n /**\n * Generic change event. Triggered when the revision counter is increased.\n * @event module:ol/events/Event~BaseEvent#change\n * @api\n */\n CHANGE: 'change',\n\n /**\n * Generic error event. Triggered when an error occurs.\n * @event module:ol/events/Event~BaseEvent#error\n * @api\n */\n ERROR: 'error',\n\n BLUR: 'blur',\n CLEAR: 'clear',\n CONTEXTMENU: 'contextmenu',\n CLICK: 'click',\n DBLCLICK: 'dblclick',\n DRAGENTER: 'dragenter',\n DRAGOVER: 'dragover',\n DROP: 'drop',\n FOCUS: 'focus',\n KEYDOWN: 'keydown',\n KEYPRESS: 'keypress',\n LOAD: 'load',\n RESIZE: 'resize',\n TOUCHMOVE: 'touchmove',\n WHEEL: 'wheel',\n};\n","/**\n * @module ol/events/Target\n */\nimport Disposable from '../Disposable.js';\nimport Event from './Event.js';\nimport {VOID} from '../functions.js';\nimport {clear} from '../obj.js';\n\n/**\n * @typedef {EventTarget|Target} EventTargetLike\n */\n\n/**\n * @classdesc\n * A simplified implementation of the W3C DOM Level 2 EventTarget interface.\n * See https://www.w3.org/TR/2000/REC-DOM-Level-2-Events-20001113/events.html#Events-EventTarget.\n *\n * There are two important simplifications compared to the specification:\n *\n * 1. The handling of `useCapture` in `addEventListener` and\n * `removeEventListener`. There is no real capture model.\n * 2. The handling of `stopPropagation` and `preventDefault` on `dispatchEvent`.\n * There is no event target hierarchy. When a listener calls\n * `stopPropagation` or `preventDefault` on an event object, it means that no\n * more listeners after this one will be called. Same as when the listener\n * returns false.\n */\nclass Target extends Disposable {\n /**\n * @param {*} [target] Default event target for dispatched events.\n */\n constructor(target) {\n super();\n\n /**\n * @private\n * @type {*}\n */\n this.eventTarget_ = target;\n\n /**\n * @private\n * @type {Object|null}\n */\n this.pendingRemovals_ = null;\n\n /**\n * @private\n * @type {Object|null}\n */\n this.dispatching_ = null;\n\n /**\n * @private\n * @type {Object>|null}\n */\n this.listeners_ = null;\n }\n\n /**\n * @param {string} type Type.\n * @param {import(\"../events.js\").Listener} listener Listener.\n */\n addEventListener(type, listener) {\n if (!type || !listener) {\n return;\n }\n const listeners = this.listeners_ || (this.listeners_ = {});\n const listenersForType = listeners[type] || (listeners[type] = []);\n if (!listenersForType.includes(listener)) {\n listenersForType.push(listener);\n }\n }\n\n /**\n * Dispatches an event and calls all listeners listening for events\n * of this type. The event parameter can either be a string or an\n * Object with a `type` property.\n *\n * @param {import(\"./Event.js\").default|string} event Event object.\n * @return {boolean|undefined} `false` if anyone called preventDefault on the\n * event object or if any of the listeners returned false.\n * @api\n */\n dispatchEvent(event) {\n const isString = typeof event === 'string';\n const type = isString ? event : event.type;\n const listeners = this.listeners_ && this.listeners_[type];\n if (!listeners) {\n return;\n }\n\n const evt = isString ? new Event(event) : /** @type {Event} */ (event);\n if (!evt.target) {\n evt.target = this.eventTarget_ || this;\n }\n const dispatching = this.dispatching_ || (this.dispatching_ = {});\n const pendingRemovals =\n this.pendingRemovals_ || (this.pendingRemovals_ = {});\n if (!(type in dispatching)) {\n dispatching[type] = 0;\n pendingRemovals[type] = 0;\n }\n ++dispatching[type];\n let propagate;\n for (let i = 0, ii = listeners.length; i < ii; ++i) {\n if ('handleEvent' in listeners[i]) {\n propagate = /** @type {import(\"../events.js\").ListenerObject} */ (\n listeners[i]\n ).handleEvent(evt);\n } else {\n propagate = /** @type {import(\"../events.js\").ListenerFunction} */ (\n listeners[i]\n ).call(this, evt);\n }\n if (propagate === false || evt.propagationStopped) {\n propagate = false;\n break;\n }\n }\n if (--dispatching[type] === 0) {\n let pr = pendingRemovals[type];\n delete pendingRemovals[type];\n while (pr--) {\n this.removeEventListener(type, VOID);\n }\n delete dispatching[type];\n }\n return propagate;\n }\n\n /**\n * Clean up.\n * @override\n */\n disposeInternal() {\n this.listeners_ && clear(this.listeners_);\n }\n\n /**\n * Get the listeners for a specified event type. Listeners are returned in the\n * order that they will be called in.\n *\n * @param {string} type Type.\n * @return {Array|undefined} Listeners.\n */\n getListeners(type) {\n return (this.listeners_ && this.listeners_[type]) || undefined;\n }\n\n /**\n * @param {string} [type] Type. If not provided,\n * `true` will be returned if this event target has any listeners.\n * @return {boolean} Has listeners.\n */\n hasListener(type) {\n if (!this.listeners_) {\n return false;\n }\n return type\n ? type in this.listeners_\n : Object.keys(this.listeners_).length > 0;\n }\n\n /**\n * @param {string} type Type.\n * @param {import(\"../events.js\").Listener} listener Listener.\n */\n removeEventListener(type, listener) {\n if (!this.listeners_) {\n return;\n }\n const listeners = this.listeners_[type];\n if (!listeners) {\n return;\n }\n const index = listeners.indexOf(listener);\n if (index !== -1) {\n if (this.pendingRemovals_ && type in this.pendingRemovals_) {\n // make listener a no-op, and remove later in #dispatchEvent()\n listeners[index] = VOID;\n ++this.pendingRemovals_[type];\n } else {\n listeners.splice(index, 1);\n if (listeners.length === 0) {\n delete this.listeners_[type];\n }\n }\n }\n }\n}\n\nexport default Target;\n","/**\n * @module ol/extent\n */\nimport Relationship from './extent/Relationship.js';\n\n/**\n * An array of numbers representing an extent: `[minx, miny, maxx, maxy]`.\n * @typedef {Array} Extent\n * @api\n */\n\n/**\n * Extent corner.\n * @typedef {'bottom-left' | 'bottom-right' | 'top-left' | 'top-right'} Corner\n */\n\n/**\n * Build an extent that includes all given coordinates.\n *\n * @param {Array} coordinates Coordinates.\n * @return {Extent} Bounding extent.\n * @api\n */\nexport function boundingExtent(coordinates) {\n const extent = createEmpty();\n for (let i = 0, ii = coordinates.length; i < ii; ++i) {\n extendCoordinate(extent, coordinates[i]);\n }\n return extent;\n}\n\n/**\n * @param {Array} xs Xs.\n * @param {Array} ys Ys.\n * @param {Extent} [dest] Destination extent.\n * @private\n * @return {Extent} Extent.\n */\nfunction _boundingExtentXYs(xs, ys, dest) {\n const minX = Math.min.apply(null, xs);\n const minY = Math.min.apply(null, ys);\n const maxX = Math.max.apply(null, xs);\n const maxY = Math.max.apply(null, ys);\n return createOrUpdate(minX, minY, maxX, maxY, dest);\n}\n\n/**\n * Return extent increased by the provided value.\n * @param {Extent} extent Extent.\n * @param {number} value The amount by which the extent should be buffered.\n * @param {Extent} [dest] Extent.\n * @return {Extent} Extent.\n * @api\n */\nexport function buffer(extent, value, dest) {\n if (dest) {\n dest[0] = extent[0] - value;\n dest[1] = extent[1] - value;\n dest[2] = extent[2] + value;\n dest[3] = extent[3] + value;\n return dest;\n }\n return [\n extent[0] - value,\n extent[1] - value,\n extent[2] + value,\n extent[3] + value,\n ];\n}\n\n/**\n * Creates a clone of an extent.\n *\n * @param {Extent} extent Extent to clone.\n * @param {Extent} [dest] Extent.\n * @return {Extent} The clone.\n */\nexport function clone(extent, dest) {\n if (dest) {\n dest[0] = extent[0];\n dest[1] = extent[1];\n dest[2] = extent[2];\n dest[3] = extent[3];\n return dest;\n }\n return extent.slice();\n}\n\n/**\n * @param {Extent} extent Extent.\n * @param {number} x X.\n * @param {number} y Y.\n * @return {number} Closest squared distance.\n */\nexport function closestSquaredDistanceXY(extent, x, y) {\n let dx, dy;\n if (x < extent[0]) {\n dx = extent[0] - x;\n } else if (extent[2] < x) {\n dx = x - extent[2];\n } else {\n dx = 0;\n }\n if (y < extent[1]) {\n dy = extent[1] - y;\n } else if (extent[3] < y) {\n dy = y - extent[3];\n } else {\n dy = 0;\n }\n return dx * dx + dy * dy;\n}\n\n/**\n * Check if the passed coordinate is contained or on the edge of the extent.\n *\n * @param {Extent} extent Extent.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n * @return {boolean} The coordinate is contained in the extent.\n * @api\n */\nexport function containsCoordinate(extent, coordinate) {\n return containsXY(extent, coordinate[0], coordinate[1]);\n}\n\n/**\n * Check if one extent contains another.\n *\n * An extent is deemed contained if it lies completely within the other extent,\n * including if they share one or more edges.\n *\n * @param {Extent} extent1 Extent 1.\n * @param {Extent} extent2 Extent 2.\n * @return {boolean} The second extent is contained by or on the edge of the\n * first.\n * @api\n */\nexport function containsExtent(extent1, extent2) {\n return (\n extent1[0] <= extent2[0] &&\n extent2[2] <= extent1[2] &&\n extent1[1] <= extent2[1] &&\n extent2[3] <= extent1[3]\n );\n}\n\n/**\n * Check if the passed coordinate is contained or on the edge of the extent.\n *\n * @param {Extent} extent Extent.\n * @param {number} x X coordinate.\n * @param {number} y Y coordinate.\n * @return {boolean} The x, y values are contained in the extent.\n * @api\n */\nexport function containsXY(extent, x, y) {\n return extent[0] <= x && x <= extent[2] && extent[1] <= y && y <= extent[3];\n}\n\n/**\n * Get the relationship between a coordinate and extent.\n * @param {Extent} extent The extent.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate The coordinate.\n * @return {import(\"./extent/Relationship.js\").default} The relationship (bitwise compare with\n * import(\"./extent/Relationship.js\").Relationship).\n */\nexport function coordinateRelationship(extent, coordinate) {\n const minX = extent[0];\n const minY = extent[1];\n const maxX = extent[2];\n const maxY = extent[3];\n const x = coordinate[0];\n const y = coordinate[1];\n let relationship = Relationship.UNKNOWN;\n if (x < minX) {\n relationship = relationship | Relationship.LEFT;\n } else if (x > maxX) {\n relationship = relationship | Relationship.RIGHT;\n }\n if (y < minY) {\n relationship = relationship | Relationship.BELOW;\n } else if (y > maxY) {\n relationship = relationship | Relationship.ABOVE;\n }\n if (relationship === Relationship.UNKNOWN) {\n relationship = Relationship.INTERSECTING;\n }\n return relationship;\n}\n\n/**\n * Create an empty extent.\n * @return {Extent} Empty extent.\n * @api\n */\nexport function createEmpty() {\n return [Infinity, Infinity, -Infinity, -Infinity];\n}\n\n/**\n * Create a new extent or update the provided extent.\n * @param {number} minX Minimum X.\n * @param {number} minY Minimum Y.\n * @param {number} maxX Maximum X.\n * @param {number} maxY Maximum Y.\n * @param {Extent} [dest] Destination extent.\n * @return {Extent} Extent.\n */\nexport function createOrUpdate(minX, minY, maxX, maxY, dest) {\n if (dest) {\n dest[0] = minX;\n dest[1] = minY;\n dest[2] = maxX;\n dest[3] = maxY;\n return dest;\n }\n return [minX, minY, maxX, maxY];\n}\n\n/**\n * Create a new empty extent or make the provided one empty.\n * @param {Extent} [dest] Extent.\n * @return {Extent} Extent.\n */\nexport function createOrUpdateEmpty(dest) {\n return createOrUpdate(Infinity, Infinity, -Infinity, -Infinity, dest);\n}\n\n/**\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {Extent} [dest] Extent.\n * @return {Extent} Extent.\n */\nexport function createOrUpdateFromCoordinate(coordinate, dest) {\n const x = coordinate[0];\n const y = coordinate[1];\n return createOrUpdate(x, y, x, y, dest);\n}\n\n/**\n * @param {Array} coordinates Coordinates.\n * @param {Extent} [dest] Extent.\n * @return {Extent} Extent.\n */\nexport function createOrUpdateFromCoordinates(coordinates, dest) {\n const extent = createOrUpdateEmpty(dest);\n return extendCoordinates(extent, coordinates);\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {Extent} [dest] Extent.\n * @return {Extent} Extent.\n */\nexport function createOrUpdateFromFlatCoordinates(\n flatCoordinates,\n offset,\n end,\n stride,\n dest,\n) {\n const extent = createOrUpdateEmpty(dest);\n return extendFlatCoordinates(extent, flatCoordinates, offset, end, stride);\n}\n\n/**\n * @param {Array>} rings Rings.\n * @param {Extent} [dest] Extent.\n * @return {Extent} Extent.\n */\nexport function createOrUpdateFromRings(rings, dest) {\n const extent = createOrUpdateEmpty(dest);\n return extendRings(extent, rings);\n}\n\n/**\n * Determine if two extents are equivalent.\n * @param {Extent} extent1 Extent 1.\n * @param {Extent} extent2 Extent 2.\n * @return {boolean} The two extents are equivalent.\n * @api\n */\nexport function equals(extent1, extent2) {\n return (\n extent1[0] == extent2[0] &&\n extent1[2] == extent2[2] &&\n extent1[1] == extent2[1] &&\n extent1[3] == extent2[3]\n );\n}\n\n/**\n * Determine if two extents are approximately equivalent.\n * @param {Extent} extent1 Extent 1.\n * @param {Extent} extent2 Extent 2.\n * @param {number} tolerance Tolerance in extent coordinate units.\n * @return {boolean} The two extents differ by less than the tolerance.\n */\nexport function approximatelyEquals(extent1, extent2, tolerance) {\n return (\n Math.abs(extent1[0] - extent2[0]) < tolerance &&\n Math.abs(extent1[2] - extent2[2]) < tolerance &&\n Math.abs(extent1[1] - extent2[1]) < tolerance &&\n Math.abs(extent1[3] - extent2[3]) < tolerance\n );\n}\n\n/**\n * Modify an extent to include another extent.\n * @param {Extent} extent1 The extent to be modified.\n * @param {Extent} extent2 The extent that will be included in the first.\n * @return {Extent} A reference to the first (extended) extent.\n * @api\n */\nexport function extend(extent1, extent2) {\n if (extent2[0] < extent1[0]) {\n extent1[0] = extent2[0];\n }\n if (extent2[2] > extent1[2]) {\n extent1[2] = extent2[2];\n }\n if (extent2[1] < extent1[1]) {\n extent1[1] = extent2[1];\n }\n if (extent2[3] > extent1[3]) {\n extent1[3] = extent2[3];\n }\n return extent1;\n}\n\n/**\n * @param {Extent} extent Extent.\n * @param {import(\"./coordinate.js\").Coordinate} coordinate Coordinate.\n */\nexport function extendCoordinate(extent, coordinate) {\n if (coordinate[0] < extent[0]) {\n extent[0] = coordinate[0];\n }\n if (coordinate[0] > extent[2]) {\n extent[2] = coordinate[0];\n }\n if (coordinate[1] < extent[1]) {\n extent[1] = coordinate[1];\n }\n if (coordinate[1] > extent[3]) {\n extent[3] = coordinate[1];\n }\n}\n\n/**\n * @param {Extent} extent Extent.\n * @param {Array} coordinates Coordinates.\n * @return {Extent} Extent.\n */\nexport function extendCoordinates(extent, coordinates) {\n for (let i = 0, ii = coordinates.length; i < ii; ++i) {\n extendCoordinate(extent, coordinates[i]);\n }\n return extent;\n}\n\n/**\n * @param {Extent} extent Extent.\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @return {Extent} Extent.\n */\nexport function extendFlatCoordinates(\n extent,\n flatCoordinates,\n offset,\n end,\n stride,\n) {\n for (; offset < end; offset += stride) {\n extendXY(extent, flatCoordinates[offset], flatCoordinates[offset + 1]);\n }\n return extent;\n}\n\n/**\n * @param {Extent} extent Extent.\n * @param {Array>} rings Rings.\n * @return {Extent} Extent.\n */\nexport function extendRings(extent, rings) {\n for (let i = 0, ii = rings.length; i < ii; ++i) {\n extendCoordinates(extent, rings[i]);\n }\n return extent;\n}\n\n/**\n * @param {Extent} extent Extent.\n * @param {number} x X.\n * @param {number} y Y.\n */\nexport function extendXY(extent, x, y) {\n extent[0] = Math.min(extent[0], x);\n extent[1] = Math.min(extent[1], y);\n extent[2] = Math.max(extent[2], x);\n extent[3] = Math.max(extent[3], y);\n}\n\n/**\n * This function calls `callback` for each corner of the extent. If the\n * callback returns a truthy value the function returns that value\n * immediately. Otherwise the function returns `false`.\n * @param {Extent} extent Extent.\n * @param {function(import(\"./coordinate.js\").Coordinate): S} callback Callback.\n * @return {S|boolean} Value.\n * @template S\n */\nexport function forEachCorner(extent, callback) {\n let val;\n val = callback(getBottomLeft(extent));\n if (val) {\n return val;\n }\n val = callback(getBottomRight(extent));\n if (val) {\n return val;\n }\n val = callback(getTopRight(extent));\n if (val) {\n return val;\n }\n val = callback(getTopLeft(extent));\n if (val) {\n return val;\n }\n return false;\n}\n\n/**\n * Get the size of an extent.\n * @param {Extent} extent Extent.\n * @return {number} Area.\n * @api\n */\nexport function getArea(extent) {\n let area = 0;\n if (!isEmpty(extent)) {\n area = getWidth(extent) * getHeight(extent);\n }\n return area;\n}\n\n/**\n * Get the bottom left coordinate of an extent.\n * @param {Extent} extent Extent.\n * @return {import(\"./coordinate.js\").Coordinate} Bottom left coordinate.\n * @api\n */\nexport function getBottomLeft(extent) {\n return [extent[0], extent[1]];\n}\n\n/**\n * Get the bottom right coordinate of an extent.\n * @param {Extent} extent Extent.\n * @return {import(\"./coordinate.js\").Coordinate} Bottom right coordinate.\n * @api\n */\nexport function getBottomRight(extent) {\n return [extent[2], extent[1]];\n}\n\n/**\n * Get the center coordinate of an extent.\n * @param {Extent} extent Extent.\n * @return {import(\"./coordinate.js\").Coordinate} Center.\n * @api\n */\nexport function getCenter(extent) {\n return [(extent[0] + extent[2]) / 2, (extent[1] + extent[3]) / 2];\n}\n\n/**\n * Get a corner coordinate of an extent.\n * @param {Extent} extent Extent.\n * @param {Corner} corner Corner.\n * @return {import(\"./coordinate.js\").Coordinate} Corner coordinate.\n */\nexport function getCorner(extent, corner) {\n let coordinate;\n if (corner === 'bottom-left') {\n coordinate = getBottomLeft(extent);\n } else if (corner === 'bottom-right') {\n coordinate = getBottomRight(extent);\n } else if (corner === 'top-left') {\n coordinate = getTopLeft(extent);\n } else if (corner === 'top-right') {\n coordinate = getTopRight(extent);\n } else {\n throw new Error('Invalid corner');\n }\n return coordinate;\n}\n\n/**\n * @param {Extent} extent1 Extent 1.\n * @param {Extent} extent2 Extent 2.\n * @return {number} Enlarged area.\n */\nexport function getEnlargedArea(extent1, extent2) {\n const minX = Math.min(extent1[0], extent2[0]);\n const minY = Math.min(extent1[1], extent2[1]);\n const maxX = Math.max(extent1[2], extent2[2]);\n const maxY = Math.max(extent1[3], extent2[3]);\n return (maxX - minX) * (maxY - minY);\n}\n\n/**\n * @param {import(\"./coordinate.js\").Coordinate} center Center.\n * @param {number} resolution Resolution.\n * @param {number} rotation Rotation.\n * @param {import(\"./size.js\").Size} size Size.\n * @param {Extent} [dest] Destination extent.\n * @return {Extent} Extent.\n */\nexport function getForViewAndSize(center, resolution, rotation, size, dest) {\n const [x0, y0, x1, y1, x2, y2, x3, y3] = getRotatedViewport(\n center,\n resolution,\n rotation,\n size,\n );\n return createOrUpdate(\n Math.min(x0, x1, x2, x3),\n Math.min(y0, y1, y2, y3),\n Math.max(x0, x1, x2, x3),\n Math.max(y0, y1, y2, y3),\n dest,\n );\n}\n\n/**\n * @param {import(\"./coordinate.js\").Coordinate} center Center.\n * @param {number} resolution Resolution.\n * @param {number} rotation Rotation.\n * @param {import(\"./size.js\").Size} size Size.\n * @return {Array} Linear ring representing the viewport.\n */\nexport function getRotatedViewport(center, resolution, rotation, size) {\n const dx = (resolution * size[0]) / 2;\n const dy = (resolution * size[1]) / 2;\n const cosRotation = Math.cos(rotation);\n const sinRotation = Math.sin(rotation);\n const xCos = dx * cosRotation;\n const xSin = dx * sinRotation;\n const yCos = dy * cosRotation;\n const ySin = dy * sinRotation;\n const x = center[0];\n const y = center[1];\n return [\n x - xCos + ySin,\n y - xSin - yCos,\n x - xCos - ySin,\n y - xSin + yCos,\n x + xCos - ySin,\n y + xSin + yCos,\n x + xCos + ySin,\n y + xSin - yCos,\n x - xCos + ySin,\n y - xSin - yCos,\n ];\n}\n\n/**\n * Get the height of an extent.\n * @param {Extent} extent Extent.\n * @return {number} Height.\n * @api\n */\nexport function getHeight(extent) {\n return extent[3] - extent[1];\n}\n\n/**\n * @param {Extent} extent1 Extent 1.\n * @param {Extent} extent2 Extent 2.\n * @return {number} Intersection area.\n */\nexport function getIntersectionArea(extent1, extent2) {\n const intersection = getIntersection(extent1, extent2);\n return getArea(intersection);\n}\n\n/**\n * Get the intersection of two extents.\n * @param {Extent} extent1 Extent 1.\n * @param {Extent} extent2 Extent 2.\n * @param {Extent} [dest] Optional extent to populate with intersection.\n * @return {Extent} Intersecting extent.\n * @api\n */\nexport function getIntersection(extent1, extent2, dest) {\n const intersection = dest ? dest : createEmpty();\n if (intersects(extent1, extent2)) {\n if (extent1[0] > extent2[0]) {\n intersection[0] = extent1[0];\n } else {\n intersection[0] = extent2[0];\n }\n if (extent1[1] > extent2[1]) {\n intersection[1] = extent1[1];\n } else {\n intersection[1] = extent2[1];\n }\n if (extent1[2] < extent2[2]) {\n intersection[2] = extent1[2];\n } else {\n intersection[2] = extent2[2];\n }\n if (extent1[3] < extent2[3]) {\n intersection[3] = extent1[3];\n } else {\n intersection[3] = extent2[3];\n }\n } else {\n createOrUpdateEmpty(intersection);\n }\n return intersection;\n}\n\n/**\n * @param {Extent} extent Extent.\n * @return {number} Margin.\n */\nexport function getMargin(extent) {\n return getWidth(extent) + getHeight(extent);\n}\n\n/**\n * Get the size (width, height) of an extent.\n * @param {Extent} extent The extent.\n * @return {import(\"./size.js\").Size} The extent size.\n * @api\n */\nexport function getSize(extent) {\n return [extent[2] - extent[0], extent[3] - extent[1]];\n}\n\n/**\n * Get the top left coordinate of an extent.\n * @param {Extent} extent Extent.\n * @return {import(\"./coordinate.js\").Coordinate} Top left coordinate.\n * @api\n */\nexport function getTopLeft(extent) {\n return [extent[0], extent[3]];\n}\n\n/**\n * Get the top right coordinate of an extent.\n * @param {Extent} extent Extent.\n * @return {import(\"./coordinate.js\").Coordinate} Top right coordinate.\n * @api\n */\nexport function getTopRight(extent) {\n return [extent[2], extent[3]];\n}\n\n/**\n * Get the width of an extent.\n * @param {Extent} extent Extent.\n * @return {number} Width.\n * @api\n */\nexport function getWidth(extent) {\n return extent[2] - extent[0];\n}\n\n/**\n * Determine if one extent intersects another.\n * @param {Extent} extent1 Extent 1.\n * @param {Extent} extent2 Extent.\n * @return {boolean} The two extents intersect.\n * @api\n */\nexport function intersects(extent1, extent2) {\n return (\n extent1[0] <= extent2[2] &&\n extent1[2] >= extent2[0] &&\n extent1[1] <= extent2[3] &&\n extent1[3] >= extent2[1]\n );\n}\n\n/**\n * Determine if an extent is empty.\n * @param {Extent} extent Extent.\n * @return {boolean} Is empty.\n * @api\n */\nexport function isEmpty(extent) {\n return extent[2] < extent[0] || extent[3] < extent[1];\n}\n\n/**\n * @param {Extent} extent Extent.\n * @param {Extent} [dest] Extent.\n * @return {Extent} Extent.\n */\nexport function returnOrUpdate(extent, dest) {\n if (dest) {\n dest[0] = extent[0];\n dest[1] = extent[1];\n dest[2] = extent[2];\n dest[3] = extent[3];\n return dest;\n }\n return extent;\n}\n\n/**\n * @param {Extent} extent Extent.\n * @param {number} value Value.\n */\nexport function scaleFromCenter(extent, value) {\n const deltaX = ((extent[2] - extent[0]) / 2) * (value - 1);\n const deltaY = ((extent[3] - extent[1]) / 2) * (value - 1);\n extent[0] -= deltaX;\n extent[2] += deltaX;\n extent[1] -= deltaY;\n extent[3] += deltaY;\n}\n\n/**\n * Determine if the segment between two coordinates intersects (crosses,\n * touches, or is contained by) the provided extent.\n * @param {Extent} extent The extent.\n * @param {import(\"./coordinate.js\").Coordinate} start Segment start coordinate.\n * @param {import(\"./coordinate.js\").Coordinate} end Segment end coordinate.\n * @return {boolean} The segment intersects the extent.\n */\nexport function intersectsSegment(extent, start, end) {\n let intersects = false;\n const startRel = coordinateRelationship(extent, start);\n const endRel = coordinateRelationship(extent, end);\n if (\n startRel === Relationship.INTERSECTING ||\n endRel === Relationship.INTERSECTING\n ) {\n intersects = true;\n } else {\n const minX = extent[0];\n const minY = extent[1];\n const maxX = extent[2];\n const maxY = extent[3];\n const startX = start[0];\n const startY = start[1];\n const endX = end[0];\n const endY = end[1];\n const slope = (endY - startY) / (endX - startX);\n let x, y;\n if (!!(endRel & Relationship.ABOVE) && !(startRel & Relationship.ABOVE)) {\n // potentially intersects top\n x = endX - (endY - maxY) / slope;\n intersects = x >= minX && x <= maxX;\n }\n if (\n !intersects &&\n !!(endRel & Relationship.RIGHT) &&\n !(startRel & Relationship.RIGHT)\n ) {\n // potentially intersects right\n y = endY - (endX - maxX) * slope;\n intersects = y >= minY && y <= maxY;\n }\n if (\n !intersects &&\n !!(endRel & Relationship.BELOW) &&\n !(startRel & Relationship.BELOW)\n ) {\n // potentially intersects bottom\n x = endX - (endY - minY) / slope;\n intersects = x >= minX && x <= maxX;\n }\n if (\n !intersects &&\n !!(endRel & Relationship.LEFT) &&\n !(startRel & Relationship.LEFT)\n ) {\n // potentially intersects left\n y = endY - (endX - minX) * slope;\n intersects = y >= minY && y <= maxY;\n }\n }\n return intersects;\n}\n\n/**\n * Apply a transform function to the extent.\n * @param {Extent} extent Extent.\n * @param {import(\"./proj.js\").TransformFunction} transformFn Transform function.\n * Called with `[minX, minY, maxX, maxY]` extent coordinates.\n * @param {Extent} [dest] Destination extent.\n * @param {number} [stops] Number of stops per side used for the transform.\n * By default only the corners are used.\n * @return {Extent} Extent.\n * @api\n */\nexport function applyTransform(extent, transformFn, dest, stops) {\n if (isEmpty(extent)) {\n return createOrUpdateEmpty(dest);\n }\n let coordinates = [];\n if (stops > 1) {\n const width = extent[2] - extent[0];\n const height = extent[3] - extent[1];\n for (let i = 0; i < stops; ++i) {\n coordinates.push(\n extent[0] + (width * i) / stops,\n extent[1],\n extent[2],\n extent[1] + (height * i) / stops,\n extent[2] - (width * i) / stops,\n extent[3],\n extent[0],\n extent[3] - (height * i) / stops,\n );\n }\n } else {\n coordinates = [\n extent[0],\n extent[1],\n extent[2],\n extent[1],\n extent[2],\n extent[3],\n extent[0],\n extent[3],\n ];\n }\n transformFn(coordinates, coordinates, 2);\n const xs = [];\n const ys = [];\n for (let i = 0, l = coordinates.length; i < l; i += 2) {\n xs.push(coordinates[i]);\n ys.push(coordinates[i + 1]);\n }\n return _boundingExtentXYs(xs, ys, dest);\n}\n\n/**\n * Modifies the provided extent in-place to be within the real world\n * extent.\n *\n * @param {Extent} extent Extent.\n * @param {import(\"./proj/Projection.js\").default} projection Projection\n * @return {Extent} The extent within the real world extent.\n */\nexport function wrapX(extent, projection) {\n const projectionExtent = projection.getExtent();\n const center = getCenter(extent);\n if (\n projection.canWrapX() &&\n (center[0] < projectionExtent[0] || center[0] >= projectionExtent[2])\n ) {\n const worldWidth = getWidth(projectionExtent);\n const worldsAway = Math.floor(\n (center[0] - projectionExtent[0]) / worldWidth,\n );\n const offset = worldsAway * worldWidth;\n extent[0] -= offset;\n extent[2] -= offset;\n }\n return extent;\n}\n\n/**\n * Fits the extent to the real world\n *\n * If the extent does not cross the anti meridian, this will return the extent in an array\n * If the extent crosses the anti meridian, the extent will be sliced, so each part fits within the\n * real world\n *\n *\n * @param {Extent} extent Extent.\n * @param {import(\"./proj/Projection.js\").default} projection Projection\n * @param {boolean} [multiWorld] Return all worlds\n * @return {Array} The extent within the real world extent.\n */\nexport function wrapAndSliceX(extent, projection, multiWorld) {\n if (projection.canWrapX()) {\n const projectionExtent = projection.getExtent();\n\n if (!isFinite(extent[0]) || !isFinite(extent[2])) {\n return [[projectionExtent[0], extent[1], projectionExtent[2], extent[3]]];\n }\n\n wrapX(extent, projection);\n const worldWidth = getWidth(projectionExtent);\n\n if (getWidth(extent) > worldWidth && !multiWorld) {\n // the extent wraps around on itself\n return [[projectionExtent[0], extent[1], projectionExtent[2], extent[3]]];\n }\n if (extent[0] < projectionExtent[0]) {\n // the extent crosses the anti meridian, so it needs to be sliced\n return [\n [extent[0] + worldWidth, extent[1], projectionExtent[2], extent[3]],\n [projectionExtent[0], extent[1], extent[2], extent[3]],\n ];\n }\n if (extent[2] > projectionExtent[2]) {\n // the extent crosses the anti meridian, so it needs to be sliced\n return [\n [extent[0], extent[1], projectionExtent[2], extent[3]],\n [projectionExtent[0], extent[1], extent[2] - worldWidth, extent[3]],\n ];\n }\n }\n\n return [extent];\n}\n","/**\n * @module ol/extent/Relationship\n */\n\n/**\n * Relationship to an extent.\n * @enum {number}\n */\nexport default {\n UNKNOWN: 0,\n INTERSECTING: 1,\n ABOVE: 2,\n RIGHT: 4,\n BELOW: 8,\n LEFT: 16,\n};\n","/**\n * @module ol/featureloader\n */\nimport {VOID} from './functions.js';\n\n/**\n *\n * @type {boolean}\n * @private\n */\nlet withCredentials = false;\n\n/**\n * {@link module:ol/source/Vector~VectorSource} sources use a function of this type to\n * load features.\n *\n * This function takes up to 5 arguments. These are an {@link module:ol/extent~Extent} representing\n * the area to be loaded, a `{number}` representing the resolution (map units per pixel), a\n * {@link module:ol/proj/Projection~Projection} for the projection, an optional success callback that should get\n * the loaded features passed as an argument and an optional failure callback with no arguments. If\n * the callbacks are not used, the corresponding vector source will not fire `'featuresloadend'` and\n * `'featuresloaderror'` events. `this` within the function is bound to the\n * {@link module:ol/source/Vector~VectorSource} it's called from.\n *\n * The function is responsible for loading the features and adding them to the\n * source.\n *\n * @template {import(\"./Feature.js\").FeatureLike} [FeatureType=import(\"./Feature.js\").default]\n * @typedef {function(this:(import(\"./source/Vector\").default|import(\"./VectorTile.js\").default),\n * import(\"./extent.js\").Extent,\n * number,\n * import(\"./proj/Projection.js\").default,\n * function(Array): void=,\n * function(): void=): void} FeatureLoader\n * @api\n */\n\n/**\n * {@link module:ol/source/Vector~VectorSource} sources use a function of this type to\n * get the url to load features from.\n *\n * This function takes an {@link module:ol/extent~Extent} representing the area\n * to be loaded, a `{number}` representing the resolution (map units per pixel)\n * and an {@link module:ol/proj/Projection~Projection} for the projection as\n * arguments and returns a `{string}` representing the URL.\n * @typedef {function(import(\"./extent.js\").Extent, number, import(\"./proj/Projection.js\").default): string} FeatureUrlFunction\n * @api\n */\n\n/**\n * @template {import(\"./Feature.js\").FeatureLike} [FeatureType=import(\"./Feature.js\").default]\n * @param {string|FeatureUrlFunction} url Feature URL service.\n * @param {import(\"./format/Feature.js\").default} format Feature format.\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number} resolution Resolution.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @param {function(Array, import(\"./proj/Projection.js\").default): void} success Success\n * Function called with the loaded features and optionally with the data projection.\n * @param {function(): void} failure Failure\n * Function called when loading failed.\n */\nexport function loadFeaturesXhr(\n url,\n format,\n extent,\n resolution,\n projection,\n success,\n failure,\n) {\n const xhr = new XMLHttpRequest();\n xhr.open(\n 'GET',\n typeof url === 'function' ? url(extent, resolution, projection) : url,\n true,\n );\n if (format.getType() == 'arraybuffer') {\n xhr.responseType = 'arraybuffer';\n }\n xhr.withCredentials = withCredentials;\n /**\n * @param {Event} event Event.\n * @private\n */\n xhr.onload = function (event) {\n // status will be 0 for file:// urls\n if (!xhr.status || (xhr.status >= 200 && xhr.status < 300)) {\n const type = format.getType();\n try {\n /** @type {Document|Node|Object|string|undefined} */\n let source;\n if (type == 'text' || type == 'json') {\n source = xhr.responseText;\n } else if (type == 'xml') {\n source = xhr.responseXML || xhr.responseText;\n } else if (type == 'arraybuffer') {\n source = /** @type {ArrayBuffer} */ (xhr.response);\n }\n if (source) {\n success(\n /** @type {Array} */\n (\n format.readFeatures(source, {\n extent: extent,\n featureProjection: projection,\n })\n ),\n format.readProjection(source),\n );\n } else {\n failure();\n }\n } catch {\n failure();\n }\n } else {\n failure();\n }\n };\n /**\n * @private\n */\n xhr.onerror = failure;\n xhr.send();\n}\n\n/**\n * Create an XHR feature loader for a `url` and `format`. The feature loader\n * loads features (with XHR), parses the features, and adds them to the\n * vector source.\n * @template {import(\"./Feature.js\").FeatureLike} FeatureType\n * @param {string|FeatureUrlFunction} url Feature URL service.\n * @param {import(\"./format/Feature.js\").default} format Feature format.\n * @return {FeatureLoader} The feature loader.\n * @api\n */\nexport function xhr(url, format) {\n /**\n * @param {import(\"./extent.js\").Extent} extent Extent.\n * @param {number} resolution Resolution.\n * @param {import(\"./proj/Projection.js\").default} projection Projection.\n * @param {function(Array): void} [success] Success\n * Function called when loading succeeded.\n * @param {function(): void} [failure] Failure\n * Function called when loading failed.\n */\n return function (extent, resolution, projection, success, failure) {\n const source =\n /** @type {import(\"./source/Vector\").default} */ (this);\n loadFeaturesXhr(\n url,\n format,\n extent,\n resolution,\n projection,\n /**\n * @param {Array} features The loaded features.\n * @param {import(\"./proj/Projection.js\").default} dataProjection Data\n * projection.\n */\n function (features, dataProjection) {\n source.addFeatures(features);\n if (success !== undefined) {\n success(features);\n }\n },\n /* FIXME handle error */ failure ? failure : VOID,\n );\n };\n}\n\n/**\n * Setter for the withCredentials configuration for the XHR.\n *\n * @param {boolean} xhrWithCredentials The value of withCredentials to set.\n * Compare https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/\n * @api\n */\nexport function setWithCredentials(xhrWithCredentials) {\n withCredentials = xhrWithCredentials;\n}\n","/**\n * @module ol/geom/GeometryCollection\n */\nimport EventType from '../events/EventType.js';\nimport Geometry from './Geometry.js';\nimport {\n closestSquaredDistanceXY,\n createOrUpdateEmpty,\n extend,\n getCenter,\n} from '../extent.js';\nimport {listen, unlistenByKey} from '../events.js';\n\n/**\n * @classdesc\n * An array of {@link module:ol/geom/Geometry~Geometry} objects.\n *\n * @api\n */\nclass GeometryCollection extends Geometry {\n /**\n * @param {Array} geometries Geometries.\n */\n constructor(geometries) {\n super();\n\n /**\n * @private\n * @type {Array}\n */\n this.geometries_ = geometries;\n\n /**\n * @private\n * @type {Array}\n */\n this.changeEventsKeys_ = [];\n\n this.listenGeometriesChange_();\n }\n\n /**\n * @private\n */\n unlistenGeometriesChange_() {\n this.changeEventsKeys_.forEach(unlistenByKey);\n this.changeEventsKeys_.length = 0;\n }\n\n /**\n * @private\n */\n listenGeometriesChange_() {\n const geometries = this.geometries_;\n for (let i = 0, ii = geometries.length; i < ii; ++i) {\n this.changeEventsKeys_.push(\n listen(geometries[i], EventType.CHANGE, this.changed, this),\n );\n }\n }\n\n /**\n * Make a complete copy of the geometry.\n * @return {!GeometryCollection} Clone.\n * @api\n * @override\n */\n clone() {\n const geometryCollection = new GeometryCollection(\n cloneGeometries(this.geometries_),\n );\n geometryCollection.applyProperties(this);\n return geometryCollection;\n }\n\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n * @override\n */\n closestPointXY(x, y, closestPoint, minSquaredDistance) {\n if (minSquaredDistance < closestSquaredDistanceXY(this.getExtent(), x, y)) {\n return minSquaredDistance;\n }\n const geometries = this.geometries_;\n for (let i = 0, ii = geometries.length; i < ii; ++i) {\n minSquaredDistance = geometries[i].closestPointXY(\n x,\n y,\n closestPoint,\n minSquaredDistance,\n );\n }\n return minSquaredDistance;\n }\n\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @return {boolean} Contains (x, y).\n * @override\n */\n containsXY(x, y) {\n const geometries = this.geometries_;\n for (let i = 0, ii = geometries.length; i < ii; ++i) {\n if (geometries[i].containsXY(x, y)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @protected\n * @return {import(\"../extent.js\").Extent} extent Extent.\n * @override\n */\n computeExtent(extent) {\n createOrUpdateEmpty(extent);\n const geometries = this.geometries_;\n for (let i = 0, ii = geometries.length; i < ii; ++i) {\n extend(extent, geometries[i].getExtent());\n }\n return extent;\n }\n\n /**\n * Return the geometries that make up this geometry collection.\n * @return {Array} Geometries.\n * @api\n */\n getGeometries() {\n return cloneGeometries(this.geometries_);\n }\n\n /**\n * @return {Array} Geometries.\n */\n getGeometriesArray() {\n return this.geometries_;\n }\n\n /**\n * @return {Array} Geometries.\n */\n getGeometriesArrayRecursive() {\n /** @type {Array} */\n let geometriesArray = [];\n const geometries = this.geometries_;\n for (let i = 0, ii = geometries.length; i < ii; ++i) {\n if (geometries[i].getType() === this.getType()) {\n geometriesArray = geometriesArray.concat(\n /** @type {GeometryCollection} */ (\n geometries[i]\n ).getGeometriesArrayRecursive(),\n );\n } else {\n geometriesArray.push(geometries[i]);\n }\n }\n return geometriesArray;\n }\n\n /**\n * Create a simplified version of this geometry using the Douglas Peucker algorithm.\n * @param {number} squaredTolerance Squared tolerance.\n * @return {GeometryCollection} Simplified GeometryCollection.\n * @override\n */\n getSimplifiedGeometry(squaredTolerance) {\n if (this.simplifiedGeometryRevision !== this.getRevision()) {\n this.simplifiedGeometryMaxMinSquaredTolerance = 0;\n this.simplifiedGeometryRevision = this.getRevision();\n }\n if (\n squaredTolerance < 0 ||\n (this.simplifiedGeometryMaxMinSquaredTolerance !== 0 &&\n squaredTolerance < this.simplifiedGeometryMaxMinSquaredTolerance)\n ) {\n return this;\n }\n\n const simplifiedGeometries = [];\n const geometries = this.geometries_;\n let simplified = false;\n for (let i = 0, ii = geometries.length; i < ii; ++i) {\n const geometry = geometries[i];\n const simplifiedGeometry =\n geometry.getSimplifiedGeometry(squaredTolerance);\n simplifiedGeometries.push(simplifiedGeometry);\n if (simplifiedGeometry !== geometry) {\n simplified = true;\n }\n }\n if (simplified) {\n const simplifiedGeometryCollection = new GeometryCollection(\n simplifiedGeometries,\n );\n return simplifiedGeometryCollection;\n }\n this.simplifiedGeometryMaxMinSquaredTolerance = squaredTolerance;\n return this;\n }\n\n /**\n * Get the type of this geometry.\n * @return {import(\"./Geometry.js\").Type} Geometry type.\n * @api\n * @override\n */\n getType() {\n return 'GeometryCollection';\n }\n\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n * @override\n */\n intersectsExtent(extent) {\n const geometries = this.geometries_;\n for (let i = 0, ii = geometries.length; i < ii; ++i) {\n if (geometries[i].intersectsExtent(extent)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * @return {boolean} Is empty.\n */\n isEmpty() {\n return this.geometries_.length === 0;\n }\n\n /**\n * Rotate the geometry around a given coordinate. This modifies the geometry\n * coordinates in place.\n * @param {number} angle Rotation angle in radians.\n * @param {import(\"../coordinate.js\").Coordinate} anchor The rotation center.\n * @api\n * @override\n */\n rotate(angle, anchor) {\n const geometries = this.geometries_;\n for (let i = 0, ii = geometries.length; i < ii; ++i) {\n geometries[i].rotate(angle, anchor);\n }\n this.changed();\n }\n\n /**\n * Scale the geometry (with an optional origin). This modifies the geometry\n * coordinates in place.\n * @abstract\n * @param {number} sx The scaling factor in the x-direction.\n * @param {number} [sy] The scaling factor in the y-direction (defaults to sx).\n * @param {import(\"../coordinate.js\").Coordinate} [anchor] The scale origin (defaults to the center\n * of the geometry extent).\n * @api\n * @override\n */\n scale(sx, sy, anchor) {\n if (!anchor) {\n anchor = getCenter(this.getExtent());\n }\n const geometries = this.geometries_;\n for (let i = 0, ii = geometries.length; i < ii; ++i) {\n geometries[i].scale(sx, sy, anchor);\n }\n this.changed();\n }\n\n /**\n * Set the geometries that make up this geometry collection.\n * @param {Array} geometries Geometries.\n * @api\n */\n setGeometries(geometries) {\n this.setGeometriesArray(cloneGeometries(geometries));\n }\n\n /**\n * @param {Array} geometries Geometries.\n */\n setGeometriesArray(geometries) {\n this.unlistenGeometriesChange_();\n this.geometries_ = geometries;\n this.listenGeometriesChange_();\n this.changed();\n }\n\n /**\n * Apply a transform function to the coordinates of the geometry.\n * The geometry is modified in place.\n * If you do not want the geometry modified in place, first `clone()` it and\n * then use this function on the clone.\n * @param {import(\"../proj.js\").TransformFunction} transformFn Transform function.\n * Called with a flat array of geometry coordinates.\n * @api\n * @override\n */\n applyTransform(transformFn) {\n const geometries = this.geometries_;\n for (let i = 0, ii = geometries.length; i < ii; ++i) {\n geometries[i].applyTransform(transformFn);\n }\n this.changed();\n }\n\n /**\n * Translate the geometry. This modifies the geometry coordinates in place. If\n * instead you want a new geometry, first `clone()` this geometry.\n * @param {number} deltaX Delta X.\n * @param {number} deltaY Delta Y.\n * @api\n * @override\n */\n translate(deltaX, deltaY) {\n const geometries = this.geometries_;\n for (let i = 0, ii = geometries.length; i < ii; ++i) {\n geometries[i].translate(deltaX, deltaY);\n }\n this.changed();\n }\n\n /**\n * Clean up.\n * @override\n */\n disposeInternal() {\n this.unlistenGeometriesChange_();\n super.disposeInternal();\n }\n}\n\n/**\n * @param {Array} geometries Geometries.\n * @return {Array} Cloned geometries.\n */\nfunction cloneGeometries(geometries) {\n return geometries.map((geometry) => geometry.clone());\n}\n\nexport default GeometryCollection;\n","/**\n * @module ol/format/Feature\n */\nimport Feature from '../Feature.js';\nimport RenderFeature from '../render/Feature.js';\nimport {\n GeometryCollection,\n LineString,\n MultiLineString,\n MultiPoint,\n MultiPolygon,\n Point,\n Polygon,\n} from '../geom.js';\nimport {abstract} from '../util.js';\nimport {\n equivalent as equivalentProjection,\n get as getProjection,\n getTransform,\n transformExtent,\n} from '../proj.js';\nimport {\n linearRingsAreOriented,\n linearRingssAreOriented,\n orientLinearRings,\n orientLinearRingsArray,\n} from '../geom/flat/orient.js';\n\n/**\n * @typedef {Object} ReadOptions\n * @property {import(\"../proj.js\").ProjectionLike} [dataProjection] Projection of the data we are reading.\n * If not provided, the projection will be derived from the data (where possible) or\n * the `dataProjection` of the format is assigned (where set). If the projection\n * can not be derived from the data and if no `dataProjection` is set for a format,\n * the features will not be reprojected.\n * @property {import(\"../extent.js\").Extent} [extent] Tile extent in map units of the tile being read.\n * This is only required when reading data with tile pixels as geometry units. When configured,\n * a `dataProjection` with `TILE_PIXELS` as `units` and the tile's pixel extent as `extent` needs to be\n * provided.\n * @property {import(\"../proj.js\").ProjectionLike} [featureProjection] Projection of the feature geometries\n * created by the format reader. If not provided, features will be returned in the\n * `dataProjection`.\n */\n\n/**\n * @typedef {Object} WriteOptions\n * @property {import(\"../proj.js\").ProjectionLike} [dataProjection] Projection of the data we are writing.\n * If not provided, the `dataProjection` of the format is assigned (where set).\n * If no `dataProjection` is set for a format, the features will be returned\n * in the `featureProjection`.\n * @property {import(\"../proj.js\").ProjectionLike} [featureProjection] Projection of the feature geometries\n * that will be serialized by the format writer. If not provided, geometries are assumed\n * to be in the `dataProjection` if that is set; in other words, they are not transformed.\n * @property {boolean} [rightHanded] When writing geometries, follow the right-hand\n * rule for linear ring orientation. This means that polygons will have counter-clockwise\n * exterior rings and clockwise interior rings. By default, coordinates are serialized\n * as they are provided at construction. If `true`, the right-hand rule will\n * be applied. If `false`, the left-hand rule will be applied (clockwise for\n * exterior and counter-clockwise for interior rings). Note that not all\n * formats support this. The GeoJSON format does use this property when writing\n * geometries.\n * @property {number} [decimals] Maximum number of decimal places for coordinates.\n * Coordinates are stored internally as floats, but floating-point arithmetic can create\n * coordinates with a large number of decimal places, not generally wanted on output.\n * Set a number here to round coordinates. Can also be used to ensure that\n * coordinates read in can be written back out with the same number of decimals.\n * Default is no rounding.\n */\n\n/**\n * @typedef {'arraybuffer' | 'json' | 'text' | 'xml'} Type\n */\n\n/**\n * @typedef {Object} SimpleGeometryObject\n * @property {import('../geom/Geometry.js').Type} type Type.\n * @property {Array} flatCoordinates Flat coordinates.\n * @property {Array|Array>} [ends] Ends or endss.\n * @property {import('../geom/Geometry.js').GeometryLayout} [layout] Layout.\n */\n\n/**\n * @typedef {Array} GeometryCollectionObject\n */\n\n/**\n * @typedef {SimpleGeometryObject|GeometryCollectionObject} GeometryObject\n */\n\n/**\n * @typedef {Object} FeatureObject\n * @property {string|number} [id] Id.\n * @property {GeometryObject} [geometry] Geometry.\n * @property {Object} [properties] Properties.\n */\n\n/***\n * @template {import('../Feature.js').FeatureLike} T\n * @typedef {T extends RenderFeature ? typeof RenderFeature : typeof Feature} FeatureToFeatureClass\n */\n\n/***\n * @template {import(\"../Feature.js\").FeatureClass} T\n * @typedef {T[keyof T] extends RenderFeature ? RenderFeature : Feature} FeatureClassToFeature\n */\n\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * Base class for feature formats.\n * {@link module:ol/format/Feature~FeatureFormat} subclasses provide the ability to decode and encode\n * {@link module:ol/Feature~Feature} objects from a variety of commonly used geospatial\n * file formats. See the documentation for each format for more details.\n *\n * @template {import('../Feature.js').FeatureLike} [FeatureType=import(\"../Feature.js\").default]\n * @abstract\n * @api\n */\nclass FeatureFormat {\n constructor() {\n /**\n * @protected\n * @type {import(\"../proj/Projection.js\").default|undefined}\n */\n this.dataProjection = undefined;\n\n /**\n * @protected\n * @type {import(\"../proj/Projection.js\").default|undefined}\n */\n this.defaultFeatureProjection = undefined;\n\n /**\n * @protected\n * @type {FeatureToFeatureClass}\n */\n this.featureClass = /** @type {FeatureToFeatureClass} */ (\n Feature\n );\n\n /**\n * A list media types supported by the format in descending order of preference.\n * @type {Array}\n */\n this.supportedMediaTypes = null;\n }\n\n /**\n * Adds the data projection to the read options.\n * @param {Document|Element|Object|string} source Source.\n * @param {ReadOptions} [options] Options.\n * @return {ReadOptions|undefined} Options.\n * @protected\n */\n getReadOptions(source, options) {\n if (options) {\n let dataProjection = options.dataProjection\n ? getProjection(options.dataProjection)\n : this.readProjection(source);\n if (\n options.extent &&\n dataProjection &&\n dataProjection.getUnits() === 'tile-pixels'\n ) {\n dataProjection = getProjection(dataProjection);\n dataProjection.setWorldExtent(options.extent);\n }\n options = {\n dataProjection: dataProjection,\n featureProjection: options.featureProjection,\n };\n }\n return this.adaptOptions(options);\n }\n\n /**\n * Sets the `dataProjection` on the options, if no `dataProjection`\n * is set.\n * @param {WriteOptions|ReadOptions|undefined} options\n * Options.\n * @protected\n * @return {WriteOptions|ReadOptions|undefined}\n * Updated options.\n */\n adaptOptions(options) {\n return Object.assign(\n {\n dataProjection: this.dataProjection,\n featureProjection: this.defaultFeatureProjection,\n featureClass: this.featureClass,\n },\n options,\n );\n }\n\n /**\n * @abstract\n * @return {Type} The format type.\n */\n getType() {\n return abstract();\n }\n\n /**\n * Read a single feature from a source.\n *\n * @abstract\n * @param {Document|Element|Object|string} source Source.\n * @param {ReadOptions} [options] Read options.\n * @return {FeatureType|Array} Feature.\n */\n readFeature(source, options) {\n return abstract();\n }\n\n /**\n * Read all features from a source.\n *\n * @abstract\n * @param {Document|Element|ArrayBuffer|Object|string} source Source.\n * @param {ReadOptions} [options] Read options.\n * @return {Array} Features.\n */\n readFeatures(source, options) {\n return abstract();\n }\n\n /**\n * Read a single geometry from a source.\n *\n * @abstract\n * @param {Document|Element|Object|string} source Source.\n * @param {ReadOptions} [options] Read options.\n * @return {import(\"../geom/Geometry.js\").default} Geometry.\n */\n readGeometry(source, options) {\n return abstract();\n }\n\n /**\n * Read the projection from a source.\n *\n * @abstract\n * @param {Document|Element|Object|string} source Source.\n * @return {import(\"../proj/Projection.js\").default|undefined} Projection.\n */\n readProjection(source) {\n return abstract();\n }\n\n /**\n * Encode a feature in this format.\n *\n * @abstract\n * @param {Feature} feature Feature.\n * @param {WriteOptions} [options] Write options.\n * @return {string|ArrayBuffer} Result.\n */\n writeFeature(feature, options) {\n return abstract();\n }\n\n /**\n * Encode an array of features in this format.\n *\n * @abstract\n * @param {Array} features Features.\n * @param {WriteOptions} [options] Write options.\n * @return {string|ArrayBuffer} Result.\n */\n writeFeatures(features, options) {\n return abstract();\n }\n\n /**\n * Write a single geometry in this format.\n *\n * @abstract\n * @param {import(\"../geom/Geometry.js\").default} geometry Geometry.\n * @param {WriteOptions} [options] Write options.\n * @return {string|ArrayBuffer} Result.\n */\n writeGeometry(geometry, options) {\n return abstract();\n }\n}\n\nexport default FeatureFormat;\n\n/**\n * @template {import(\"../geom/Geometry.js\").default|RenderFeature} T\n * @param {T} geometry Geometry.\n * @param {boolean} write Set to true for writing, false for reading.\n * @param {WriteOptions|ReadOptions} [options] Options.\n * @return {T} Transformed geometry.\n */\nexport function transformGeometryWithOptions(geometry, write, options) {\n const featureProjection = options\n ? getProjection(options.featureProjection)\n : null;\n const dataProjection = options ? getProjection(options.dataProjection) : null;\n\n let transformed = geometry;\n if (\n featureProjection &&\n dataProjection &&\n !equivalentProjection(featureProjection, dataProjection)\n ) {\n if (write) {\n transformed = /** @type {T} */ (geometry.clone());\n }\n const fromProjection = write ? featureProjection : dataProjection;\n const toProjection = write ? dataProjection : featureProjection;\n if (fromProjection.getUnits() === 'tile-pixels') {\n transformed.transform(fromProjection, toProjection);\n } else {\n transformed.applyTransform(getTransform(fromProjection, toProjection));\n }\n }\n if (\n write &&\n options &&\n /** @type {WriteOptions} */ (options).decimals !== undefined\n ) {\n const power = Math.pow(10, /** @type {WriteOptions} */ (options).decimals);\n // if decimals option on write, round each coordinate appropriately\n /**\n * @param {Array} coordinates Coordinates.\n * @return {Array} Transformed coordinates.\n */\n const transform = function (coordinates) {\n for (let i = 0, ii = coordinates.length; i < ii; ++i) {\n coordinates[i] = Math.round(coordinates[i] * power) / power;\n }\n return coordinates;\n };\n if (transformed === geometry) {\n transformed = /** @type {T} */ (geometry.clone());\n }\n transformed.applyTransform(transform);\n }\n return transformed;\n}\n\n/**\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @param {ReadOptions} [options] Read options.\n * @return {import(\"../extent.js\").Extent} Transformed extent.\n */\nexport function transformExtentWithOptions(extent, options) {\n const featureProjection = options\n ? getProjection(options.featureProjection)\n : null;\n const dataProjection = options ? getProjection(options.dataProjection) : null;\n\n if (\n featureProjection &&\n dataProjection &&\n !equivalentProjection(featureProjection, dataProjection)\n ) {\n return transformExtent(extent, dataProjection, featureProjection);\n }\n return extent;\n}\n\nconst GeometryConstructor = {\n Point: Point,\n LineString: LineString,\n Polygon: Polygon,\n MultiPoint: MultiPoint,\n MultiLineString: MultiLineString,\n MultiPolygon: MultiPolygon,\n};\n\nfunction orientFlatCoordinates(flatCoordinates, ends, stride) {\n if (Array.isArray(ends[0])) {\n // MultiPolagon\n if (!linearRingssAreOriented(flatCoordinates, 0, ends, stride)) {\n flatCoordinates = flatCoordinates.slice();\n orientLinearRingsArray(flatCoordinates, 0, ends, stride);\n }\n return flatCoordinates;\n }\n if (!linearRingsAreOriented(flatCoordinates, 0, ends, stride)) {\n flatCoordinates = flatCoordinates.slice();\n orientLinearRings(flatCoordinates, 0, ends, stride);\n }\n return flatCoordinates;\n}\n\n/**\n * @param {FeatureObject} object Feature object.\n * @param {WriteOptions|ReadOptions} [options] Options.\n * @return {RenderFeature|Array} Render feature.\n */\nexport function createRenderFeature(object, options) {\n const geometry = object.geometry;\n if (!geometry) {\n return [];\n }\n if (Array.isArray(geometry)) {\n return geometry\n .map((geometry) => createRenderFeature({...object, geometry}))\n .flat();\n }\n\n const geometryType =\n geometry.type === 'MultiPolygon' ? 'Polygon' : geometry.type;\n if (geometryType === 'GeometryCollection' || geometryType === 'Circle') {\n throw new Error('Unsupported geometry type: ' + geometryType);\n }\n\n const stride = geometry.layout.length;\n return transformGeometryWithOptions(\n new RenderFeature(\n geometryType,\n geometryType === 'Polygon'\n ? orientFlatCoordinates(geometry.flatCoordinates, geometry.ends, stride)\n : geometry.flatCoordinates,\n geometry.ends?.flat(),\n stride,\n object.properties || {},\n object.id,\n ).enableSimplifyTransformed(),\n false,\n options,\n );\n}\n\n/**\n * @param {GeometryObject|null} object Geometry object.\n * @param {WriteOptions|ReadOptions} [options] Options.\n * @return {import(\"../geom/Geometry.js\").default} Geometry.\n */\nexport function createGeometry(object, options) {\n if (!object) {\n return null;\n }\n if (Array.isArray(object)) {\n const geometries = object.map((geometry) =>\n createGeometry(geometry, options),\n );\n return new GeometryCollection(geometries);\n }\n const Geometry = GeometryConstructor[object.type];\n return transformGeometryWithOptions(\n new Geometry(object.flatCoordinates, object.layout, object.ends),\n false,\n options,\n );\n}\n","/**\n * @module ol/format/JSONFeature\n */\nimport FeatureFormat from './Feature.js';\nimport {abstract} from '../util.js';\n\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * Base class for JSON feature formats.\n *\n * @template {import('../Feature.js').FeatureLike} [FeatureType=import(\"../Feature.js\").default]\n * @extends {FeatureFormat}\n * @abstract\n */\nclass JSONFeature extends FeatureFormat {\n constructor() {\n super();\n }\n\n /**\n * @return {import(\"./Feature.js\").Type} Format.\n * @override\n */\n getType() {\n return 'json';\n }\n\n /**\n * Read a feature. Only works for a single feature. Use `readFeatures` to\n * read a feature collection.\n *\n * @param {ArrayBuffer|Document|Element|Object|string} source Source.\n * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n * @return {FeatureType|Array} Feature.\n * @api\n * @override\n */\n readFeature(source, options) {\n return this.readFeatureFromObject(\n getObject(source),\n this.getReadOptions(source, options),\n );\n }\n\n /**\n * Read all features. Works with both a single feature and a feature\n * collection.\n *\n * @param {ArrayBuffer|Document|Element|Object|string} source Source.\n * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n * @return {Array} Features.\n * @api\n * @override\n */\n readFeatures(source, options) {\n return this.readFeaturesFromObject(\n getObject(source),\n this.getReadOptions(source, options),\n );\n }\n\n /**\n * @abstract\n * @param {Object} object Object.\n * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n * @protected\n * @return {FeatureType|Array} Feature.\n */\n readFeatureFromObject(object, options) {\n return abstract();\n }\n\n /**\n * @abstract\n * @param {Object} object Object.\n * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n * @protected\n * @return {Array} Features.\n */\n readFeaturesFromObject(object, options) {\n return abstract();\n }\n\n /**\n * Read a geometry.\n *\n * @param {ArrayBuffer|Document|Element|Object|string} source Source.\n * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n * @return {import(\"../geom/Geometry.js\").default} Geometry.\n * @api\n * @override\n */\n readGeometry(source, options) {\n return this.readGeometryFromObject(\n getObject(source),\n this.getReadOptions(source, options),\n );\n }\n\n /**\n * @abstract\n * @param {Object} object Object.\n * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n * @protected\n * @return {import(\"../geom/Geometry.js\").default} Geometry.\n */\n readGeometryFromObject(object, options) {\n return abstract();\n }\n\n /**\n * Read the projection.\n *\n * @param {ArrayBuffer|Document|Element|Object|string} source Source.\n * @return {import(\"../proj/Projection.js\").default} Projection.\n * @api\n * @override\n */\n readProjection(source) {\n return this.readProjectionFromObject(getObject(source));\n }\n\n /**\n * @abstract\n * @param {Object} object Object.\n * @protected\n * @return {import(\"../proj/Projection.js\").default} Projection.\n */\n readProjectionFromObject(object) {\n return abstract();\n }\n\n /**\n * Encode a feature as string.\n *\n * @param {import(\"../Feature.js\").default} feature Feature.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {string} Encoded feature.\n * @api\n * @override\n */\n writeFeature(feature, options) {\n return JSON.stringify(this.writeFeatureObject(feature, options));\n }\n\n /**\n * @abstract\n * @param {import(\"../Feature.js\").default} feature Feature.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {Object} Object.\n */\n writeFeatureObject(feature, options) {\n return abstract();\n }\n\n /**\n * Encode an array of features as string.\n *\n * @param {Array} features Features.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {string} Encoded features.\n * @api\n * @override\n */\n writeFeatures(features, options) {\n return JSON.stringify(this.writeFeaturesObject(features, options));\n }\n\n /**\n * @abstract\n * @param {Array} features Features.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {Object} Object.\n */\n writeFeaturesObject(features, options) {\n return abstract();\n }\n\n /**\n * Encode a geometry as string.\n *\n * @param {import(\"../geom/Geometry.js\").default} geometry Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {string} Encoded geometry.\n * @api\n * @override\n */\n writeGeometry(geometry, options) {\n return JSON.stringify(this.writeGeometryObject(geometry, options));\n }\n\n /**\n * @abstract\n * @param {import(\"../geom/Geometry.js\").default} geometry Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {Object} Object.\n */\n writeGeometryObject(geometry, options) {\n return abstract();\n }\n}\n\n/**\n * @param {Document|Element|Object|string} source Source.\n * @return {Object} Object.\n */\nfunction getObject(source) {\n if (typeof source === 'string') {\n const object = JSON.parse(source);\n return object ? /** @type {Object} */ (object) : null;\n }\n if (source !== null) {\n return source;\n }\n return null;\n}\n\nexport default JSONFeature;\n","/**\n * @module ol/format/GeoJSON\n */\n\nimport Feature from '../Feature.js';\nimport JSONFeature from './JSONFeature.js';\nimport RenderFeature from '../render/Feature.js';\nimport {\n createGeometry,\n createRenderFeature,\n transformGeometryWithOptions,\n} from './Feature.js';\nimport {\n deflateCoordinatesArray,\n deflateMultiCoordinatesArray,\n} from '../geom/flat/deflate.js';\nimport {getLayoutForStride} from '../geom/SimpleGeometry.js';\nimport {get as getProjection} from '../proj.js';\nimport {isEmpty} from '../obj.js';\n\n/**\n * @typedef {import(\"geojson\").GeoJSON} GeoJSONObject\n * @typedef {import(\"geojson\").Feature} GeoJSONFeature\n * @typedef {import(\"geojson\").FeatureCollection} GeoJSONFeatureCollection\n * @typedef {import(\"geojson\").Geometry} GeoJSONGeometry\n * @typedef {import(\"geojson\").Point} GeoJSONPoint\n * @typedef {import(\"geojson\").LineString} GeoJSONLineString\n * @typedef {import(\"geojson\").Polygon} GeoJSONPolygon\n * @typedef {import(\"geojson\").MultiPoint} GeoJSONMultiPoint\n * @typedef {import(\"geojson\").MultiLineString} GeoJSONMultiLineString\n * @typedef {import(\"geojson\").MultiPolygon} GeoJSONMultiPolygon\n * @typedef {import(\"geojson\").GeometryCollection} GeoJSONGeometryCollection\n */\n\n/**\n * @template {import(\"../Feature.js\").FeatureLike} [FeatureType=import(\"../Feature.js\").default]\n * @typedef {Object} Options\n *\n * @property {import(\"../proj.js\").ProjectionLike} [dataProjection='EPSG:4326'] Default data projection.\n * @property {import(\"../proj.js\").ProjectionLike} [featureProjection] Projection for features read or\n * written by the format. Options passed to read or write methods will take precedence.\n * @property {string} [geometryName] Geometry name to use when creating features.\n * @property {boolean} [extractGeometryName=false] Certain GeoJSON providers include\n * the geometry_name field in the feature GeoJSON. If set to `true` the GeoJSON reader\n * will look for that field to set the geometry name. If both this field is set to `true`\n * and a `geometryName` is provided, the `geometryName` will take precedence.\n * @property {import('./Feature.js').FeatureToFeatureClass} [featureClass] Feature class\n * to be used when reading features. The default is {@link module:ol/Feature~Feature}. If performance is\n * the primary concern, and features are not going to be modified or round-tripped through the format,\n * consider using {@link module:ol/render/Feature~RenderFeature}\n */\n\n/**\n * @classdesc\n * Feature format for reading and writing data in the GeoJSON format.\n *\n * @template {import('../Feature.js').FeatureLike} [FeatureType=import(\"../Feature.js\").default]\n * @extends {JSONFeature}\n * @api\n */\nclass GeoJSON extends JSONFeature {\n /**\n * @param {Options} [options] Options.\n */\n constructor(options) {\n options = options ? options : {};\n\n super();\n\n /**\n * @type {import(\"../proj/Projection.js\").default}\n */\n this.dataProjection = getProjection(\n options.dataProjection ? options.dataProjection : 'EPSG:4326',\n );\n\n if (options.featureProjection) {\n /**\n * @type {import(\"../proj/Projection.js\").default}\n */\n this.defaultFeatureProjection = getProjection(options.featureProjection);\n }\n\n if (options.featureClass) {\n this.featureClass = options.featureClass;\n }\n\n /**\n * Name of the geometry attribute for features.\n * @type {string|undefined}\n * @private\n */\n this.geometryName_ = options.geometryName;\n\n /**\n * Look for the `geometry_name` in the feature GeoJSON\n * @type {boolean|undefined}\n * @private\n */\n this.extractGeometryName_ = options.extractGeometryName;\n\n this.supportedMediaTypes = [\n 'application/geo+json',\n 'application/vnd.geo+json',\n ];\n }\n\n /**\n * @param {Object} object Object.\n * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n * @protected\n * @return {FeatureType|Array} Feature.\n * @override\n */\n readFeatureFromObject(object, options) {\n /**\n * @type {GeoJSONFeature}\n */\n let geoJSONFeature = null;\n if (object['type'] === 'Feature') {\n geoJSONFeature = /** @type {GeoJSONFeature} */ (object);\n } else {\n geoJSONFeature = {\n 'type': 'Feature',\n 'geometry': /** @type {GeoJSONGeometry} */ (object),\n 'properties': null,\n };\n }\n\n const geometry = readGeometryInternal(geoJSONFeature['geometry'], options);\n if (this.featureClass === RenderFeature) {\n return /** @type {FeatureType|Array} */ (\n createRenderFeature(\n {\n geometry,\n id: geoJSONFeature['id'],\n properties: geoJSONFeature['properties'],\n },\n options,\n )\n );\n }\n\n const feature = new Feature();\n if (this.geometryName_) {\n feature.setGeometryName(this.geometryName_);\n } else if (this.extractGeometryName_ && geoJSONFeature['geometry_name']) {\n feature.setGeometryName(geoJSONFeature['geometry_name']);\n }\n feature.setGeometry(createGeometry(geometry, options));\n\n if ('id' in geoJSONFeature) {\n feature.setId(geoJSONFeature['id']);\n }\n\n if (geoJSONFeature['properties']) {\n feature.setProperties(geoJSONFeature['properties'], true);\n }\n return /** @type {FeatureType|Array} */ (feature);\n }\n\n /**\n * @param {Object} object Object.\n * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n * @protected\n * @return {Array} Features.\n * @override\n */\n readFeaturesFromObject(object, options) {\n const geoJSONObject = /** @type {GeoJSONObject} */ (object);\n let features = null;\n if (geoJSONObject['type'] === 'FeatureCollection') {\n const geoJSONFeatureCollection = /** @type {GeoJSONFeatureCollection} */ (\n object\n );\n features = [];\n const geoJSONFeatures = geoJSONFeatureCollection['features'];\n for (let i = 0, ii = geoJSONFeatures.length; i < ii; ++i) {\n const featureObject = this.readFeatureFromObject(\n geoJSONFeatures[i],\n options,\n );\n if (!featureObject) {\n continue;\n }\n features.push(featureObject);\n }\n } else {\n features = [this.readFeatureFromObject(object, options)];\n }\n return /** @type {Array} */ (features.flat());\n }\n\n /**\n * @param {GeoJSONGeometry} object Object.\n * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n * @protected\n * @return {import(\"../geom/Geometry.js\").default} Geometry.\n * @override\n */\n readGeometryFromObject(object, options) {\n return readGeometry(object, options);\n }\n\n /**\n * @param {Object} object Object.\n * @protected\n * @return {import(\"../proj/Projection.js\").default} Projection.\n * @override\n */\n readProjectionFromObject(object) {\n const crs = object['crs'];\n let projection;\n if (crs) {\n if (crs['type'] == 'name') {\n projection = getProjection(crs['properties']['name']);\n } else if (crs['type'] === 'EPSG') {\n projection = getProjection('EPSG:' + crs['properties']['code']);\n } else {\n throw new Error('Unknown SRS type');\n }\n } else {\n projection = this.dataProjection;\n }\n return /** @type {import(\"../proj/Projection.js\").default} */ (projection);\n }\n\n /**\n * Encode a feature as a GeoJSON Feature object.\n *\n * @param {import(\"../Feature.js\").default} feature Feature.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {GeoJSONFeature} Object.\n * @api\n * @override\n */\n writeFeatureObject(feature, options) {\n options = this.adaptOptions(options);\n\n /** @type {GeoJSONFeature} */\n const object = {\n 'type': 'Feature',\n geometry: null,\n properties: null,\n };\n\n const id = feature.getId();\n if (id !== undefined) {\n object.id = id;\n }\n\n if (!feature.hasProperties()) {\n return object;\n }\n\n const properties = feature.getProperties();\n const geometry = feature.getGeometry();\n if (geometry) {\n object.geometry = writeGeometry(geometry, options);\n\n delete properties[feature.getGeometryName()];\n }\n\n if (!isEmpty(properties)) {\n object.properties = properties;\n }\n\n return object;\n }\n\n /**\n * Encode an array of features as a GeoJSON object.\n *\n * @param {Array} features Features.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {GeoJSONFeatureCollection} GeoJSON Object.\n * @api\n * @override\n */\n writeFeaturesObject(features, options) {\n options = this.adaptOptions(options);\n const objects = [];\n for (let i = 0, ii = features.length; i < ii; ++i) {\n objects.push(this.writeFeatureObject(features[i], options));\n }\n return {\n type: 'FeatureCollection',\n features: objects,\n };\n }\n\n /**\n * Encode a geometry as a GeoJSON object.\n *\n * @param {import(\"../geom/Geometry.js\").default} geometry Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {GeoJSONGeometry|GeoJSONGeometryCollection} Object.\n * @api\n * @override\n */\n writeGeometryObject(geometry, options) {\n return writeGeometry(geometry, this.adaptOptions(options));\n }\n}\n\n/**\n * @param {GeoJSONGeometry|GeoJSONGeometryCollection} object Object.\n * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n * @return {import(\"./Feature.js\").GeometryObject} Geometry.\n */\nfunction readGeometryInternal(object, options) {\n if (!object) {\n return null;\n }\n\n /** @type {import(\"./Feature.js\").GeometryObject} */\n let geometry;\n switch (object['type']) {\n case 'Point': {\n geometry = readPointGeometry(/** @type {GeoJSONPoint} */ (object));\n break;\n }\n case 'LineString': {\n geometry = readLineStringGeometry(\n /** @type {GeoJSONLineString} */ (object),\n );\n break;\n }\n case 'Polygon': {\n geometry = readPolygonGeometry(/** @type {GeoJSONPolygon} */ (object));\n break;\n }\n case 'MultiPoint': {\n geometry = readMultiPointGeometry(\n /** @type {GeoJSONMultiPoint} */ (object),\n );\n break;\n }\n case 'MultiLineString': {\n geometry = readMultiLineStringGeometry(\n /** @type {GeoJSONMultiLineString} */ (object),\n );\n break;\n }\n case 'MultiPolygon': {\n geometry = readMultiPolygonGeometry(\n /** @type {GeoJSONMultiPolygon} */ (object),\n );\n break;\n }\n case 'GeometryCollection': {\n geometry = readGeometryCollectionGeometry(\n /** @type {GeoJSONGeometryCollection} */ (object),\n );\n break;\n }\n default: {\n throw new Error('Unsupported GeoJSON type: ' + object['type']);\n }\n }\n return geometry;\n}\n\n/**\n * @param {GeoJSONGeometry|GeoJSONGeometryCollection} object Object.\n * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n * @return {import(\"../geom/Geometry.js\").default} Geometry.\n */\nfunction readGeometry(object, options) {\n const geometryObject = readGeometryInternal(object, options);\n return createGeometry(geometryObject, options);\n}\n\n/**\n * @param {GeoJSONGeometryCollection} object Object.\n * @param {import(\"./Feature.js\").ReadOptions} [options] Read options.\n * @return {import(\"./Feature.js\").GeometryCollectionObject} Geometry collection.\n */\nfunction readGeometryCollectionGeometry(object, options) {\n const geometries = object['geometries'].map(\n /**\n * @param {GeoJSONGeometry} geometry Geometry.\n * @return {import(\"./Feature.js\").GeometryObject} geometry Geometry.\n */\n function (geometry) {\n return readGeometryInternal(geometry, options);\n },\n );\n return geometries;\n}\n\n/**\n * @param {GeoJSONPoint} object Input object.\n * @return {import(\"./Feature.js\").GeometryObject} Point geometry.\n */\nfunction readPointGeometry(object) {\n const flatCoordinates = object['coordinates'];\n return {\n type: 'Point',\n flatCoordinates,\n layout: getLayoutForStride(flatCoordinates.length),\n };\n}\n\n/**\n * @param {GeoJSONLineString} object Object.\n * @return {import(\"./Feature.js\").GeometryObject} LineString geometry.\n */\nfunction readLineStringGeometry(object) {\n const coordinates = object['coordinates'];\n const flatCoordinates = coordinates.flat();\n return {\n type: 'LineString',\n flatCoordinates,\n ends: [flatCoordinates.length],\n layout: getLayoutForStride(coordinates[0]?.length || 2),\n };\n}\n\n/**\n * @param {GeoJSONMultiLineString} object Object.\n * @return {import(\"./Feature.js\").GeometryObject} MultiLineString geometry.\n */\nfunction readMultiLineStringGeometry(object) {\n const coordinates = object['coordinates'];\n const stride = coordinates[0]?.[0]?.length || 2;\n const flatCoordinates = [];\n const ends = deflateCoordinatesArray(flatCoordinates, 0, coordinates, stride);\n return {\n type: 'MultiLineString',\n flatCoordinates,\n ends,\n layout: getLayoutForStride(stride),\n };\n}\n\n/**\n * @param {GeoJSONMultiPoint} object Object.\n * @return {import(\"./Feature.js\").GeometryObject} MultiPoint geometry.\n */\nfunction readMultiPointGeometry(object) {\n const coordinates = object['coordinates'];\n return {\n type: 'MultiPoint',\n flatCoordinates: coordinates.flat(),\n layout: getLayoutForStride(coordinates[0]?.length || 2),\n };\n}\n\n/**\n * @param {GeoJSONMultiPolygon} object Object.\n * @return {import(\"./Feature.js\").GeometryObject} MultiPolygon geometry.\n */\nfunction readMultiPolygonGeometry(object) {\n const coordinates = object['coordinates'];\n const flatCoordinates = [];\n const stride = coordinates[0]?.[0]?.[0].length || 2;\n const endss = deflateMultiCoordinatesArray(\n flatCoordinates,\n 0,\n coordinates,\n stride,\n );\n return {\n type: 'MultiPolygon',\n flatCoordinates,\n ends: endss,\n layout: getLayoutForStride(stride),\n };\n}\n\n/**\n * @param {GeoJSONPolygon} object Object.\n * @return {import(\"./Feature.js\").GeometryObject} Polygon.\n */\nfunction readPolygonGeometry(object) {\n const coordinates = object['coordinates'];\n const flatCoordinates = [];\n const stride = coordinates[0]?.[0]?.length;\n const ends = deflateCoordinatesArray(flatCoordinates, 0, coordinates, stride);\n return {\n type: 'Polygon',\n flatCoordinates,\n ends,\n layout: getLayoutForStride(stride),\n };\n}\n\n/**\n * @param {import(\"../geom/Geometry.js\").default} geometry Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {GeoJSONGeometry} GeoJSON geometry.\n */\nfunction writeGeometry(geometry, options) {\n geometry = transformGeometryWithOptions(geometry, true, options);\n\n const type = geometry.getType();\n\n /** @type {GeoJSONGeometry} */\n let geoJSON;\n switch (type) {\n case 'Point': {\n geoJSON = writePointGeometry(\n /** @type {import(\"../geom/Point.js\").default} */ (geometry),\n options,\n );\n break;\n }\n case 'LineString': {\n geoJSON = writeLineStringGeometry(\n /** @type {import(\"../geom/LineString.js\").default} */ (geometry),\n options,\n );\n break;\n }\n case 'Polygon': {\n geoJSON = writePolygonGeometry(\n /** @type {import(\"../geom/Polygon.js\").default} */ (geometry),\n options,\n );\n break;\n }\n case 'MultiPoint': {\n geoJSON = writeMultiPointGeometry(\n /** @type {import(\"../geom/MultiPoint.js\").default} */ (geometry),\n options,\n );\n break;\n }\n case 'MultiLineString': {\n geoJSON = writeMultiLineStringGeometry(\n /** @type {import(\"../geom/MultiLineString.js\").default} */ (geometry),\n options,\n );\n break;\n }\n case 'MultiPolygon': {\n geoJSON = writeMultiPolygonGeometry(\n /** @type {import(\"../geom/MultiPolygon.js\").default} */ (geometry),\n options,\n );\n break;\n }\n case 'GeometryCollection': {\n geoJSON = writeGeometryCollectionGeometry(\n /** @type {import(\"../geom/GeometryCollection.js\").default} */ (\n geometry\n ),\n options,\n );\n break;\n }\n case 'Circle': {\n geoJSON = {\n type: 'GeometryCollection',\n geometries: [],\n };\n break;\n }\n default: {\n throw new Error('Unsupported geometry type: ' + type);\n }\n }\n return geoJSON;\n}\n\n/**\n * @param {import(\"../geom/GeometryCollection.js\").default} geometry Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {GeoJSONGeometryCollection} GeoJSON geometry collection.\n */\nfunction writeGeometryCollectionGeometry(geometry, options) {\n options = Object.assign({}, options);\n delete options.featureProjection;\n const geometries = geometry.getGeometriesArray().map(function (geometry) {\n return writeGeometry(geometry, options);\n });\n return {\n type: 'GeometryCollection',\n geometries: geometries,\n };\n}\n\n/**\n * @param {import(\"../geom/LineString.js\").default} geometry Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {GeoJSONGeometry} GeoJSON geometry.\n */\nfunction writeLineStringGeometry(geometry, options) {\n return {\n type: 'LineString',\n coordinates: geometry.getCoordinates(),\n };\n}\n\n/**\n * @param {import(\"../geom/MultiLineString.js\").default} geometry Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {GeoJSONGeometry} GeoJSON geometry.\n */\nfunction writeMultiLineStringGeometry(geometry, options) {\n return {\n type: 'MultiLineString',\n coordinates: geometry.getCoordinates(),\n };\n}\n\n/**\n * @param {import(\"../geom/MultiPoint.js\").default} geometry Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {GeoJSONGeometry} GeoJSON geometry.\n */\nfunction writeMultiPointGeometry(geometry, options) {\n return {\n type: 'MultiPoint',\n coordinates: geometry.getCoordinates(),\n };\n}\n\n/**\n * @param {import(\"../geom/MultiPolygon.js\").default} geometry Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {GeoJSONGeometry} GeoJSON geometry.\n */\nfunction writeMultiPolygonGeometry(geometry, options) {\n let right;\n if (options) {\n right = options.rightHanded;\n }\n return {\n type: 'MultiPolygon',\n coordinates: geometry.getCoordinates(right),\n };\n}\n\n/**\n * @param {import(\"../geom/Point.js\").default} geometry Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {GeoJSONGeometry} GeoJSON geometry.\n */\nfunction writePointGeometry(geometry, options) {\n return {\n type: 'Point',\n coordinates: geometry.getCoordinates(),\n };\n}\n\n/**\n * @param {import(\"../geom/Polygon.js\").default} geometry Geometry.\n * @param {import(\"./Feature.js\").WriteOptions} [options] Write options.\n * @return {GeoJSONGeometry} GeoJSON geometry.\n */\nfunction writePolygonGeometry(geometry, options) {\n let right;\n if (options) {\n right = options.rightHanded;\n }\n return {\n type: 'Polygon',\n coordinates: geometry.getCoordinates(right),\n };\n}\n\nexport default GeoJSON;\n","/**\n * @module ol/functions\n */\n\nimport {equals as arrayEquals} from './array.js';\n\n/**\n * Always returns true.\n * @return {boolean} true.\n */\nexport function TRUE() {\n return true;\n}\n\n/**\n * Always returns false.\n * @return {boolean} false.\n */\nexport function FALSE() {\n return false;\n}\n\n/**\n * A reusable function, used e.g. as a default for callbacks.\n *\n * @return {void} Nothing.\n */\nexport function VOID() {}\n\n/**\n * Wrap a function in another function that remembers the last return. If the\n * returned function is called twice in a row with the same arguments and the same\n * this object, it will return the value from the first call in the second call.\n *\n * @param {function(...any): ReturnType} fn The function to memoize.\n * @return {function(...any): ReturnType} The memoized function.\n * @template ReturnType\n */\nexport function memoizeOne(fn) {\n /** @type {ReturnType} */\n let lastResult;\n\n /** @type {Array|undefined} */\n let lastArgs;\n\n let lastThis;\n\n /**\n * @this {*} Only need to know if `this` changed, don't care what type\n * @return {ReturnType} Memoized value\n */\n return function () {\n const nextArgs = Array.prototype.slice.call(arguments);\n if (!lastArgs || this !== lastThis || !arrayEquals(nextArgs, lastArgs)) {\n lastThis = this;\n lastArgs = nextArgs;\n lastResult = fn.apply(this, arguments);\n }\n return lastResult;\n };\n}\n\n/**\n * @template T\n * @param {function(): (T | Promise)} getter A function that returns a value or a promise for a value.\n * @return {Promise} A promise for the value.\n */\nexport function toPromise(getter) {\n function promiseGetter() {\n let value;\n try {\n value = getter();\n } catch (err) {\n return Promise.reject(err);\n }\n if (value instanceof Promise) {\n return value;\n }\n return Promise.resolve(value);\n }\n return promiseGetter();\n}\n","/**\n * @module ol/geom/Geometry\n */\nimport BaseObject from '../Object.js';\nimport {abstract} from '../util.js';\nimport {\n compose as composeTransform,\n create as createTransform,\n} from '../transform.js';\nimport {\n createEmpty,\n createOrUpdateEmpty,\n getHeight,\n returnOrUpdate,\n} from '../extent.js';\nimport {get as getProjection, getTransform} from '../proj.js';\nimport {memoizeOne} from '../functions.js';\nimport {transform2D} from './flat/transform.js';\n\n/**\n * @typedef {'XY' | 'XYZ' | 'XYM' | 'XYZM'} GeometryLayout\n * The coordinate layout for geometries, indicating whether a 3rd or 4th z ('Z')\n * or measure ('M') coordinate is available.\n */\n\n/**\n * @typedef {'Point' | 'LineString' | 'LinearRing' | 'Polygon' | 'MultiPoint' | 'MultiLineString' | 'MultiPolygon' | 'GeometryCollection' | 'Circle'} Type\n * The geometry type. One of `'Point'`, `'LineString'`, `'LinearRing'`,\n * `'Polygon'`, `'MultiPoint'`, `'MultiLineString'`, `'MultiPolygon'`,\n * `'GeometryCollection'`, or `'Circle'`.\n */\n\n/**\n * @type {import(\"../transform.js\").Transform}\n */\nconst tmpTransform = createTransform();\n\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * Base class for vector geometries.\n *\n * To get notified of changes to the geometry, register a listener for the\n * generic `change` event on your geometry instance.\n *\n * @abstract\n * @api\n */\nclass Geometry extends BaseObject {\n constructor() {\n super();\n\n /**\n * @private\n * @type {import(\"../extent.js\").Extent}\n */\n this.extent_ = createEmpty();\n\n /**\n * @private\n * @type {number}\n */\n this.extentRevision_ = -1;\n\n /**\n * @protected\n * @type {number}\n */\n this.simplifiedGeometryMaxMinSquaredTolerance = 0;\n\n /**\n * @protected\n * @type {number}\n */\n this.simplifiedGeometryRevision = 0;\n\n /**\n * Get a transformed and simplified version of the geometry.\n * @abstract\n * @param {number} revision The geometry revision.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {import(\"../proj.js\").TransformFunction} [transform] Optional transform function.\n * @return {Geometry} Simplified geometry.\n */\n this.simplifyTransformedInternal = memoizeOne(\n (revision, squaredTolerance, transform) => {\n if (!transform) {\n return this.getSimplifiedGeometry(squaredTolerance);\n }\n const clone = this.clone();\n clone.applyTransform(transform);\n return clone.getSimplifiedGeometry(squaredTolerance);\n },\n );\n }\n\n /**\n * Get a transformed and simplified version of the geometry.\n * @abstract\n * @param {number} squaredTolerance Squared tolerance.\n * @param {import(\"../proj.js\").TransformFunction} [transform] Optional transform function.\n * @return {Geometry} Simplified geometry.\n */\n simplifyTransformed(squaredTolerance, transform) {\n return this.simplifyTransformedInternal(\n this.getRevision(),\n squaredTolerance,\n transform,\n );\n }\n\n /**\n * Make a complete copy of the geometry.\n * @abstract\n * @return {!Geometry} Clone.\n */\n clone() {\n return abstract();\n }\n\n /**\n * @abstract\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n */\n closestPointXY(x, y, closestPoint, minSquaredDistance) {\n return abstract();\n }\n\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @return {boolean} Contains (x, y).\n */\n containsXY(x, y) {\n const coord = this.getClosestPoint([x, y]);\n return coord[0] === x && coord[1] === y;\n }\n\n /**\n * Return the closest point of the geometry to the passed point as\n * {@link module:ol/coordinate~Coordinate coordinate}.\n * @param {import(\"../coordinate.js\").Coordinate} point Point.\n * @param {import(\"../coordinate.js\").Coordinate} [closestPoint] Closest point.\n * @return {import(\"../coordinate.js\").Coordinate} Closest point.\n * @api\n */\n getClosestPoint(point, closestPoint) {\n closestPoint = closestPoint ? closestPoint : [NaN, NaN];\n this.closestPointXY(point[0], point[1], closestPoint, Infinity);\n return closestPoint;\n }\n\n /**\n * Returns true if this geometry includes the specified coordinate. If the\n * coordinate is on the boundary of the geometry, returns false.\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @return {boolean} Contains coordinate.\n * @api\n */\n intersectsCoordinate(coordinate) {\n return this.containsXY(coordinate[0], coordinate[1]);\n }\n\n /**\n * @abstract\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @protected\n * @return {import(\"../extent.js\").Extent} extent Extent.\n */\n computeExtent(extent) {\n return abstract();\n }\n\n /**\n * Get the extent of the geometry.\n * @param {import(\"../extent.js\").Extent} [extent] Extent.\n * @return {import(\"../extent.js\").Extent} extent Extent.\n * @api\n */\n getExtent(extent) {\n if (this.extentRevision_ != this.getRevision()) {\n const extent = this.computeExtent(this.extent_);\n if (isNaN(extent[0]) || isNaN(extent[1])) {\n createOrUpdateEmpty(extent);\n }\n this.extentRevision_ = this.getRevision();\n }\n return returnOrUpdate(this.extent_, extent);\n }\n\n /**\n * Rotate the geometry around a given coordinate. This modifies the geometry\n * coordinates in place.\n * @abstract\n * @param {number} angle Rotation angle in radians.\n * @param {import(\"../coordinate.js\").Coordinate} anchor The rotation center.\n * @api\n */\n rotate(angle, anchor) {\n abstract();\n }\n\n /**\n * Scale the geometry (with an optional origin). This modifies the geometry\n * coordinates in place.\n * @abstract\n * @param {number} sx The scaling factor in the x-direction.\n * @param {number} [sy] The scaling factor in the y-direction (defaults to sx).\n * @param {import(\"../coordinate.js\").Coordinate} [anchor] The scale origin (defaults to the center\n * of the geometry extent).\n * @api\n */\n scale(sx, sy, anchor) {\n abstract();\n }\n\n /**\n * Create a simplified version of this geometry. For linestrings, this uses\n * the [Douglas Peucker](https://en.wikipedia.org/wiki/Ramer-Douglas-Peucker_algorithm)\n * algorithm. For polygons, a quantization-based\n * simplification is used to preserve topology.\n * @param {number} tolerance The tolerance distance for simplification.\n * @return {Geometry} A new, simplified version of the original geometry.\n * @api\n */\n simplify(tolerance) {\n return this.getSimplifiedGeometry(tolerance * tolerance);\n }\n\n /**\n * Create a simplified version of this geometry using the Douglas Peucker\n * algorithm.\n * See https://en.wikipedia.org/wiki/Ramer-Douglas-Peucker_algorithm.\n * @abstract\n * @param {number} squaredTolerance Squared tolerance.\n * @return {Geometry} Simplified geometry.\n */\n getSimplifiedGeometry(squaredTolerance) {\n return abstract();\n }\n\n /**\n * Get the type of this geometry.\n * @abstract\n * @return {Type} Geometry type.\n */\n getType() {\n return abstract();\n }\n\n /**\n * Apply a transform function to the coordinates of the geometry.\n * The geometry is modified in place.\n * If you do not want the geometry modified in place, first `clone()` it and\n * then use this function on the clone.\n * @abstract\n * @param {import(\"../proj.js\").TransformFunction} transformFn Transform function.\n * Called with a flat array of geometry coordinates.\n */\n applyTransform(transformFn) {\n abstract();\n }\n\n /**\n * Test if the geometry and the passed extent intersect.\n * @abstract\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n */\n intersectsExtent(extent) {\n return abstract();\n }\n\n /**\n * Translate the geometry. This modifies the geometry coordinates in place. If\n * instead you want a new geometry, first `clone()` this geometry.\n * @abstract\n * @param {number} deltaX Delta X.\n * @param {number} deltaY Delta Y.\n * @api\n */\n translate(deltaX, deltaY) {\n abstract();\n }\n\n /**\n * Transform each coordinate of the geometry from one coordinate reference\n * system to another. The geometry is modified in place.\n * For example, a line will be transformed to a line and a circle to a circle.\n * If you do not want the geometry modified in place, first `clone()` it and\n * then use this function on the clone.\n *\n * @param {import(\"../proj.js\").ProjectionLike} source The current projection. Can be a\n * string identifier or a {@link module:ol/proj/Projection~Projection} object.\n * @param {import(\"../proj.js\").ProjectionLike} destination The desired projection. Can be a\n * string identifier or a {@link module:ol/proj/Projection~Projection} object.\n * @return {this} This geometry. Note that original geometry is\n * modified in place.\n * @api\n */\n transform(source, destination) {\n /** @type {import(\"../proj/Projection.js\").default} */\n const sourceProj = getProjection(source);\n const transformFn =\n sourceProj.getUnits() == 'tile-pixels'\n ? function (inCoordinates, outCoordinates, stride) {\n const pixelExtent = sourceProj.getExtent();\n const projectedExtent = sourceProj.getWorldExtent();\n const scale = getHeight(projectedExtent) / getHeight(pixelExtent);\n composeTransform(\n tmpTransform,\n projectedExtent[0],\n projectedExtent[3],\n scale,\n -scale,\n 0,\n 0,\n 0,\n );\n transform2D(\n inCoordinates,\n 0,\n inCoordinates.length,\n stride,\n tmpTransform,\n outCoordinates,\n );\n return getTransform(sourceProj, destination)(\n inCoordinates,\n outCoordinates,\n stride,\n );\n }\n : getTransform(sourceProj, destination);\n this.applyTransform(transformFn);\n return this;\n }\n}\n\nexport default Geometry;\n","/**\n * @module ol/geom/LineString\n */\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {assignClosestPoint, maxSquaredDelta} from './flat/closest.js';\nimport {closestSquaredDistanceXY} from '../extent.js';\nimport {deflateCoordinates} from './flat/deflate.js';\nimport {douglasPeucker} from './flat/simplify.js';\nimport {extend} from '../array.js';\nimport {forEach as forEachSegment} from './flat/segments.js';\nimport {inflateCoordinates} from './flat/inflate.js';\nimport {interpolatePoint, lineStringCoordinateAtM} from './flat/interpolate.js';\nimport {intersectsLineString} from './flat/intersectsextent.js';\nimport {lineStringLength} from './flat/length.js';\n\n/**\n * @classdesc\n * Linestring geometry.\n *\n * @api\n */\nclass LineString extends SimpleGeometry {\n /**\n * @param {Array|Array} coordinates Coordinates.\n * For internal use, flat coordinates in combination with `layout` are also accepted.\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n */\n constructor(coordinates, layout) {\n super();\n\n /**\n * @private\n * @type {import(\"../coordinate.js\").Coordinate|null}\n */\n this.flatMidpoint_ = null;\n\n /**\n * @private\n * @type {number}\n */\n this.flatMidpointRevision_ = -1;\n\n /**\n * @private\n * @type {number}\n */\n this.maxDelta_ = -1;\n\n /**\n * @private\n * @type {number}\n */\n this.maxDeltaRevision_ = -1;\n\n if (layout !== undefined && !Array.isArray(coordinates[0])) {\n this.setFlatCoordinates(\n layout,\n /** @type {Array} */ (coordinates),\n );\n } else {\n this.setCoordinates(\n /** @type {Array} */ (\n coordinates\n ),\n layout,\n );\n }\n }\n\n /**\n * Append the passed coordinate to the coordinates of the linestring.\n * @param {import(\"../coordinate.js\").Coordinate} coordinate Coordinate.\n * @api\n */\n appendCoordinate(coordinate) {\n extend(this.flatCoordinates, coordinate);\n this.changed();\n }\n\n /**\n * Make a complete copy of the geometry.\n * @return {!LineString} Clone.\n * @api\n * @override\n */\n clone() {\n const lineString = new LineString(\n this.flatCoordinates.slice(),\n this.layout,\n );\n lineString.applyProperties(this);\n return lineString;\n }\n\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n * @override\n */\n closestPointXY(x, y, closestPoint, minSquaredDistance) {\n if (minSquaredDistance < closestSquaredDistanceXY(this.getExtent(), x, y)) {\n return minSquaredDistance;\n }\n if (this.maxDeltaRevision_ != this.getRevision()) {\n this.maxDelta_ = Math.sqrt(\n maxSquaredDelta(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n 0,\n ),\n );\n this.maxDeltaRevision_ = this.getRevision();\n }\n return assignClosestPoint(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n this.maxDelta_,\n false,\n x,\n y,\n closestPoint,\n minSquaredDistance,\n );\n }\n\n /**\n * Iterate over each segment, calling the provided callback.\n * If the callback returns a truthy value the function returns that\n * value immediately. Otherwise the function returns `false`.\n *\n * @param {function(this: S, import(\"../coordinate.js\").Coordinate, import(\"../coordinate.js\").Coordinate): T} callback Function\n * called for each segment. The function will receive two arguments, the start and end coordinates of the segment.\n * @return {T|boolean} Value.\n * @template T,S\n * @api\n */\n forEachSegment(callback) {\n return forEachSegment(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n callback,\n );\n }\n\n /**\n * Returns the coordinate at `m` using linear interpolation, or `null` if no\n * such coordinate exists.\n *\n * `extrapolate` controls extrapolation beyond the range of Ms in the\n * MultiLineString. If `extrapolate` is `true` then Ms less than the first\n * M will return the first coordinate and Ms greater than the last M will\n * return the last coordinate.\n *\n * @param {number} m M.\n * @param {boolean} [extrapolate] Extrapolate. Default is `false`.\n * @return {import(\"../coordinate.js\").Coordinate|null} Coordinate.\n * @api\n */\n getCoordinateAtM(m, extrapolate) {\n if (this.layout != 'XYM' && this.layout != 'XYZM') {\n return null;\n }\n extrapolate = extrapolate !== undefined ? extrapolate : false;\n return lineStringCoordinateAtM(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n m,\n extrapolate,\n );\n }\n\n /**\n * Return the coordinates of the linestring.\n * @return {Array} Coordinates.\n * @api\n * @override\n */\n getCoordinates() {\n return inflateCoordinates(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n );\n }\n\n /**\n * Return the coordinate at the provided fraction along the linestring.\n * The `fraction` is a number between 0 and 1, where 0 is the start of the\n * linestring and 1 is the end.\n * @param {number} fraction Fraction.\n * @param {import(\"../coordinate.js\").Coordinate} [dest] Optional coordinate whose values will\n * be modified. If not provided, a new coordinate will be returned.\n * @return {import(\"../coordinate.js\").Coordinate} Coordinate of the interpolated point.\n * @api\n */\n getCoordinateAt(fraction, dest) {\n return interpolatePoint(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n fraction,\n dest,\n this.stride,\n );\n }\n\n /**\n * Return the length of the linestring on projected plane.\n * @return {number} Length (on projected plane).\n * @api\n */\n getLength() {\n return lineStringLength(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n );\n }\n\n /**\n * @return {Array} Flat midpoint.\n */\n getFlatMidpoint() {\n if (this.flatMidpointRevision_ != this.getRevision()) {\n this.flatMidpoint_ = this.getCoordinateAt(\n 0.5,\n this.flatMidpoint_ ?? undefined,\n );\n this.flatMidpointRevision_ = this.getRevision();\n }\n return /** @type {Array} */ (this.flatMidpoint_);\n }\n\n /**\n * @param {number} squaredTolerance Squared tolerance.\n * @return {LineString} Simplified LineString.\n * @protected\n * @override\n */\n getSimplifiedGeometryInternal(squaredTolerance) {\n /** @type {Array} */\n const simplifiedFlatCoordinates = [];\n simplifiedFlatCoordinates.length = douglasPeucker(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n squaredTolerance,\n simplifiedFlatCoordinates,\n 0,\n );\n return new LineString(simplifiedFlatCoordinates, 'XY');\n }\n\n /**\n * Get the type of this geometry.\n * @return {import(\"./Geometry.js\").Type} Geometry type.\n * @api\n * @override\n */\n getType() {\n return 'LineString';\n }\n\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n * @override\n */\n intersectsExtent(extent) {\n return intersectsLineString(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n extent,\n );\n }\n\n /**\n * Set the coordinates of the linestring.\n * @param {!Array} coordinates Coordinates.\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n * @api\n * @override\n */\n setCoordinates(coordinates, layout) {\n this.setLayout(layout, coordinates, 1);\n if (!this.flatCoordinates) {\n this.flatCoordinates = [];\n }\n this.flatCoordinates.length = deflateCoordinates(\n this.flatCoordinates,\n 0,\n coordinates,\n this.stride,\n );\n this.changed();\n }\n}\n\nexport default LineString;\n","/**\n * @module ol/geom/MultiLineString\n */\nimport LineString from './LineString.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {arrayMaxSquaredDelta, assignClosestArrayPoint} from './flat/closest.js';\nimport {closestSquaredDistanceXY} from '../extent.js';\nimport {deflateCoordinatesArray} from './flat/deflate.js';\nimport {douglasPeuckerArray} from './flat/simplify.js';\nimport {extend} from '../array.js';\nimport {inflateCoordinatesArray} from './flat/inflate.js';\nimport {\n interpolatePoint,\n lineStringsCoordinateAtM,\n} from './flat/interpolate.js';\nimport {intersectsLineStringArray} from './flat/intersectsextent.js';\n\n/**\n * @classdesc\n * Multi-linestring geometry.\n *\n * @api\n */\nclass MultiLineString extends SimpleGeometry {\n /**\n * @param {Array|LineString>|Array} coordinates\n * Coordinates or LineString geometries. (For internal use, flat coordinates in\n * combination with `layout` and `ends` are also accepted.)\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n * @param {Array} [ends] Flat coordinate ends for internal use.\n */\n constructor(coordinates, layout, ends) {\n super();\n\n /**\n * @type {Array}\n * @private\n */\n this.ends_ = [];\n\n /**\n * @private\n * @type {number}\n */\n this.maxDelta_ = -1;\n\n /**\n * @private\n * @type {number}\n */\n this.maxDeltaRevision_ = -1;\n\n if (Array.isArray(coordinates[0])) {\n this.setCoordinates(\n /** @type {Array>} */ (\n coordinates\n ),\n layout,\n );\n } else if (layout !== undefined && ends) {\n this.setFlatCoordinates(\n layout,\n /** @type {Array} */ (coordinates),\n );\n this.ends_ = ends;\n } else {\n const lineStrings = /** @type {Array} */ (coordinates);\n /** @type {Array} */\n const flatCoordinates = [];\n const ends = [];\n for (let i = 0, ii = lineStrings.length; i < ii; ++i) {\n const lineString = lineStrings[i];\n extend(flatCoordinates, lineString.getFlatCoordinates());\n ends.push(flatCoordinates.length);\n }\n const layout =\n lineStrings.length === 0\n ? this.getLayout()\n : lineStrings[0].getLayout();\n this.setFlatCoordinates(layout, flatCoordinates);\n this.ends_ = ends;\n }\n }\n\n /**\n * Append the passed linestring to the multilinestring.\n * @param {LineString} lineString LineString.\n * @api\n */\n appendLineString(lineString) {\n extend(this.flatCoordinates, lineString.getFlatCoordinates().slice());\n this.ends_.push(this.flatCoordinates.length);\n this.changed();\n }\n\n /**\n * Make a complete copy of the geometry.\n * @return {!MultiLineString} Clone.\n * @api\n * @override\n */\n clone() {\n const multiLineString = new MultiLineString(\n this.flatCoordinates.slice(),\n this.layout,\n this.ends_.slice(),\n );\n multiLineString.applyProperties(this);\n return multiLineString;\n }\n\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n * @override\n */\n closestPointXY(x, y, closestPoint, minSquaredDistance) {\n if (minSquaredDistance < closestSquaredDistanceXY(this.getExtent(), x, y)) {\n return minSquaredDistance;\n }\n if (this.maxDeltaRevision_ != this.getRevision()) {\n this.maxDelta_ = Math.sqrt(\n arrayMaxSquaredDelta(\n this.flatCoordinates,\n 0,\n this.ends_,\n this.stride,\n 0,\n ),\n );\n this.maxDeltaRevision_ = this.getRevision();\n }\n return assignClosestArrayPoint(\n this.flatCoordinates,\n 0,\n this.ends_,\n this.stride,\n this.maxDelta_,\n false,\n x,\n y,\n closestPoint,\n minSquaredDistance,\n );\n }\n\n /**\n * Returns the coordinate at `m` using linear interpolation, or `null` if no\n * such coordinate exists.\n *\n * `extrapolate` controls extrapolation beyond the range of Ms in the\n * MultiLineString. If `extrapolate` is `true` then Ms less than the first\n * M will return the first coordinate and Ms greater than the last M will\n * return the last coordinate.\n *\n * `interpolate` controls interpolation between consecutive LineStrings\n * within the MultiLineString. If `interpolate` is `true` the coordinates\n * will be linearly interpolated between the last coordinate of one LineString\n * and the first coordinate of the next LineString. If `interpolate` is\n * `false` then the function will return `null` for Ms falling between\n * LineStrings.\n *\n * @param {number} m M.\n * @param {boolean} [extrapolate] Extrapolate. Default is `false`.\n * @param {boolean} [interpolate] Interpolate. Default is `false`.\n * @return {import(\"../coordinate.js\").Coordinate|null} Coordinate.\n * @api\n */\n getCoordinateAtM(m, extrapolate, interpolate) {\n if (\n (this.layout != 'XYM' && this.layout != 'XYZM') ||\n this.flatCoordinates.length === 0\n ) {\n return null;\n }\n extrapolate = extrapolate !== undefined ? extrapolate : false;\n interpolate = interpolate !== undefined ? interpolate : false;\n return lineStringsCoordinateAtM(\n this.flatCoordinates,\n 0,\n this.ends_,\n this.stride,\n m,\n extrapolate,\n interpolate,\n );\n }\n\n /**\n * Return the coordinates of the multilinestring.\n * @return {Array>} Coordinates.\n * @api\n * @override\n */\n getCoordinates() {\n return inflateCoordinatesArray(\n this.flatCoordinates,\n 0,\n this.ends_,\n this.stride,\n );\n }\n\n /**\n * @return {Array} Ends.\n */\n getEnds() {\n return this.ends_;\n }\n\n /**\n * Return the linestring at the specified index.\n * @param {number} index Index.\n * @return {LineString} LineString.\n * @api\n */\n getLineString(index) {\n if (index < 0 || this.ends_.length <= index) {\n return null;\n }\n return new LineString(\n this.flatCoordinates.slice(\n index === 0 ? 0 : this.ends_[index - 1],\n this.ends_[index],\n ),\n this.layout,\n );\n }\n\n /**\n * Return the linestrings of this multilinestring.\n * @return {Array} LineStrings.\n * @api\n */\n getLineStrings() {\n const flatCoordinates = this.flatCoordinates;\n const ends = this.ends_;\n const layout = this.layout;\n /** @type {Array} */\n const lineStrings = [];\n let offset = 0;\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n const end = ends[i];\n const lineString = new LineString(\n flatCoordinates.slice(offset, end),\n layout,\n );\n lineStrings.push(lineString);\n offset = end;\n }\n return lineStrings;\n }\n\n /**\n * @return {Array} Flat midpoints.\n */\n getFlatMidpoints() {\n /** @type {Array} */\n const midpoints = [];\n const flatCoordinates = this.flatCoordinates;\n let offset = 0;\n const ends = this.ends_;\n const stride = this.stride;\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n const end = ends[i];\n const midpoint = interpolatePoint(\n flatCoordinates,\n offset,\n end,\n stride,\n 0.5,\n );\n extend(midpoints, midpoint);\n offset = end;\n }\n return midpoints;\n }\n\n /**\n * @param {number} squaredTolerance Squared tolerance.\n * @return {MultiLineString} Simplified MultiLineString.\n * @protected\n * @override\n */\n getSimplifiedGeometryInternal(squaredTolerance) {\n /** @type {Array} */\n const simplifiedFlatCoordinates = [];\n /** @type {Array} */\n const simplifiedEnds = [];\n simplifiedFlatCoordinates.length = douglasPeuckerArray(\n this.flatCoordinates,\n 0,\n this.ends_,\n this.stride,\n squaredTolerance,\n simplifiedFlatCoordinates,\n 0,\n simplifiedEnds,\n );\n return new MultiLineString(simplifiedFlatCoordinates, 'XY', simplifiedEnds);\n }\n\n /**\n * Get the type of this geometry.\n * @return {import(\"./Geometry.js\").Type} Geometry type.\n * @api\n * @override\n */\n getType() {\n return 'MultiLineString';\n }\n\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n * @override\n */\n intersectsExtent(extent) {\n return intersectsLineStringArray(\n this.flatCoordinates,\n 0,\n this.ends_,\n this.stride,\n extent,\n );\n }\n\n /**\n * Set the coordinates of the multilinestring.\n * @param {!Array>} coordinates Coordinates.\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n * @api\n * @override\n */\n setCoordinates(coordinates, layout) {\n this.setLayout(layout, coordinates, 2);\n if (!this.flatCoordinates) {\n this.flatCoordinates = [];\n }\n const ends = deflateCoordinatesArray(\n this.flatCoordinates,\n 0,\n coordinates,\n this.stride,\n this.ends_,\n );\n this.flatCoordinates.length = ends.length === 0 ? 0 : ends[ends.length - 1];\n this.changed();\n }\n}\n\nexport default MultiLineString;\n","/**\n * @module ol/geom/MultiPoint\n */\nimport Point from './Point.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {closestSquaredDistanceXY, containsXY} from '../extent.js';\nimport {deflateCoordinates} from './flat/deflate.js';\nimport {extend} from '../array.js';\nimport {inflateCoordinates} from './flat/inflate.js';\nimport {squaredDistance as squaredDx} from '../math.js';\n\n/**\n * @classdesc\n * Multi-point geometry.\n *\n * @api\n */\nclass MultiPoint extends SimpleGeometry {\n /**\n * @param {Array|Array} coordinates Coordinates.\n * For internal use, flat coordinates in combination with `layout` are also accepted.\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n */\n constructor(coordinates, layout) {\n super();\n if (layout && !Array.isArray(coordinates[0])) {\n this.setFlatCoordinates(\n layout,\n /** @type {Array} */ (coordinates),\n );\n } else {\n this.setCoordinates(\n /** @type {Array} */ (\n coordinates\n ),\n layout,\n );\n }\n }\n\n /**\n * Append the passed point to this multipoint.\n * @param {Point} point Point.\n * @api\n */\n appendPoint(point) {\n extend(this.flatCoordinates, point.getFlatCoordinates());\n this.changed();\n }\n\n /**\n * Make a complete copy of the geometry.\n * @return {!MultiPoint} Clone.\n * @api\n * @override\n */\n clone() {\n const multiPoint = new MultiPoint(\n this.flatCoordinates.slice(),\n this.layout,\n );\n multiPoint.applyProperties(this);\n return multiPoint;\n }\n\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n * @override\n */\n closestPointXY(x, y, closestPoint, minSquaredDistance) {\n if (minSquaredDistance < closestSquaredDistanceXY(this.getExtent(), x, y)) {\n return minSquaredDistance;\n }\n const flatCoordinates = this.flatCoordinates;\n const stride = this.stride;\n for (let i = 0, ii = flatCoordinates.length; i < ii; i += stride) {\n const squaredDistance = squaredDx(\n x,\n y,\n flatCoordinates[i],\n flatCoordinates[i + 1],\n );\n if (squaredDistance < minSquaredDistance) {\n minSquaredDistance = squaredDistance;\n for (let j = 0; j < stride; ++j) {\n closestPoint[j] = flatCoordinates[i + j];\n }\n closestPoint.length = stride;\n }\n }\n return minSquaredDistance;\n }\n\n /**\n * Return the coordinates of the multipoint.\n * @return {Array} Coordinates.\n * @api\n * @override\n */\n getCoordinates() {\n return inflateCoordinates(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n );\n }\n\n /**\n * Return the point at the specified index.\n * @param {number} index Index.\n * @return {Point} Point.\n * @api\n */\n getPoint(index) {\n const n = this.flatCoordinates.length / this.stride;\n if (index < 0 || n <= index) {\n return null;\n }\n return new Point(\n this.flatCoordinates.slice(\n index * this.stride,\n (index + 1) * this.stride,\n ),\n this.layout,\n );\n }\n\n /**\n * Return the points of this multipoint.\n * @return {Array} Points.\n * @api\n */\n getPoints() {\n const flatCoordinates = this.flatCoordinates;\n const layout = this.layout;\n const stride = this.stride;\n /** @type {Array} */\n const points = [];\n for (let i = 0, ii = flatCoordinates.length; i < ii; i += stride) {\n const point = new Point(flatCoordinates.slice(i, i + stride), layout);\n points.push(point);\n }\n return points;\n }\n\n /**\n * Get the type of this geometry.\n * @return {import(\"./Geometry.js\").Type} Geometry type.\n * @api\n * @override\n */\n getType() {\n return 'MultiPoint';\n }\n\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n * @override\n */\n intersectsExtent(extent) {\n const flatCoordinates = this.flatCoordinates;\n const stride = this.stride;\n for (let i = 0, ii = flatCoordinates.length; i < ii; i += stride) {\n const x = flatCoordinates[i];\n const y = flatCoordinates[i + 1];\n if (containsXY(extent, x, y)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Set the coordinates of the multipoint.\n * @param {!Array} coordinates Coordinates.\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n * @api\n * @override\n */\n setCoordinates(coordinates, layout) {\n this.setLayout(layout, coordinates, 1);\n if (!this.flatCoordinates) {\n this.flatCoordinates = [];\n }\n this.flatCoordinates.length = deflateCoordinates(\n this.flatCoordinates,\n 0,\n coordinates,\n this.stride,\n );\n this.changed();\n }\n}\n\nexport default MultiPoint;\n","/**\n * @module ol/geom/MultiPolygon\n */\nimport MultiPoint from './MultiPoint.js';\nimport Polygon from './Polygon.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {\n assignClosestMultiArrayPoint,\n multiArrayMaxSquaredDelta,\n} from './flat/closest.js';\nimport {closestSquaredDistanceXY} from '../extent.js';\nimport {deflateMultiCoordinatesArray} from './flat/deflate.js';\nimport {extend} from '../array.js';\nimport {getInteriorPointsOfMultiArray} from './flat/interiorpoint.js';\nimport {inflateMultiCoordinatesArray} from './flat/inflate.js';\nimport {intersectsLinearRingMultiArray} from './flat/intersectsextent.js';\nimport {\n linearRingssAreOriented,\n orientLinearRingsArray,\n} from './flat/orient.js';\nimport {linearRingss as linearRingssArea} from './flat/area.js';\nimport {linearRingss as linearRingssCenter} from './flat/center.js';\nimport {linearRingssContainsXY} from './flat/contains.js';\nimport {quantizeMultiArray} from './flat/simplify.js';\n\n/**\n * @classdesc\n * Multi-polygon geometry.\n *\n * @api\n */\nclass MultiPolygon extends SimpleGeometry {\n /**\n * @param {Array>|Polygon>|Array} coordinates Coordinates.\n * For internal use, flat coordinates in combination with `layout` and `endss` are also accepted.\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n * @param {Array>} [endss] Array of ends for internal use with flat coordinates.\n */\n constructor(coordinates, layout, endss) {\n super();\n\n /**\n * @type {Array>}\n * @private\n */\n this.endss_ = [];\n\n /**\n * @private\n * @type {number}\n */\n this.flatInteriorPointsRevision_ = -1;\n\n /**\n * @private\n * @type {Array|null}\n */\n this.flatInteriorPoints_ = null;\n\n /**\n * @private\n * @type {number}\n */\n this.maxDelta_ = -1;\n\n /**\n * @private\n * @type {number}\n */\n this.maxDeltaRevision_ = -1;\n\n /**\n * @private\n * @type {number}\n */\n this.orientedRevision_ = -1;\n\n /**\n * @private\n * @type {Array|null}\n */\n this.orientedFlatCoordinates_ = null;\n\n if (!endss && !Array.isArray(coordinates[0])) {\n const polygons = /** @type {Array} */ (coordinates);\n /** @type {Array} */\n const flatCoordinates = [];\n const thisEndss = [];\n for (let i = 0, ii = polygons.length; i < ii; ++i) {\n const polygon = polygons[i];\n const offset = flatCoordinates.length;\n const ends = polygon.getEnds();\n for (let j = 0, jj = ends.length; j < jj; ++j) {\n ends[j] += offset;\n }\n extend(flatCoordinates, polygon.getFlatCoordinates());\n thisEndss.push(ends);\n }\n layout =\n polygons.length === 0 ? this.getLayout() : polygons[0].getLayout();\n coordinates = flatCoordinates;\n endss = thisEndss;\n }\n if (layout !== undefined && endss) {\n this.setFlatCoordinates(\n layout,\n /** @type {Array} */ (coordinates),\n );\n this.endss_ = endss;\n } else {\n this.setCoordinates(\n /** @type {Array>>} */ (\n coordinates\n ),\n layout,\n );\n }\n }\n\n /**\n * Append the passed polygon to this multipolygon.\n * @param {Polygon} polygon Polygon.\n * @api\n */\n appendPolygon(polygon) {\n /** @type {Array} */\n let ends;\n if (!this.flatCoordinates) {\n this.flatCoordinates = polygon.getFlatCoordinates().slice();\n ends = polygon.getEnds().slice();\n this.endss_.push();\n } else {\n const offset = this.flatCoordinates.length;\n extend(this.flatCoordinates, polygon.getFlatCoordinates());\n ends = polygon.getEnds().slice();\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n ends[i] += offset;\n }\n }\n this.endss_.push(ends);\n this.changed();\n }\n\n /**\n * Make a complete copy of the geometry.\n * @return {!MultiPolygon} Clone.\n * @api\n * @override\n */\n clone() {\n const len = this.endss_.length;\n const newEndss = new Array(len);\n for (let i = 0; i < len; ++i) {\n newEndss[i] = this.endss_[i].slice();\n }\n\n const multiPolygon = new MultiPolygon(\n this.flatCoordinates.slice(),\n this.layout,\n newEndss,\n );\n multiPolygon.applyProperties(this);\n\n return multiPolygon;\n }\n\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n * @override\n */\n closestPointXY(x, y, closestPoint, minSquaredDistance) {\n if (minSquaredDistance < closestSquaredDistanceXY(this.getExtent(), x, y)) {\n return minSquaredDistance;\n }\n if (this.maxDeltaRevision_ != this.getRevision()) {\n this.maxDelta_ = Math.sqrt(\n multiArrayMaxSquaredDelta(\n this.flatCoordinates,\n 0,\n this.endss_,\n this.stride,\n 0,\n ),\n );\n this.maxDeltaRevision_ = this.getRevision();\n }\n return assignClosestMultiArrayPoint(\n this.getOrientedFlatCoordinates(),\n 0,\n this.endss_,\n this.stride,\n this.maxDelta_,\n true,\n x,\n y,\n closestPoint,\n minSquaredDistance,\n );\n }\n\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @return {boolean} Contains (x, y).\n * @override\n */\n containsXY(x, y) {\n return linearRingssContainsXY(\n this.getOrientedFlatCoordinates(),\n 0,\n this.endss_,\n this.stride,\n x,\n y,\n );\n }\n\n /**\n * Return the area of the multipolygon on projected plane.\n * @return {number} Area (on projected plane).\n * @api\n */\n getArea() {\n return linearRingssArea(\n this.getOrientedFlatCoordinates(),\n 0,\n this.endss_,\n this.stride,\n );\n }\n\n /**\n * Get the coordinate array for this geometry. This array has the structure\n * of a GeoJSON coordinate array for multi-polygons.\n *\n * @param {boolean} [right] Orient coordinates according to the right-hand\n * rule (counter-clockwise for exterior and clockwise for interior rings).\n * If `false`, coordinates will be oriented according to the left-hand rule\n * (clockwise for exterior and counter-clockwise for interior rings).\n * By default, coordinate orientation will depend on how the geometry was\n * constructed.\n * @return {Array>>} Coordinates.\n * @api\n * @override\n */\n getCoordinates(right) {\n let flatCoordinates;\n if (right !== undefined) {\n flatCoordinates = this.getOrientedFlatCoordinates().slice();\n orientLinearRingsArray(\n flatCoordinates,\n 0,\n this.endss_,\n this.stride,\n right,\n );\n } else {\n flatCoordinates = this.flatCoordinates;\n }\n\n return inflateMultiCoordinatesArray(\n flatCoordinates,\n 0,\n this.endss_,\n this.stride,\n );\n }\n\n /**\n * @return {Array>} Endss.\n */\n getEndss() {\n return this.endss_;\n }\n\n /**\n * @return {Array} Flat interior points.\n */\n getFlatInteriorPoints() {\n if (this.flatInteriorPointsRevision_ != this.getRevision()) {\n const flatCenters = linearRingssCenter(\n this.flatCoordinates,\n 0,\n this.endss_,\n this.stride,\n );\n this.flatInteriorPoints_ = getInteriorPointsOfMultiArray(\n this.getOrientedFlatCoordinates(),\n 0,\n this.endss_,\n this.stride,\n flatCenters,\n );\n this.flatInteriorPointsRevision_ = this.getRevision();\n }\n return /** @type {Array} */ (this.flatInteriorPoints_);\n }\n\n /**\n * Return the interior points as {@link module:ol/geom/MultiPoint~MultiPoint multipoint}.\n * @return {MultiPoint} Interior points as XYM coordinates, where M is\n * the length of the horizontal intersection that the point belongs to.\n * @api\n */\n getInteriorPoints() {\n return new MultiPoint(this.getFlatInteriorPoints().slice(), 'XYM');\n }\n\n /**\n * @return {Array} Oriented flat coordinates.\n */\n getOrientedFlatCoordinates() {\n if (this.orientedRevision_ != this.getRevision()) {\n const flatCoordinates = this.flatCoordinates;\n if (\n linearRingssAreOriented(flatCoordinates, 0, this.endss_, this.stride)\n ) {\n this.orientedFlatCoordinates_ = flatCoordinates;\n } else {\n this.orientedFlatCoordinates_ = flatCoordinates.slice();\n this.orientedFlatCoordinates_.length = orientLinearRingsArray(\n this.orientedFlatCoordinates_,\n 0,\n this.endss_,\n this.stride,\n );\n }\n this.orientedRevision_ = this.getRevision();\n }\n return /** @type {Array} */ (this.orientedFlatCoordinates_);\n }\n\n /**\n * @param {number} squaredTolerance Squared tolerance.\n * @return {MultiPolygon} Simplified MultiPolygon.\n * @protected\n * @override\n */\n getSimplifiedGeometryInternal(squaredTolerance) {\n /** @type {Array} */\n const simplifiedFlatCoordinates = [];\n /** @type {Array>} */\n const simplifiedEndss = [];\n simplifiedFlatCoordinates.length = quantizeMultiArray(\n this.flatCoordinates,\n 0,\n this.endss_,\n this.stride,\n Math.sqrt(squaredTolerance),\n simplifiedFlatCoordinates,\n 0,\n simplifiedEndss,\n );\n return new MultiPolygon(simplifiedFlatCoordinates, 'XY', simplifiedEndss);\n }\n\n /**\n * Return the polygon at the specified index.\n * @param {number} index Index.\n * @return {Polygon} Polygon.\n * @api\n */\n getPolygon(index) {\n if (index < 0 || this.endss_.length <= index) {\n return null;\n }\n let offset;\n if (index === 0) {\n offset = 0;\n } else {\n const prevEnds = this.endss_[index - 1];\n offset = prevEnds[prevEnds.length - 1];\n }\n const ends = this.endss_[index].slice();\n const end = ends[ends.length - 1];\n if (offset !== 0) {\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n ends[i] -= offset;\n }\n }\n return new Polygon(\n this.flatCoordinates.slice(offset, end),\n this.layout,\n ends,\n );\n }\n\n /**\n * Return the polygons of this multipolygon.\n * @return {Array} Polygons.\n * @api\n */\n getPolygons() {\n const layout = this.layout;\n const flatCoordinates = this.flatCoordinates;\n const endss = this.endss_;\n const polygons = [];\n let offset = 0;\n for (let i = 0, ii = endss.length; i < ii; ++i) {\n const ends = endss[i].slice();\n const end = ends[ends.length - 1];\n if (offset !== 0) {\n for (let j = 0, jj = ends.length; j < jj; ++j) {\n ends[j] -= offset;\n }\n }\n const polygon = new Polygon(\n flatCoordinates.slice(offset, end),\n layout,\n ends,\n );\n polygons.push(polygon);\n offset = end;\n }\n return polygons;\n }\n\n /**\n * Get the type of this geometry.\n * @return {import(\"./Geometry.js\").Type} Geometry type.\n * @api\n * @override\n */\n getType() {\n return 'MultiPolygon';\n }\n\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n * @override\n */\n intersectsExtent(extent) {\n return intersectsLinearRingMultiArray(\n this.getOrientedFlatCoordinates(),\n 0,\n this.endss_,\n this.stride,\n extent,\n );\n }\n\n /**\n * Set the coordinates of the multipolygon.\n * @param {!Array>>} coordinates Coordinates.\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n * @api\n * @override\n */\n setCoordinates(coordinates, layout) {\n this.setLayout(layout, coordinates, 3);\n if (!this.flatCoordinates) {\n this.flatCoordinates = [];\n }\n const endss = deflateMultiCoordinatesArray(\n this.flatCoordinates,\n 0,\n coordinates,\n this.stride,\n this.endss_,\n );\n if (endss.length === 0) {\n this.flatCoordinates.length = 0;\n } else {\n const lastEnds = endss[endss.length - 1];\n this.flatCoordinates.length =\n lastEnds.length === 0 ? 0 : lastEnds[lastEnds.length - 1];\n }\n this.changed();\n }\n}\n\nexport default MultiPolygon;\n","/**\n * @module ol/geom/Point\n */\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {containsXY, createOrUpdateFromCoordinate} from '../extent.js';\nimport {deflateCoordinate} from './flat/deflate.js';\nimport {squaredDistance as squaredDx} from '../math.js';\n\n/**\n * @classdesc\n * Point geometry.\n *\n * @api\n */\nclass Point extends SimpleGeometry {\n /**\n * @param {import(\"../coordinate.js\").Coordinate} coordinates Coordinates.\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n */\n constructor(coordinates, layout) {\n super();\n this.setCoordinates(coordinates, layout);\n }\n\n /**\n * Make a complete copy of the geometry.\n * @return {!Point} Clone.\n * @api\n * @override\n */\n clone() {\n const point = new Point(this.flatCoordinates.slice(), this.layout);\n point.applyProperties(this);\n return point;\n }\n\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n * @override\n */\n closestPointXY(x, y, closestPoint, minSquaredDistance) {\n const flatCoordinates = this.flatCoordinates;\n const squaredDistance = squaredDx(\n x,\n y,\n flatCoordinates[0],\n flatCoordinates[1],\n );\n if (squaredDistance < minSquaredDistance) {\n const stride = this.stride;\n for (let i = 0; i < stride; ++i) {\n closestPoint[i] = flatCoordinates[i];\n }\n closestPoint.length = stride;\n return squaredDistance;\n }\n return minSquaredDistance;\n }\n\n /**\n * Return the coordinate of the point.\n * @return {import(\"../coordinate.js\").Coordinate} Coordinates.\n * @api\n * @override\n */\n getCoordinates() {\n return this.flatCoordinates.slice();\n }\n\n /**\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @protected\n * @return {import(\"../extent.js\").Extent} extent Extent.\n * @override\n */\n computeExtent(extent) {\n return createOrUpdateFromCoordinate(this.flatCoordinates, extent);\n }\n\n /**\n * Get the type of this geometry.\n * @return {import(\"./Geometry.js\").Type} Geometry type.\n * @api\n * @override\n */\n getType() {\n return 'Point';\n }\n\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n * @override\n */\n intersectsExtent(extent) {\n return containsXY(extent, this.flatCoordinates[0], this.flatCoordinates[1]);\n }\n\n /**\n * @param {!Array<*>} coordinates Coordinates.\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n * @api\n * @override\n */\n setCoordinates(coordinates, layout) {\n this.setLayout(layout, coordinates, 0);\n if (!this.flatCoordinates) {\n this.flatCoordinates = [];\n }\n this.flatCoordinates.length = deflateCoordinate(\n this.flatCoordinates,\n 0,\n coordinates,\n this.stride,\n );\n this.changed();\n }\n}\n\nexport default Point;\n","/**\n * @module ol/geom/LinearRing\n */\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {assignClosestPoint, maxSquaredDelta} from './flat/closest.js';\nimport {closestSquaredDistanceXY} from '../extent.js';\nimport {deflateCoordinates} from './flat/deflate.js';\nimport {douglasPeucker} from './flat/simplify.js';\nimport {inflateCoordinates} from './flat/inflate.js';\nimport {linearRing as linearRingArea} from './flat/area.js';\n\n/**\n * @classdesc\n * Linear ring geometry. Only used as part of polygon; cannot be rendered\n * on its own.\n *\n * @api\n */\nclass LinearRing extends SimpleGeometry {\n /**\n * @param {Array|Array} coordinates Coordinates.\n * For internal use, flat coordinates in combination with `layout` are also accepted.\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n */\n constructor(coordinates, layout) {\n super();\n\n /**\n * @private\n * @type {number}\n */\n this.maxDelta_ = -1;\n\n /**\n * @private\n * @type {number}\n */\n this.maxDeltaRevision_ = -1;\n\n if (layout !== undefined && !Array.isArray(coordinates[0])) {\n this.setFlatCoordinates(\n layout,\n /** @type {Array} */ (coordinates),\n );\n } else {\n this.setCoordinates(\n /** @type {Array} */ (\n coordinates\n ),\n layout,\n );\n }\n }\n\n /**\n * Make a complete copy of the geometry.\n * @return {!LinearRing} Clone.\n * @api\n * @override\n */\n clone() {\n return new LinearRing(this.flatCoordinates.slice(), this.layout);\n }\n\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n * @override\n */\n closestPointXY(x, y, closestPoint, minSquaredDistance) {\n if (minSquaredDistance < closestSquaredDistanceXY(this.getExtent(), x, y)) {\n return minSquaredDistance;\n }\n if (this.maxDeltaRevision_ != this.getRevision()) {\n this.maxDelta_ = Math.sqrt(\n maxSquaredDelta(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n 0,\n ),\n );\n this.maxDeltaRevision_ = this.getRevision();\n }\n return assignClosestPoint(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n this.maxDelta_,\n true,\n x,\n y,\n closestPoint,\n minSquaredDistance,\n );\n }\n\n /**\n * Return the area of the linear ring on projected plane.\n * @return {number} Area (on projected plane).\n * @api\n */\n getArea() {\n return linearRingArea(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n );\n }\n\n /**\n * Return the coordinates of the linear ring.\n * @return {Array} Coordinates.\n * @api\n * @override\n */\n getCoordinates() {\n return inflateCoordinates(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n );\n }\n\n /**\n * @param {number} squaredTolerance Squared tolerance.\n * @return {LinearRing} Simplified LinearRing.\n * @protected\n * @override\n */\n getSimplifiedGeometryInternal(squaredTolerance) {\n /** @type {Array} */\n const simplifiedFlatCoordinates = [];\n simplifiedFlatCoordinates.length = douglasPeucker(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n squaredTolerance,\n simplifiedFlatCoordinates,\n 0,\n );\n return new LinearRing(simplifiedFlatCoordinates, 'XY');\n }\n\n /**\n * Get the type of this geometry.\n * @return {import(\"./Geometry.js\").Type} Geometry type.\n * @api\n * @override\n */\n getType() {\n return 'LinearRing';\n }\n\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n * @override\n */\n intersectsExtent(extent) {\n return false;\n }\n\n /**\n * Set the coordinates of the linear ring.\n * @param {!Array} coordinates Coordinates.\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n * @api\n * @override\n */\n setCoordinates(coordinates, layout) {\n this.setLayout(layout, coordinates, 1);\n if (!this.flatCoordinates) {\n this.flatCoordinates = [];\n }\n this.flatCoordinates.length = deflateCoordinates(\n this.flatCoordinates,\n 0,\n coordinates,\n this.stride,\n );\n this.changed();\n }\n}\n\nexport default LinearRing;\n","/**\n * @module ol/geom/Polygon\n */\nimport LinearRing from './LinearRing.js';\nimport Point from './Point.js';\nimport SimpleGeometry from './SimpleGeometry.js';\nimport {arrayMaxSquaredDelta, assignClosestArrayPoint} from './flat/closest.js';\nimport {closestSquaredDistanceXY, getCenter, isEmpty} from '../extent.js';\nimport {deflateCoordinatesArray} from './flat/deflate.js';\nimport {extend} from '../array.js';\nimport {getInteriorPointOfArray} from './flat/interiorpoint.js';\nimport {inflateCoordinatesArray} from './flat/inflate.js';\nimport {intersectsLinearRingArray} from './flat/intersectsextent.js';\nimport {linearRingsAreOriented, orientLinearRings} from './flat/orient.js';\nimport {linearRings as linearRingsArea} from './flat/area.js';\nimport {linearRingsContainsXY} from './flat/contains.js';\nimport {modulo} from '../math.js';\nimport {quantizeArray} from './flat/simplify.js';\nimport {offset as sphereOffset} from '../sphere.js';\n\n/**\n * @classdesc\n * Polygon geometry.\n *\n * @api\n */\nclass Polygon extends SimpleGeometry {\n /**\n * @param {!Array>|!Array} coordinates\n * Array of linear rings that define the polygon. The first linear ring of the\n * array defines the outer-boundary or surface of the polygon. Each subsequent\n * linear ring defines a hole in the surface of the polygon. A linear ring is\n * an array of vertices' coordinates where the first coordinate and the last are\n * equivalent. (For internal use, flat coordinates in combination with\n * `layout` and `ends` are also accepted.)\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n * @param {Array} [ends] Ends (for internal use with flat coordinates).\n */\n constructor(coordinates, layout, ends) {\n super();\n\n /**\n * @type {Array}\n * @private\n */\n this.ends_ = [];\n\n /**\n * @private\n * @type {number}\n */\n this.flatInteriorPointRevision_ = -1;\n\n /**\n * @private\n * @type {import(\"../coordinate.js\").Coordinate|null}\n */\n this.flatInteriorPoint_ = null;\n\n /**\n * @private\n * @type {number}\n */\n this.maxDelta_ = -1;\n\n /**\n * @private\n * @type {number}\n */\n this.maxDeltaRevision_ = -1;\n\n /**\n * @private\n * @type {number}\n */\n this.orientedRevision_ = -1;\n\n /**\n * @private\n * @type {Array|null}\n */\n this.orientedFlatCoordinates_ = null;\n\n if (layout !== undefined && ends) {\n this.setFlatCoordinates(\n layout,\n /** @type {Array} */ (coordinates),\n );\n this.ends_ = ends;\n } else {\n this.setCoordinates(\n /** @type {Array>} */ (\n coordinates\n ),\n layout,\n );\n }\n }\n\n /**\n * Append the passed linear ring to this polygon.\n * @param {LinearRing} linearRing Linear ring.\n * @api\n */\n appendLinearRing(linearRing) {\n if (!this.flatCoordinates) {\n this.flatCoordinates = linearRing.getFlatCoordinates().slice();\n } else {\n extend(this.flatCoordinates, linearRing.getFlatCoordinates());\n }\n this.ends_.push(this.flatCoordinates.length);\n this.changed();\n }\n\n /**\n * Make a complete copy of the geometry.\n * @return {!Polygon} Clone.\n * @api\n * @override\n */\n clone() {\n const polygon = new Polygon(\n this.flatCoordinates.slice(),\n this.layout,\n this.ends_.slice(),\n );\n polygon.applyProperties(this);\n return polygon;\n }\n\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @param {import(\"../coordinate.js\").Coordinate} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @return {number} Minimum squared distance.\n * @override\n */\n closestPointXY(x, y, closestPoint, minSquaredDistance) {\n if (minSquaredDistance < closestSquaredDistanceXY(this.getExtent(), x, y)) {\n return minSquaredDistance;\n }\n if (this.maxDeltaRevision_ != this.getRevision()) {\n this.maxDelta_ = Math.sqrt(\n arrayMaxSquaredDelta(\n this.flatCoordinates,\n 0,\n this.ends_,\n this.stride,\n 0,\n ),\n );\n this.maxDeltaRevision_ = this.getRevision();\n }\n return assignClosestArrayPoint(\n this.flatCoordinates,\n 0,\n this.ends_,\n this.stride,\n this.maxDelta_,\n true,\n x,\n y,\n closestPoint,\n minSquaredDistance,\n );\n }\n\n /**\n * @param {number} x X.\n * @param {number} y Y.\n * @return {boolean} Contains (x, y).\n * @override\n */\n containsXY(x, y) {\n return linearRingsContainsXY(\n this.getOrientedFlatCoordinates(),\n 0,\n this.ends_,\n this.stride,\n x,\n y,\n );\n }\n\n /**\n * Return the area of the polygon on projected plane.\n * @return {number} Area (on projected plane).\n * @api\n */\n getArea() {\n return linearRingsArea(\n this.getOrientedFlatCoordinates(),\n 0,\n this.ends_,\n this.stride,\n );\n }\n\n /**\n * Get the coordinate array for this geometry. This array has the structure\n * of a GeoJSON coordinate array for polygons.\n *\n * @param {boolean} [right] Orient coordinates according to the right-hand\n * rule (counter-clockwise for exterior and clockwise for interior rings).\n * If `false`, coordinates will be oriented according to the left-hand rule\n * (clockwise for exterior and counter-clockwise for interior rings).\n * By default, coordinate orientation will depend on how the geometry was\n * constructed.\n * @return {Array>} Coordinates.\n * @api\n * @override\n */\n getCoordinates(right) {\n let flatCoordinates;\n if (right !== undefined) {\n flatCoordinates = this.getOrientedFlatCoordinates().slice();\n orientLinearRings(flatCoordinates, 0, this.ends_, this.stride, right);\n } else {\n flatCoordinates = this.flatCoordinates;\n }\n\n return inflateCoordinatesArray(flatCoordinates, 0, this.ends_, this.stride);\n }\n\n /**\n * @return {Array} Ends.\n */\n getEnds() {\n return this.ends_;\n }\n\n /**\n * @return {Array} Interior point.\n */\n getFlatInteriorPoint() {\n if (this.flatInteriorPointRevision_ != this.getRevision()) {\n const flatCenter = getCenter(this.getExtent());\n this.flatInteriorPoint_ = getInteriorPointOfArray(\n this.getOrientedFlatCoordinates(),\n 0,\n this.ends_,\n this.stride,\n flatCenter,\n 0,\n );\n this.flatInteriorPointRevision_ = this.getRevision();\n }\n return /** @type {import(\"../coordinate.js\").Coordinate} */ (\n this.flatInteriorPoint_\n );\n }\n\n /**\n * Return an interior point of the polygon.\n * @return {Point} Interior point as XYM coordinate, where M is the\n * length of the horizontal intersection that the point belongs to.\n * @api\n */\n getInteriorPoint() {\n return new Point(this.getFlatInteriorPoint(), 'XYM');\n }\n\n /**\n * Return the number of rings of the polygon, this includes the exterior\n * ring and any interior rings.\n *\n * @return {number} Number of rings.\n * @api\n */\n getLinearRingCount() {\n return this.ends_.length;\n }\n\n /**\n * Return the Nth linear ring of the polygon geometry. Return `null` if the\n * given index is out of range.\n * The exterior linear ring is available at index `0` and the interior rings\n * at index `1` and beyond.\n *\n * @param {number} index Index.\n * @return {LinearRing|null} Linear ring.\n * @api\n */\n getLinearRing(index) {\n if (index < 0 || this.ends_.length <= index) {\n return null;\n }\n return new LinearRing(\n this.flatCoordinates.slice(\n index === 0 ? 0 : this.ends_[index - 1],\n this.ends_[index],\n ),\n this.layout,\n );\n }\n\n /**\n * Return the linear rings of the polygon.\n * @return {Array} Linear rings.\n * @api\n */\n getLinearRings() {\n const layout = this.layout;\n const flatCoordinates = this.flatCoordinates;\n const ends = this.ends_;\n const linearRings = [];\n let offset = 0;\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n const end = ends[i];\n const linearRing = new LinearRing(\n flatCoordinates.slice(offset, end),\n layout,\n );\n linearRings.push(linearRing);\n offset = end;\n }\n return linearRings;\n }\n\n /**\n * @return {Array} Oriented flat coordinates.\n */\n getOrientedFlatCoordinates() {\n if (this.orientedRevision_ != this.getRevision()) {\n const flatCoordinates = this.flatCoordinates;\n if (linearRingsAreOriented(flatCoordinates, 0, this.ends_, this.stride)) {\n this.orientedFlatCoordinates_ = flatCoordinates;\n } else {\n this.orientedFlatCoordinates_ = flatCoordinates.slice();\n this.orientedFlatCoordinates_.length = orientLinearRings(\n this.orientedFlatCoordinates_,\n 0,\n this.ends_,\n this.stride,\n );\n }\n this.orientedRevision_ = this.getRevision();\n }\n return /** @type {Array} */ (this.orientedFlatCoordinates_);\n }\n\n /**\n * @param {number} squaredTolerance Squared tolerance.\n * @return {Polygon} Simplified Polygon.\n * @protected\n * @override\n */\n getSimplifiedGeometryInternal(squaredTolerance) {\n /** @type {Array} */\n const simplifiedFlatCoordinates = [];\n /** @type {Array} */\n const simplifiedEnds = [];\n simplifiedFlatCoordinates.length = quantizeArray(\n this.flatCoordinates,\n 0,\n this.ends_,\n this.stride,\n Math.sqrt(squaredTolerance),\n simplifiedFlatCoordinates,\n 0,\n simplifiedEnds,\n );\n return new Polygon(simplifiedFlatCoordinates, 'XY', simplifiedEnds);\n }\n\n /**\n * Get the type of this geometry.\n * @return {import(\"./Geometry.js\").Type} Geometry type.\n * @api\n * @override\n */\n getType() {\n return 'Polygon';\n }\n\n /**\n * Test if the geometry and the passed extent intersect.\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @return {boolean} `true` if the geometry and the extent intersect.\n * @api\n * @override\n */\n intersectsExtent(extent) {\n return intersectsLinearRingArray(\n this.getOrientedFlatCoordinates(),\n 0,\n this.ends_,\n this.stride,\n extent,\n );\n }\n\n /**\n * Set the coordinates of the polygon.\n * @param {!Array>} coordinates Coordinates.\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n * @api\n * @override\n */\n setCoordinates(coordinates, layout) {\n this.setLayout(layout, coordinates, 2);\n if (!this.flatCoordinates) {\n this.flatCoordinates = [];\n }\n const ends = deflateCoordinatesArray(\n this.flatCoordinates,\n 0,\n coordinates,\n this.stride,\n this.ends_,\n );\n this.flatCoordinates.length = ends.length === 0 ? 0 : ends[ends.length - 1];\n this.changed();\n }\n}\n\nexport default Polygon;\n\n/**\n * Create an approximation of a circle on the surface of a sphere.\n * @param {import(\"../coordinate.js\").Coordinate} center Center (`[lon, lat]` in degrees).\n * @param {number} radius The great-circle distance from the center to\n * the polygon vertices in meters.\n * @param {number} [n] Optional number of vertices for the resulting\n * polygon. Default is `32`.\n * @param {number} [sphereRadius] Optional radius for the sphere (defaults to\n * the Earth's mean radius using the WGS84 ellipsoid).\n * @return {Polygon} The \"circular\" polygon.\n * @api\n */\nexport function circular(center, radius, n, sphereRadius) {\n n = n ? n : 32;\n /** @type {Array} */\n const flatCoordinates = [];\n for (let i = 0; i < n; ++i) {\n extend(\n flatCoordinates,\n sphereOffset(center, radius, (2 * Math.PI * i) / n, sphereRadius),\n );\n }\n flatCoordinates.push(flatCoordinates[0], flatCoordinates[1]);\n return new Polygon(flatCoordinates, 'XY', [flatCoordinates.length]);\n}\n\n/**\n * Create a polygon from an extent. The layout used is `XY`.\n * @param {import(\"../extent.js\").Extent} extent The extent.\n * @return {Polygon} The polygon.\n * @api\n */\nexport function fromExtent(extent) {\n if (isEmpty(extent)) {\n throw new Error('Cannot create polygon from empty extent');\n }\n const minX = extent[0];\n const minY = extent[1];\n const maxX = extent[2];\n const maxY = extent[3];\n const flatCoordinates = [\n minX,\n minY,\n minX,\n maxY,\n maxX,\n maxY,\n maxX,\n minY,\n minX,\n minY,\n ];\n return new Polygon(flatCoordinates, 'XY', [flatCoordinates.length]);\n}\n\n/**\n * Create a regular polygon from a circle.\n * @param {import(\"./Circle.js\").default} circle Circle geometry.\n * @param {number} [sides] Number of sides of the polygon. Default is 32.\n * @param {number} [angle] Start angle for the first vertex of the polygon in\n * counter-clockwise radians. 0 means East. Default is 0.\n * @return {Polygon} Polygon geometry.\n * @api\n */\nexport function fromCircle(circle, sides, angle) {\n sides = sides ? sides : 32;\n const stride = circle.getStride();\n const layout = circle.getLayout();\n const center = circle.getCenter();\n const arrayLength = stride * (sides + 1);\n const flatCoordinates = new Array(arrayLength);\n for (let i = 0; i < arrayLength; i += stride) {\n flatCoordinates[i] = 0;\n flatCoordinates[i + 1] = 0;\n for (let j = 2; j < stride; j++) {\n flatCoordinates[i + j] = center[j];\n }\n }\n const ends = [flatCoordinates.length];\n const polygon = new Polygon(flatCoordinates, layout, ends);\n makeRegular(polygon, center, circle.getRadius(), angle);\n return polygon;\n}\n\n/**\n * Modify the coordinates of a polygon to make it a regular polygon.\n * @param {Polygon} polygon Polygon geometry.\n * @param {import(\"../coordinate.js\").Coordinate} center Center of the regular polygon.\n * @param {number} radius Radius of the regular polygon.\n * @param {number} [angle] Start angle for the first vertex of the polygon in\n * counter-clockwise radians. 0 means East. Default is 0.\n */\nexport function makeRegular(polygon, center, radius, angle) {\n const flatCoordinates = polygon.getFlatCoordinates();\n const stride = polygon.getStride();\n const sides = flatCoordinates.length / stride - 1;\n const startAngle = angle ? angle : 0;\n for (let i = 0; i <= sides; ++i) {\n const offset = i * stride;\n const angle = startAngle + (modulo(i, sides) * 2 * Math.PI) / sides;\n flatCoordinates[offset] = center[0] + radius * Math.cos(angle);\n flatCoordinates[offset + 1] = center[1] + radius * Math.sin(angle);\n }\n polygon.changed();\n}\n","/**\n * @module ol/geom/SimpleGeometry\n */\nimport Geometry from './Geometry.js';\nimport {abstract} from '../util.js';\nimport {createOrUpdateFromFlatCoordinates, getCenter} from '../extent.js';\nimport {rotate, scale, transform2D, translate} from './flat/transform.js';\n\n/**\n * @classdesc\n * Abstract base class; only used for creating subclasses; do not instantiate\n * in apps, as cannot be rendered.\n *\n * @abstract\n * @api\n */\nclass SimpleGeometry extends Geometry {\n constructor() {\n super();\n\n /**\n * @protected\n * @type {import(\"./Geometry.js\").GeometryLayout}\n */\n this.layout = 'XY';\n\n /**\n * @protected\n * @type {number}\n */\n this.stride = 2;\n\n /**\n * @protected\n * @type {Array}\n */\n this.flatCoordinates;\n }\n\n /**\n * @param {import(\"../extent.js\").Extent} extent Extent.\n * @protected\n * @return {import(\"../extent.js\").Extent} extent Extent.\n * @override\n */\n computeExtent(extent) {\n return createOrUpdateFromFlatCoordinates(\n this.flatCoordinates,\n 0,\n this.flatCoordinates.length,\n this.stride,\n extent,\n );\n }\n\n /**\n * @abstract\n * @return {Array<*> | null} Coordinates.\n */\n getCoordinates() {\n return abstract();\n }\n\n /**\n * Return the first coordinate of the geometry.\n * @return {import(\"../coordinate.js\").Coordinate} First coordinate.\n * @api\n */\n getFirstCoordinate() {\n return this.flatCoordinates.slice(0, this.stride);\n }\n\n /**\n * @return {Array} Flat coordinates.\n */\n getFlatCoordinates() {\n return this.flatCoordinates;\n }\n\n /**\n * Return the last coordinate of the geometry.\n * @return {import(\"../coordinate.js\").Coordinate} Last point.\n * @api\n */\n getLastCoordinate() {\n return this.flatCoordinates.slice(\n this.flatCoordinates.length - this.stride,\n );\n }\n\n /**\n * Return the {@link import(\"./Geometry.js\").GeometryLayout layout} of the geometry.\n * @return {import(\"./Geometry.js\").GeometryLayout} Layout.\n * @api\n */\n getLayout() {\n return this.layout;\n }\n\n /**\n * Create a simplified version of this geometry using the Douglas Peucker algorithm.\n * @param {number} squaredTolerance Squared tolerance.\n * @return {SimpleGeometry} Simplified geometry.\n * @override\n */\n getSimplifiedGeometry(squaredTolerance) {\n if (this.simplifiedGeometryRevision !== this.getRevision()) {\n this.simplifiedGeometryMaxMinSquaredTolerance = 0;\n this.simplifiedGeometryRevision = this.getRevision();\n }\n // If squaredTolerance is negative or if we know that simplification will not\n // have any effect then just return this.\n if (\n squaredTolerance < 0 ||\n (this.simplifiedGeometryMaxMinSquaredTolerance !== 0 &&\n squaredTolerance <= this.simplifiedGeometryMaxMinSquaredTolerance)\n ) {\n return this;\n }\n\n const simplifiedGeometry =\n this.getSimplifiedGeometryInternal(squaredTolerance);\n const simplifiedFlatCoordinates = simplifiedGeometry.getFlatCoordinates();\n if (simplifiedFlatCoordinates.length < this.flatCoordinates.length) {\n return simplifiedGeometry;\n }\n // Simplification did not actually remove any coordinates. We now know\n // that any calls to getSimplifiedGeometry with a squaredTolerance less\n // than or equal to the current squaredTolerance will also not have any\n // effect. This allows us to short circuit simplification (saving CPU\n // cycles) and prevents the cache of simplified geometries from filling\n // up with useless identical copies of this geometry (saving memory).\n this.simplifiedGeometryMaxMinSquaredTolerance = squaredTolerance;\n return this;\n }\n\n /**\n * @param {number} squaredTolerance Squared tolerance.\n * @return {SimpleGeometry} Simplified geometry.\n * @protected\n */\n getSimplifiedGeometryInternal(squaredTolerance) {\n return this;\n }\n\n /**\n * @return {number} Stride.\n */\n getStride() {\n return this.stride;\n }\n\n /**\n * @param {import(\"./Geometry.js\").GeometryLayout} layout Layout.\n * @param {Array} flatCoordinates Flat coordinates.\n */\n setFlatCoordinates(layout, flatCoordinates) {\n this.stride = getStrideForLayout(layout);\n this.layout = layout;\n this.flatCoordinates = flatCoordinates;\n }\n\n /**\n * @abstract\n * @param {!Array<*>} coordinates Coordinates.\n * @param {import(\"./Geometry.js\").GeometryLayout} [layout] Layout.\n */\n setCoordinates(coordinates, layout) {\n abstract();\n }\n\n /**\n * @param {import(\"./Geometry.js\").GeometryLayout|undefined} layout Layout.\n * @param {Array<*>} coordinates Coordinates.\n * @param {number} nesting Nesting.\n * @protected\n */\n setLayout(layout, coordinates, nesting) {\n let stride;\n if (layout) {\n stride = getStrideForLayout(layout);\n } else {\n for (let i = 0; i < nesting; ++i) {\n if (coordinates.length === 0) {\n this.layout = 'XY';\n this.stride = 2;\n return;\n }\n coordinates = /** @type {Array} */ (coordinates[0]);\n }\n stride = coordinates.length;\n layout = getLayoutForStride(stride);\n }\n this.layout = layout;\n this.stride = stride;\n }\n\n /**\n * Apply a transform function to the coordinates of the geometry.\n * The geometry is modified in place.\n * If you do not want the geometry modified in place, first `clone()` it and\n * then use this function on the clone.\n * @param {import(\"../proj.js\").TransformFunction} transformFn Transform function.\n * Called with a flat array of geometry coordinates.\n * @api\n * @override\n */\n applyTransform(transformFn) {\n if (this.flatCoordinates) {\n transformFn(this.flatCoordinates, this.flatCoordinates, this.stride);\n this.changed();\n }\n }\n\n /**\n * Rotate the geometry around a given coordinate. This modifies the geometry\n * coordinates in place.\n * @param {number} angle Rotation angle in counter-clockwise radians.\n * @param {import(\"../coordinate.js\").Coordinate} anchor The rotation center.\n * @api\n * @override\n */\n rotate(angle, anchor) {\n const flatCoordinates = this.getFlatCoordinates();\n if (flatCoordinates) {\n const stride = this.getStride();\n rotate(\n flatCoordinates,\n 0,\n flatCoordinates.length,\n stride,\n angle,\n anchor,\n flatCoordinates,\n );\n this.changed();\n }\n }\n\n /**\n * Scale the geometry (with an optional origin). This modifies the geometry\n * coordinates in place.\n * @param {number} sx The scaling factor in the x-direction.\n * @param {number} [sy] The scaling factor in the y-direction (defaults to sx).\n * @param {import(\"../coordinate.js\").Coordinate} [anchor] The scale origin (defaults to the center\n * of the geometry extent).\n * @api\n * @override\n */\n scale(sx, sy, anchor) {\n if (sy === undefined) {\n sy = sx;\n }\n if (!anchor) {\n anchor = getCenter(this.getExtent());\n }\n const flatCoordinates = this.getFlatCoordinates();\n if (flatCoordinates) {\n const stride = this.getStride();\n scale(\n flatCoordinates,\n 0,\n flatCoordinates.length,\n stride,\n sx,\n sy,\n anchor,\n flatCoordinates,\n );\n this.changed();\n }\n }\n\n /**\n * Translate the geometry. This modifies the geometry coordinates in place. If\n * instead you want a new geometry, first `clone()` this geometry.\n * @param {number} deltaX Delta X.\n * @param {number} deltaY Delta Y.\n * @api\n * @override\n */\n translate(deltaX, deltaY) {\n const flatCoordinates = this.getFlatCoordinates();\n if (flatCoordinates) {\n const stride = this.getStride();\n translate(\n flatCoordinates,\n 0,\n flatCoordinates.length,\n stride,\n deltaX,\n deltaY,\n flatCoordinates,\n );\n this.changed();\n }\n }\n}\n\n/**\n * @param {number} stride Stride.\n * @return {import(\"./Geometry.js\").GeometryLayout} layout Layout.\n */\nexport function getLayoutForStride(stride) {\n let layout;\n if (stride == 2) {\n layout = 'XY';\n } else if (stride == 3) {\n layout = 'XYZ';\n } else if (stride == 4) {\n layout = 'XYZM';\n }\n return /** @type {import(\"./Geometry.js\").GeometryLayout} */ (layout);\n}\n\n/**\n * @param {import(\"./Geometry.js\").GeometryLayout} layout Layout.\n * @return {number} Stride.\n */\nexport function getStrideForLayout(layout) {\n let stride;\n if (layout == 'XY') {\n stride = 2;\n } else if (layout == 'XYZ' || layout == 'XYM') {\n stride = 3;\n } else if (layout == 'XYZM') {\n stride = 4;\n }\n return /** @type {number} */ (stride);\n}\n\n/**\n * @param {SimpleGeometry} simpleGeometry Simple geometry.\n * @param {import(\"../transform.js\").Transform} transform Transform.\n * @param {Array} [dest] Destination.\n * @return {Array} Transformed flat coordinates.\n */\nexport function transformGeom2D(simpleGeometry, transform, dest) {\n const flatCoordinates = simpleGeometry.getFlatCoordinates();\n if (!flatCoordinates) {\n return null;\n }\n const stride = simpleGeometry.getStride();\n return transform2D(\n flatCoordinates,\n 0,\n flatCoordinates.length,\n stride,\n transform,\n dest,\n );\n}\n\nexport default SimpleGeometry;\n","/**\n * @module ol/geom/flat/area\n */\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @return {number} Area.\n */\nexport function linearRing(flatCoordinates, offset, end, stride) {\n let twiceArea = 0;\n const x0 = flatCoordinates[end - stride];\n const y0 = flatCoordinates[end - stride + 1];\n let dx1 = 0;\n let dy1 = 0;\n for (; offset < end; offset += stride) {\n const dx2 = flatCoordinates[offset] - x0;\n const dy2 = flatCoordinates[offset + 1] - y0;\n twiceArea += dy1 * dx2 - dx1 * dy2;\n dx1 = dx2;\n dy1 = dy2;\n }\n return twiceArea / 2;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array} ends Ends.\n * @param {number} stride Stride.\n * @return {number} Area.\n */\nexport function linearRings(flatCoordinates, offset, ends, stride) {\n let area = 0;\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n const end = ends[i];\n area += linearRing(flatCoordinates, offset, end, stride);\n offset = end;\n }\n return area;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array>} endss Endss.\n * @param {number} stride Stride.\n * @return {number} Area.\n */\nexport function linearRingss(flatCoordinates, offset, endss, stride) {\n let area = 0;\n for (let i = 0, ii = endss.length; i < ii; ++i) {\n const ends = endss[i];\n area += linearRings(flatCoordinates, offset, ends, stride);\n offset = ends[ends.length - 1];\n }\n return area;\n}\n","/**\n * @module ol/geom/flat/center\n */\nimport {createEmpty, createOrUpdateFromFlatCoordinates} from '../../extent.js';\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array>} endss Endss.\n * @param {number} stride Stride.\n * @return {Array} Flat centers.\n */\nexport function linearRingss(flatCoordinates, offset, endss, stride) {\n const flatCenters = [];\n let extent = createEmpty();\n for (let i = 0, ii = endss.length; i < ii; ++i) {\n const ends = endss[i];\n extent = createOrUpdateFromFlatCoordinates(\n flatCoordinates,\n offset,\n ends[0],\n stride,\n );\n flatCenters.push((extent[0] + extent[2]) / 2, (extent[1] + extent[3]) / 2);\n offset = ends[ends.length - 1];\n }\n return flatCenters;\n}\n","/**\n * @module ol/geom/flat/closest\n */\nimport {lerp, squaredDistance as squaredDx} from '../../math.js';\n\n/**\n * Returns the point on the 2D line segment flatCoordinates[offset1] to\n * flatCoordinates[offset2] that is closest to the point (x, y). Extra\n * dimensions are linearly interpolated.\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset1 Offset 1.\n * @param {number} offset2 Offset 2.\n * @param {number} stride Stride.\n * @param {number} x X.\n * @param {number} y Y.\n * @param {Array} closestPoint Closest point.\n */\nfunction assignClosest(\n flatCoordinates,\n offset1,\n offset2,\n stride,\n x,\n y,\n closestPoint,\n) {\n const x1 = flatCoordinates[offset1];\n const y1 = flatCoordinates[offset1 + 1];\n const dx = flatCoordinates[offset2] - x1;\n const dy = flatCoordinates[offset2 + 1] - y1;\n let offset;\n if (dx === 0 && dy === 0) {\n offset = offset1;\n } else {\n const t = ((x - x1) * dx + (y - y1) * dy) / (dx * dx + dy * dy);\n if (t > 1) {\n offset = offset2;\n } else if (t > 0) {\n for (let i = 0; i < stride; ++i) {\n closestPoint[i] = lerp(\n flatCoordinates[offset1 + i],\n flatCoordinates[offset2 + i],\n t,\n );\n }\n closestPoint.length = stride;\n return;\n } else {\n offset = offset1;\n }\n }\n for (let i = 0; i < stride; ++i) {\n closestPoint[i] = flatCoordinates[offset + i];\n }\n closestPoint.length = stride;\n}\n\n/**\n * Return the squared of the largest distance between any pair of consecutive\n * coordinates.\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} max Max squared delta.\n * @return {number} Max squared delta.\n */\nexport function maxSquaredDelta(flatCoordinates, offset, end, stride, max) {\n let x1 = flatCoordinates[offset];\n let y1 = flatCoordinates[offset + 1];\n for (offset += stride; offset < end; offset += stride) {\n const x2 = flatCoordinates[offset];\n const y2 = flatCoordinates[offset + 1];\n const squaredDelta = squaredDx(x1, y1, x2, y2);\n if (squaredDelta > max) {\n max = squaredDelta;\n }\n x1 = x2;\n y1 = y2;\n }\n return max;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array} ends Ends.\n * @param {number} stride Stride.\n * @param {number} max Max squared delta.\n * @return {number} Max squared delta.\n */\nexport function arrayMaxSquaredDelta(\n flatCoordinates,\n offset,\n ends,\n stride,\n max,\n) {\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n const end = ends[i];\n max = maxSquaredDelta(flatCoordinates, offset, end, stride, max);\n offset = end;\n }\n return max;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array>} endss Endss.\n * @param {number} stride Stride.\n * @param {number} max Max squared delta.\n * @return {number} Max squared delta.\n */\nexport function multiArrayMaxSquaredDelta(\n flatCoordinates,\n offset,\n endss,\n stride,\n max,\n) {\n for (let i = 0, ii = endss.length; i < ii; ++i) {\n const ends = endss[i];\n max = arrayMaxSquaredDelta(flatCoordinates, offset, ends, stride, max);\n offset = ends[ends.length - 1];\n }\n return max;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} maxDelta Max delta.\n * @param {boolean} isRing Is ring.\n * @param {number} x X.\n * @param {number} y Y.\n * @param {Array} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @param {Array} [tmpPoint] Temporary point object.\n * @return {number} Minimum squared distance.\n */\nexport function assignClosestPoint(\n flatCoordinates,\n offset,\n end,\n stride,\n maxDelta,\n isRing,\n x,\n y,\n closestPoint,\n minSquaredDistance,\n tmpPoint,\n) {\n if (offset == end) {\n return minSquaredDistance;\n }\n let i, squaredDistance;\n if (maxDelta === 0) {\n // All points are identical, so just test the first point.\n squaredDistance = squaredDx(\n x,\n y,\n flatCoordinates[offset],\n flatCoordinates[offset + 1],\n );\n if (squaredDistance < minSquaredDistance) {\n for (i = 0; i < stride; ++i) {\n closestPoint[i] = flatCoordinates[offset + i];\n }\n closestPoint.length = stride;\n return squaredDistance;\n }\n return minSquaredDistance;\n }\n tmpPoint = tmpPoint ? tmpPoint : [NaN, NaN];\n let index = offset + stride;\n while (index < end) {\n assignClosest(\n flatCoordinates,\n index - stride,\n index,\n stride,\n x,\n y,\n tmpPoint,\n );\n squaredDistance = squaredDx(x, y, tmpPoint[0], tmpPoint[1]);\n if (squaredDistance < minSquaredDistance) {\n minSquaredDistance = squaredDistance;\n for (i = 0; i < stride; ++i) {\n closestPoint[i] = tmpPoint[i];\n }\n closestPoint.length = stride;\n index += stride;\n } else {\n // Skip ahead multiple points, because we know that all the skipped\n // points cannot be any closer than the closest point we have found so\n // far. We know this because we know how close the current point is, how\n // close the closest point we have found so far is, and the maximum\n // distance between consecutive points. For example, if we're currently\n // at distance 10, the best we've found so far is 3, and that the maximum\n // distance between consecutive points is 2, then we'll need to skip at\n // least (10 - 3) / 2 == 3 (rounded down) points to have any chance of\n // finding a closer point. We use Math.max(..., 1) to ensure that we\n // always advance at least one point, to avoid an infinite loop.\n index +=\n stride *\n Math.max(\n ((Math.sqrt(squaredDistance) - Math.sqrt(minSquaredDistance)) /\n maxDelta) |\n 0,\n 1,\n );\n }\n }\n if (isRing) {\n // Check the closing segment.\n assignClosest(\n flatCoordinates,\n end - stride,\n offset,\n stride,\n x,\n y,\n tmpPoint,\n );\n squaredDistance = squaredDx(x, y, tmpPoint[0], tmpPoint[1]);\n if (squaredDistance < minSquaredDistance) {\n minSquaredDistance = squaredDistance;\n for (i = 0; i < stride; ++i) {\n closestPoint[i] = tmpPoint[i];\n }\n closestPoint.length = stride;\n }\n }\n return minSquaredDistance;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array} ends Ends.\n * @param {number} stride Stride.\n * @param {number} maxDelta Max delta.\n * @param {boolean} isRing Is ring.\n * @param {number} x X.\n * @param {number} y Y.\n * @param {Array} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @param {Array} [tmpPoint] Temporary point object.\n * @return {number} Minimum squared distance.\n */\nexport function assignClosestArrayPoint(\n flatCoordinates,\n offset,\n ends,\n stride,\n maxDelta,\n isRing,\n x,\n y,\n closestPoint,\n minSquaredDistance,\n tmpPoint,\n) {\n tmpPoint = tmpPoint ? tmpPoint : [NaN, NaN];\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n const end = ends[i];\n minSquaredDistance = assignClosestPoint(\n flatCoordinates,\n offset,\n end,\n stride,\n maxDelta,\n isRing,\n x,\n y,\n closestPoint,\n minSquaredDistance,\n tmpPoint,\n );\n offset = end;\n }\n return minSquaredDistance;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array>} endss Endss.\n * @param {number} stride Stride.\n * @param {number} maxDelta Max delta.\n * @param {boolean} isRing Is ring.\n * @param {number} x X.\n * @param {number} y Y.\n * @param {Array} closestPoint Closest point.\n * @param {number} minSquaredDistance Minimum squared distance.\n * @param {Array} [tmpPoint] Temporary point object.\n * @return {number} Minimum squared distance.\n */\nexport function assignClosestMultiArrayPoint(\n flatCoordinates,\n offset,\n endss,\n stride,\n maxDelta,\n isRing,\n x,\n y,\n closestPoint,\n minSquaredDistance,\n tmpPoint,\n) {\n tmpPoint = tmpPoint ? tmpPoint : [NaN, NaN];\n for (let i = 0, ii = endss.length; i < ii; ++i) {\n const ends = endss[i];\n minSquaredDistance = assignClosestArrayPoint(\n flatCoordinates,\n offset,\n ends,\n stride,\n maxDelta,\n isRing,\n x,\n y,\n closestPoint,\n minSquaredDistance,\n tmpPoint,\n );\n offset = ends[ends.length - 1];\n }\n return minSquaredDistance;\n}\n","/**\n * @module ol/geom/flat/contains\n */\nimport {forEachCorner} from '../../extent.js';\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @return {boolean} Contains extent.\n */\nexport function linearRingContainsExtent(\n flatCoordinates,\n offset,\n end,\n stride,\n extent,\n) {\n const outside = forEachCorner(\n extent,\n /**\n * @param {import(\"../../coordinate.js\").Coordinate} coordinate Coordinate.\n * @return {boolean} Contains (x, y).\n */\n function (coordinate) {\n return !linearRingContainsXY(\n flatCoordinates,\n offset,\n end,\n stride,\n coordinate[0],\n coordinate[1],\n );\n },\n );\n return !outside;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} x X.\n * @param {number} y Y.\n * @return {boolean} Contains (x, y).\n */\nexport function linearRingContainsXY(\n flatCoordinates,\n offset,\n end,\n stride,\n x,\n y,\n) {\n // https://geomalgorithms.com/a03-_inclusion.html\n // Copyright 2000 softSurfer, 2012 Dan Sunday\n // This code may be freely used and modified for any purpose\n // providing that this copyright notice is included with it.\n // SoftSurfer makes no warranty for this code, and cannot be held\n // liable for any real or imagined damage resulting from its use.\n // Users of this code must verify correctness for their application.\n let wn = 0;\n let x1 = flatCoordinates[end - stride];\n let y1 = flatCoordinates[end - stride + 1];\n for (; offset < end; offset += stride) {\n const x2 = flatCoordinates[offset];\n const y2 = flatCoordinates[offset + 1];\n if (y1 <= y) {\n if (y2 > y && (x2 - x1) * (y - y1) - (x - x1) * (y2 - y1) > 0) {\n wn++;\n }\n } else if (y2 <= y && (x2 - x1) * (y - y1) - (x - x1) * (y2 - y1) < 0) {\n wn--;\n }\n x1 = x2;\n y1 = y2;\n }\n return wn !== 0;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array} ends Ends.\n * @param {number} stride Stride.\n * @param {number} x X.\n * @param {number} y Y.\n * @return {boolean} Contains (x, y).\n */\nexport function linearRingsContainsXY(\n flatCoordinates,\n offset,\n ends,\n stride,\n x,\n y,\n) {\n if (ends.length === 0) {\n return false;\n }\n if (!linearRingContainsXY(flatCoordinates, offset, ends[0], stride, x, y)) {\n return false;\n }\n for (let i = 1, ii = ends.length; i < ii; ++i) {\n if (\n linearRingContainsXY(flatCoordinates, ends[i - 1], ends[i], stride, x, y)\n ) {\n return false;\n }\n }\n return true;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array>} endss Endss.\n * @param {number} stride Stride.\n * @param {number} x X.\n * @param {number} y Y.\n * @return {boolean} Contains (x, y).\n */\nexport function linearRingssContainsXY(\n flatCoordinates,\n offset,\n endss,\n stride,\n x,\n y,\n) {\n if (endss.length === 0) {\n return false;\n }\n for (let i = 0, ii = endss.length; i < ii; ++i) {\n const ends = endss[i];\n if (linearRingsContainsXY(flatCoordinates, offset, ends, stride, x, y)) {\n return true;\n }\n offset = ends[ends.length - 1];\n }\n return false;\n}\n","/**\n * @module ol/geom/flat/deflate\n */\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {import(\"../../coordinate.js\").Coordinate} coordinate Coordinate.\n * @param {number} stride Stride.\n * @return {number} offset Offset.\n */\nexport function deflateCoordinate(flatCoordinates, offset, coordinate, stride) {\n for (let i = 0, ii = coordinate.length; i < ii; ++i) {\n flatCoordinates[offset++] = coordinate[i];\n }\n return offset;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array} coordinates Coordinates.\n * @param {number} stride Stride.\n * @return {number} offset Offset.\n */\nexport function deflateCoordinates(\n flatCoordinates,\n offset,\n coordinates,\n stride,\n) {\n for (let i = 0, ii = coordinates.length; i < ii; ++i) {\n const coordinate = coordinates[i];\n for (let j = 0; j < stride; ++j) {\n flatCoordinates[offset++] = coordinate[j];\n }\n }\n return offset;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array>} coordinatess Coordinatess.\n * @param {number} stride Stride.\n * @param {Array} [ends] Ends.\n * @return {Array} Ends.\n */\nexport function deflateCoordinatesArray(\n flatCoordinates,\n offset,\n coordinatess,\n stride,\n ends,\n) {\n ends = ends ? ends : [];\n let i = 0;\n for (let j = 0, jj = coordinatess.length; j < jj; ++j) {\n const end = deflateCoordinates(\n flatCoordinates,\n offset,\n coordinatess[j],\n stride,\n );\n ends[i++] = end;\n offset = end;\n }\n ends.length = i;\n return ends;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array>>} coordinatesss Coordinatesss.\n * @param {number} stride Stride.\n * @param {Array>} [endss] Endss.\n * @return {Array>} Endss.\n */\nexport function deflateMultiCoordinatesArray(\n flatCoordinates,\n offset,\n coordinatesss,\n stride,\n endss,\n) {\n endss = endss ? endss : [];\n let i = 0;\n for (let j = 0, jj = coordinatesss.length; j < jj; ++j) {\n const ends = deflateCoordinatesArray(\n flatCoordinates,\n offset,\n coordinatesss[j],\n stride,\n endss[i],\n );\n if (ends.length === 0) {\n ends[0] = offset;\n }\n endss[i++] = ends;\n offset = ends[ends.length - 1];\n }\n endss.length = i;\n return endss;\n}\n","/**\n * @module ol/geom/flat/inflate\n */\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {Array} [coordinates] Coordinates.\n * @return {Array} Coordinates.\n */\nexport function inflateCoordinates(\n flatCoordinates,\n offset,\n end,\n stride,\n coordinates,\n) {\n coordinates = coordinates !== undefined ? coordinates : [];\n let i = 0;\n for (let j = offset; j < end; j += stride) {\n coordinates[i++] = flatCoordinates.slice(j, j + stride);\n }\n coordinates.length = i;\n return coordinates;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array} ends Ends.\n * @param {number} stride Stride.\n * @param {Array>} [coordinatess] Coordinatess.\n * @return {Array>} Coordinatess.\n */\nexport function inflateCoordinatesArray(\n flatCoordinates,\n offset,\n ends,\n stride,\n coordinatess,\n) {\n coordinatess = coordinatess !== undefined ? coordinatess : [];\n let i = 0;\n for (let j = 0, jj = ends.length; j < jj; ++j) {\n const end = ends[j];\n coordinatess[i++] = inflateCoordinates(\n flatCoordinates,\n offset,\n end,\n stride,\n coordinatess[i],\n );\n offset = end;\n }\n coordinatess.length = i;\n return coordinatess;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array>} endss Endss.\n * @param {number} stride Stride.\n * @param {Array>>} [coordinatesss]\n * Coordinatesss.\n * @return {Array>>} Coordinatesss.\n */\nexport function inflateMultiCoordinatesArray(\n flatCoordinates,\n offset,\n endss,\n stride,\n coordinatesss,\n) {\n coordinatesss = coordinatesss !== undefined ? coordinatesss : [];\n let i = 0;\n for (let j = 0, jj = endss.length; j < jj; ++j) {\n const ends = endss[j];\n coordinatesss[i++] =\n ends.length === 1 && ends[0] === offset\n ? []\n : inflateCoordinatesArray(\n flatCoordinates,\n offset,\n ends,\n stride,\n coordinatesss[i],\n );\n offset = ends[ends.length - 1];\n }\n coordinatesss.length = i;\n return coordinatesss;\n}\n","/**\n * @module ol/geom/flat/interiorpoint\n */\nimport {ascending} from '../../array.js';\nimport {linearRingsContainsXY} from './contains.js';\n\n/**\n * Calculates a point that is likely to lie in the interior of the linear rings.\n * Inspired by JTS's com.vividsolutions.jts.geom.Geometry#getInteriorPoint.\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array} ends Ends.\n * @param {number} stride Stride.\n * @param {Array} flatCenters Flat centers.\n * @param {number} flatCentersOffset Flat center offset.\n * @param {Array} [dest] Destination.\n * @return {Array} Destination point as XYM coordinate, where M is the\n * length of the horizontal intersection that the point belongs to.\n */\nexport function getInteriorPointOfArray(\n flatCoordinates,\n offset,\n ends,\n stride,\n flatCenters,\n flatCentersOffset,\n dest,\n) {\n let i, ii, x, x1, x2, y1, y2;\n const y = flatCenters[flatCentersOffset + 1];\n /** @type {Array} */\n const intersections = [];\n // Calculate intersections with the horizontal line\n for (let r = 0, rr = ends.length; r < rr; ++r) {\n const end = ends[r];\n x1 = flatCoordinates[end - stride];\n y1 = flatCoordinates[end - stride + 1];\n for (i = offset; i < end; i += stride) {\n x2 = flatCoordinates[i];\n y2 = flatCoordinates[i + 1];\n if ((y <= y1 && y2 <= y) || (y1 <= y && y <= y2)) {\n x = ((y - y1) / (y2 - y1)) * (x2 - x1) + x1;\n intersections.push(x);\n }\n x1 = x2;\n y1 = y2;\n }\n }\n // Find the longest segment of the horizontal line that has its center point\n // inside the linear ring.\n let pointX = NaN;\n let maxSegmentLength = -Infinity;\n intersections.sort(ascending);\n x1 = intersections[0];\n for (i = 1, ii = intersections.length; i < ii; ++i) {\n x2 = intersections[i];\n const segmentLength = Math.abs(x2 - x1);\n if (segmentLength > maxSegmentLength) {\n x = (x1 + x2) / 2;\n if (linearRingsContainsXY(flatCoordinates, offset, ends, stride, x, y)) {\n pointX = x;\n maxSegmentLength = segmentLength;\n }\n }\n x1 = x2;\n }\n if (isNaN(pointX)) {\n // There is no horizontal line that has its center point inside the linear\n // ring. Use the center of the the linear ring's extent.\n pointX = flatCenters[flatCentersOffset];\n }\n if (dest) {\n dest.push(pointX, y, maxSegmentLength);\n return dest;\n }\n return [pointX, y, maxSegmentLength];\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array>} endss Endss.\n * @param {number} stride Stride.\n * @param {Array} flatCenters Flat centers.\n * @return {Array} Interior points as XYM coordinates, where M is the\n * length of the horizontal intersection that the point belongs to.\n */\nexport function getInteriorPointsOfMultiArray(\n flatCoordinates,\n offset,\n endss,\n stride,\n flatCenters,\n) {\n /** @type {Array} */\n let interiorPoints = [];\n for (let i = 0, ii = endss.length; i < ii; ++i) {\n const ends = endss[i];\n interiorPoints = getInteriorPointOfArray(\n flatCoordinates,\n offset,\n ends,\n stride,\n flatCenters,\n 2 * i,\n interiorPoints,\n );\n offset = ends[ends.length - 1];\n }\n return interiorPoints;\n}\n","/**\n * @module ol/geom/flat/interpolate\n */\nimport {binarySearch} from '../../array.js';\nimport {lerp} from '../../math.js';\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} fraction Fraction.\n * @param {Array} [dest] Destination.\n * @param {number} [dimension] Destination dimension (default is `2`)\n * @return {Array} Destination.\n */\nexport function interpolatePoint(\n flatCoordinates,\n offset,\n end,\n stride,\n fraction,\n dest,\n dimension,\n) {\n let o, t;\n const n = (end - offset) / stride;\n if (n === 1) {\n o = offset;\n } else if (n === 2) {\n o = offset;\n t = fraction;\n } else if (n !== 0) {\n let x1 = flatCoordinates[offset];\n let y1 = flatCoordinates[offset + 1];\n let length = 0;\n const cumulativeLengths = [0];\n for (let i = offset + stride; i < end; i += stride) {\n const x2 = flatCoordinates[i];\n const y2 = flatCoordinates[i + 1];\n length += Math.sqrt((x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1));\n cumulativeLengths.push(length);\n x1 = x2;\n y1 = y2;\n }\n const target = fraction * length;\n const index = binarySearch(cumulativeLengths, target);\n if (index < 0) {\n t =\n (target - cumulativeLengths[-index - 2]) /\n (cumulativeLengths[-index - 1] - cumulativeLengths[-index - 2]);\n o = offset + (-index - 2) * stride;\n } else {\n o = offset + index * stride;\n }\n }\n dimension = dimension > 1 ? dimension : 2;\n dest = dest ? dest : new Array(dimension);\n for (let i = 0; i < dimension; ++i) {\n dest[i] =\n o === undefined\n ? NaN\n : t === undefined\n ? flatCoordinates[o + i]\n : lerp(flatCoordinates[o + i], flatCoordinates[o + stride + i], t);\n }\n return dest;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} m M.\n * @param {boolean} extrapolate Extrapolate.\n * @return {import(\"../../coordinate.js\").Coordinate|null} Coordinate.\n */\nexport function lineStringCoordinateAtM(\n flatCoordinates,\n offset,\n end,\n stride,\n m,\n extrapolate,\n) {\n if (end == offset) {\n return null;\n }\n let coordinate;\n if (m < flatCoordinates[offset + stride - 1]) {\n if (extrapolate) {\n coordinate = flatCoordinates.slice(offset, offset + stride);\n coordinate[stride - 1] = m;\n return coordinate;\n }\n return null;\n }\n if (flatCoordinates[end - 1] < m) {\n if (extrapolate) {\n coordinate = flatCoordinates.slice(end - stride, end);\n coordinate[stride - 1] = m;\n return coordinate;\n }\n return null;\n }\n // FIXME use O(1) search\n if (m == flatCoordinates[offset + stride - 1]) {\n return flatCoordinates.slice(offset, offset + stride);\n }\n let lo = offset / stride;\n let hi = end / stride;\n while (lo < hi) {\n const mid = (lo + hi) >> 1;\n if (m < flatCoordinates[(mid + 1) * stride - 1]) {\n hi = mid;\n } else {\n lo = mid + 1;\n }\n }\n const m0 = flatCoordinates[lo * stride - 1];\n if (m == m0) {\n return flatCoordinates.slice((lo - 1) * stride, (lo - 1) * stride + stride);\n }\n const m1 = flatCoordinates[(lo + 1) * stride - 1];\n const t = (m - m0) / (m1 - m0);\n coordinate = [];\n for (let i = 0; i < stride - 1; ++i) {\n coordinate.push(\n lerp(\n flatCoordinates[(lo - 1) * stride + i],\n flatCoordinates[lo * stride + i],\n t,\n ),\n );\n }\n coordinate.push(m);\n return coordinate;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array} ends Ends.\n * @param {number} stride Stride.\n * @param {number} m M.\n * @param {boolean} extrapolate Extrapolate.\n * @param {boolean} interpolate Interpolate.\n * @return {import(\"../../coordinate.js\").Coordinate|null} Coordinate.\n */\nexport function lineStringsCoordinateAtM(\n flatCoordinates,\n offset,\n ends,\n stride,\n m,\n extrapolate,\n interpolate,\n) {\n if (interpolate) {\n return lineStringCoordinateAtM(\n flatCoordinates,\n offset,\n ends[ends.length - 1],\n stride,\n m,\n extrapolate,\n );\n }\n let coordinate;\n if (m < flatCoordinates[stride - 1]) {\n if (extrapolate) {\n coordinate = flatCoordinates.slice(0, stride);\n coordinate[stride - 1] = m;\n return coordinate;\n }\n return null;\n }\n if (flatCoordinates[flatCoordinates.length - 1] < m) {\n if (extrapolate) {\n coordinate = flatCoordinates.slice(flatCoordinates.length - stride);\n coordinate[stride - 1] = m;\n return coordinate;\n }\n return null;\n }\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n const end = ends[i];\n if (offset == end) {\n continue;\n }\n if (m < flatCoordinates[offset + stride - 1]) {\n return null;\n }\n if (m <= flatCoordinates[end - 1]) {\n return lineStringCoordinateAtM(\n flatCoordinates,\n offset,\n end,\n stride,\n m,\n false,\n );\n }\n offset = end;\n }\n return null;\n}\n","/**\n * @module ol/geom/flat/intersectsextent\n */\nimport {\n containsExtent,\n createEmpty,\n extendFlatCoordinates,\n intersects,\n intersectsSegment,\n} from '../../extent.js';\nimport {forEach as forEachSegment} from './segments.js';\nimport {linearRingContainsExtent, linearRingContainsXY} from './contains.js';\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @return {boolean} True if the geometry and the extent intersect.\n */\nexport function intersectsLineString(\n flatCoordinates,\n offset,\n end,\n stride,\n extent,\n) {\n const coordinatesExtent = extendFlatCoordinates(\n createEmpty(),\n flatCoordinates,\n offset,\n end,\n stride,\n );\n if (!intersects(extent, coordinatesExtent)) {\n return false;\n }\n if (containsExtent(extent, coordinatesExtent)) {\n return true;\n }\n if (coordinatesExtent[0] >= extent[0] && coordinatesExtent[2] <= extent[2]) {\n return true;\n }\n if (coordinatesExtent[1] >= extent[1] && coordinatesExtent[3] <= extent[3]) {\n return true;\n }\n return forEachSegment(\n flatCoordinates,\n offset,\n end,\n stride,\n /**\n * @param {import(\"../../coordinate.js\").Coordinate} point1 Start point.\n * @param {import(\"../../coordinate.js\").Coordinate} point2 End point.\n * @return {boolean} `true` if the segment and the extent intersect,\n * `false` otherwise.\n */\n function (point1, point2) {\n return intersectsSegment(extent, point1, point2);\n },\n );\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array} ends Ends.\n * @param {number} stride Stride.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @return {boolean} True if the geometry and the extent intersect.\n */\nexport function intersectsLineStringArray(\n flatCoordinates,\n offset,\n ends,\n stride,\n extent,\n) {\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n if (\n intersectsLineString(flatCoordinates, offset, ends[i], stride, extent)\n ) {\n return true;\n }\n offset = ends[i];\n }\n return false;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @return {boolean} True if the geometry and the extent intersect.\n */\nexport function intersectsLinearRing(\n flatCoordinates,\n offset,\n end,\n stride,\n extent,\n) {\n if (intersectsLineString(flatCoordinates, offset, end, stride, extent)) {\n return true;\n }\n if (\n linearRingContainsXY(\n flatCoordinates,\n offset,\n end,\n stride,\n extent[0],\n extent[1],\n )\n ) {\n return true;\n }\n if (\n linearRingContainsXY(\n flatCoordinates,\n offset,\n end,\n stride,\n extent[0],\n extent[3],\n )\n ) {\n return true;\n }\n if (\n linearRingContainsXY(\n flatCoordinates,\n offset,\n end,\n stride,\n extent[2],\n extent[1],\n )\n ) {\n return true;\n }\n if (\n linearRingContainsXY(\n flatCoordinates,\n offset,\n end,\n stride,\n extent[2],\n extent[3],\n )\n ) {\n return true;\n }\n return false;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array} ends Ends.\n * @param {number} stride Stride.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @return {boolean} True if the geometry and the extent intersect.\n */\nexport function intersectsLinearRingArray(\n flatCoordinates,\n offset,\n ends,\n stride,\n extent,\n) {\n if (!intersectsLinearRing(flatCoordinates, offset, ends[0], stride, extent)) {\n return false;\n }\n if (ends.length === 1) {\n return true;\n }\n for (let i = 1, ii = ends.length; i < ii; ++i) {\n if (\n linearRingContainsExtent(\n flatCoordinates,\n ends[i - 1],\n ends[i],\n stride,\n extent,\n )\n ) {\n if (\n !intersectsLineString(\n flatCoordinates,\n ends[i - 1],\n ends[i],\n stride,\n extent,\n )\n ) {\n return false;\n }\n }\n }\n return true;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array>} endss Endss.\n * @param {number} stride Stride.\n * @param {import(\"../../extent.js\").Extent} extent Extent.\n * @return {boolean} True if the geometry and the extent intersect.\n */\nexport function intersectsLinearRingMultiArray(\n flatCoordinates,\n offset,\n endss,\n stride,\n extent,\n) {\n for (let i = 0, ii = endss.length; i < ii; ++i) {\n const ends = endss[i];\n if (\n intersectsLinearRingArray(flatCoordinates, offset, ends, stride, extent)\n ) {\n return true;\n }\n offset = ends[ends.length - 1];\n }\n return false;\n}\n","/**\n * @module ol/geom/flat/length\n */\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @return {number} Length.\n */\nexport function lineStringLength(flatCoordinates, offset, end, stride) {\n let x1 = flatCoordinates[offset];\n let y1 = flatCoordinates[offset + 1];\n let length = 0;\n for (let i = offset + stride; i < end; i += stride) {\n const x2 = flatCoordinates[i];\n const y2 = flatCoordinates[i + 1];\n length += Math.sqrt((x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1));\n x1 = x2;\n y1 = y2;\n }\n return length;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @return {number} Perimeter.\n */\nexport function linearRingLength(flatCoordinates, offset, end, stride) {\n let perimeter = lineStringLength(flatCoordinates, offset, end, stride);\n const dx = flatCoordinates[end - stride] - flatCoordinates[offset];\n const dy = flatCoordinates[end - stride + 1] - flatCoordinates[offset + 1];\n perimeter += Math.sqrt(dx * dx + dy * dy);\n return perimeter;\n}\n","/**\n * @module ol/geom/flat/reverse\n */\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n */\nexport function coordinates(flatCoordinates, offset, end, stride) {\n while (offset < end - stride) {\n for (let i = 0; i < stride; ++i) {\n const tmp = flatCoordinates[offset + i];\n flatCoordinates[offset + i] = flatCoordinates[end - stride + i];\n flatCoordinates[end - stride + i] = tmp;\n }\n offset += stride;\n end -= stride;\n }\n}\n","/**\n * @module ol/geom/flat/orient\n */\nimport {coordinates as reverseCoordinates} from './reverse.js';\n\n/**\n * Is the linear ring oriented clockwise in a coordinate system with a bottom-left\n * coordinate origin? For a coordinate system with a top-left coordinate origin,\n * the ring's orientation is clockwise when this function returns false.\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @return {boolean|undefined} Is clockwise.\n */\nexport function linearRingIsClockwise(flatCoordinates, offset, end, stride) {\n // https://stackoverflow.com/q/1165647/clockwise-method#1165943\n // https://github.com/OSGeo/gdal/blob/master/gdal/ogr/ogrlinearring.cpp\n let edge = 0;\n let x1 = flatCoordinates[end - stride];\n let y1 = flatCoordinates[end - stride + 1];\n for (; offset < end; offset += stride) {\n const x2 = flatCoordinates[offset];\n const y2 = flatCoordinates[offset + 1];\n edge += (x2 - x1) * (y2 + y1);\n x1 = x2;\n y1 = y2;\n }\n return edge === 0 ? undefined : edge > 0;\n}\n\n/**\n * Determines if linear rings are oriented. By default, left-hand orientation\n * is tested (first ring must be clockwise, remaining rings counter-clockwise).\n * To test for right-hand orientation, use the `right` argument.\n *\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array} ends Array of end indexes.\n * @param {number} stride Stride.\n * @param {boolean} [right] Test for right-hand orientation\n * (counter-clockwise exterior ring and clockwise interior rings).\n * @return {boolean} Rings are correctly oriented.\n */\nexport function linearRingsAreOriented(\n flatCoordinates,\n offset,\n ends,\n stride,\n right,\n) {\n right = right !== undefined ? right : false;\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n const end = ends[i];\n const isClockwise = linearRingIsClockwise(\n flatCoordinates,\n offset,\n end,\n stride,\n );\n if (i === 0) {\n if ((right && isClockwise) || (!right && !isClockwise)) {\n return false;\n }\n } else {\n if ((right && !isClockwise) || (!right && isClockwise)) {\n return false;\n }\n }\n offset = end;\n }\n return true;\n}\n\n/**\n * Determines if linear rings are oriented. By default, left-hand orientation\n * is tested (first ring must be clockwise, remaining rings counter-clockwise).\n * To test for right-hand orientation, use the `right` argument.\n *\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array>} endss Array of array of end indexes.\n * @param {number} stride Stride.\n * @param {boolean} [right] Test for right-hand orientation\n * (counter-clockwise exterior ring and clockwise interior rings).\n * @return {boolean} Rings are correctly oriented.\n */\nexport function linearRingssAreOriented(\n flatCoordinates,\n offset,\n endss,\n stride,\n right,\n) {\n for (let i = 0, ii = endss.length; i < ii; ++i) {\n const ends = endss[i];\n if (!linearRingsAreOriented(flatCoordinates, offset, ends, stride, right)) {\n return false;\n }\n if (ends.length) {\n offset = ends[ends.length - 1];\n }\n }\n return true;\n}\n\n/**\n * Orient coordinates in a flat array of linear rings. By default, rings\n * are oriented following the left-hand rule (clockwise for exterior and\n * counter-clockwise for interior rings). To orient according to the\n * right-hand rule, use the `right` argument.\n *\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array} ends Ends.\n * @param {number} stride Stride.\n * @param {boolean} [right] Follow the right-hand rule for orientation.\n * @return {number} End.\n */\nexport function orientLinearRings(\n flatCoordinates,\n offset,\n ends,\n stride,\n right,\n) {\n right = right !== undefined ? right : false;\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n const end = ends[i];\n const isClockwise = linearRingIsClockwise(\n flatCoordinates,\n offset,\n end,\n stride,\n );\n const reverse =\n i === 0\n ? (right && isClockwise) || (!right && !isClockwise)\n : (right && !isClockwise) || (!right && isClockwise);\n if (reverse) {\n reverseCoordinates(flatCoordinates, offset, end, stride);\n }\n offset = end;\n }\n return offset;\n}\n\n/**\n * Orient coordinates in a flat array of linear rings. By default, rings\n * are oriented following the left-hand rule (clockwise for exterior and\n * counter-clockwise for interior rings). To orient according to the\n * right-hand rule, use the `right` argument.\n *\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array>} endss Array of array of end indexes.\n * @param {number} stride Stride.\n * @param {boolean} [right] Follow the right-hand rule for orientation.\n * @return {number} End.\n */\nexport function orientLinearRingsArray(\n flatCoordinates,\n offset,\n endss,\n stride,\n right,\n) {\n for (let i = 0, ii = endss.length; i < ii; ++i) {\n offset = orientLinearRings(\n flatCoordinates,\n offset,\n endss[i],\n stride,\n right,\n );\n }\n return offset;\n}\n\n/**\n * Return a two-dimensional endss\n * @param {Array} flatCoordinates Flat coordinates\n * @param {Array} ends Linear ring end indexes\n * @return {Array>} Two dimensional endss array that can\n * be used to construct a MultiPolygon\n */\nexport function inflateEnds(flatCoordinates, ends) {\n const endss = [];\n let offset = 0;\n let prevEndIndex = 0;\n let startOrientation;\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n const end = ends[i];\n // classifies an array of rings into polygons with outer rings and holes\n const orientation = linearRingIsClockwise(flatCoordinates, offset, end, 2);\n if (startOrientation === undefined) {\n startOrientation = orientation;\n }\n if (orientation === startOrientation) {\n endss.push(ends.slice(prevEndIndex, i + 1));\n } else {\n if (endss.length === 0) {\n continue;\n }\n endss[endss.length - 1].push(ends[prevEndIndex]);\n }\n prevEndIndex = i + 1;\n offset = end;\n }\n return endss;\n}\n","/**\n * @module ol/geom/flat/segments\n */\n\n/**\n * This function calls `callback` for each segment of the flat coordinates\n * array. If the callback returns a truthy value the function returns that\n * value immediately. Otherwise the function returns `false`.\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {function(import(\"../../coordinate.js\").Coordinate, import(\"../../coordinate.js\").Coordinate): T} callback Function\n * called for each segment.\n * @return {T|boolean} Value.\n * @template T\n */\nexport function forEach(flatCoordinates, offset, end, stride, callback) {\n let ret;\n offset += stride;\n for (; offset < end; offset += stride) {\n ret = callback(\n flatCoordinates.slice(offset - stride, offset),\n flatCoordinates.slice(offset, offset + stride),\n );\n if (ret) {\n return ret;\n }\n }\n return false;\n}\n","/**\n * @module ol/geom/flat/simplify\n */\n// Based on simplify-js https://github.com/mourner/simplify-js\n// Copyright (c) 2012, Vladimir Agafonkin\n// All rights reserved.\n//\n// Redistribution and use in source and binary forms, with or without\n// modification, are permitted provided that the following conditions are met:\n//\n// 1. Redistributions of source code must retain the above copyright notice,\n// this list of conditions and the following disclaimer.\n//\n// 2. Redistributions in binary form must reproduce the above copyright\n// notice, this list of conditions and the following disclaimer in the\n// documentation and/or other materials provided with the distribution.\n//\n// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\n// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE\n// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR\n// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF\n// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS\n// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN\n// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\n// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\n// POSSIBILITY OF SUCH DAMAGE.\n\nimport {squaredDistance, squaredSegmentDistance} from '../../math.js';\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {boolean} highQuality Highest quality.\n * @param {Array} [simplifiedFlatCoordinates] Simplified flat\n * coordinates.\n * @return {Array} Simplified line string.\n */\nexport function simplifyLineString(\n flatCoordinates,\n offset,\n end,\n stride,\n squaredTolerance,\n highQuality,\n simplifiedFlatCoordinates,\n) {\n simplifiedFlatCoordinates =\n simplifiedFlatCoordinates !== undefined ? simplifiedFlatCoordinates : [];\n if (!highQuality) {\n end = radialDistance(\n flatCoordinates,\n offset,\n end,\n stride,\n squaredTolerance,\n simplifiedFlatCoordinates,\n 0,\n );\n flatCoordinates = simplifiedFlatCoordinates;\n offset = 0;\n stride = 2;\n }\n simplifiedFlatCoordinates.length = douglasPeucker(\n flatCoordinates,\n offset,\n end,\n stride,\n squaredTolerance,\n simplifiedFlatCoordinates,\n 0,\n );\n return simplifiedFlatCoordinates;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {Array} simplifiedFlatCoordinates Simplified flat\n * coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @return {number} Simplified offset.\n */\nexport function douglasPeucker(\n flatCoordinates,\n offset,\n end,\n stride,\n squaredTolerance,\n simplifiedFlatCoordinates,\n simplifiedOffset,\n) {\n const n = (end - offset) / stride;\n if (n < 3) {\n for (; offset < end; offset += stride) {\n simplifiedFlatCoordinates[simplifiedOffset++] = flatCoordinates[offset];\n simplifiedFlatCoordinates[simplifiedOffset++] =\n flatCoordinates[offset + 1];\n }\n return simplifiedOffset;\n }\n /** @type {Array} */\n const markers = new Array(n);\n markers[0] = 1;\n markers[n - 1] = 1;\n /** @type {Array} */\n const stack = [offset, end - stride];\n let index = 0;\n while (stack.length > 0) {\n const last = stack.pop();\n const first = stack.pop();\n let maxSquaredDistance = 0;\n const x1 = flatCoordinates[first];\n const y1 = flatCoordinates[first + 1];\n const x2 = flatCoordinates[last];\n const y2 = flatCoordinates[last + 1];\n for (let i = first + stride; i < last; i += stride) {\n const x = flatCoordinates[i];\n const y = flatCoordinates[i + 1];\n const squaredDistance = squaredSegmentDistance(x, y, x1, y1, x2, y2);\n if (squaredDistance > maxSquaredDistance) {\n index = i;\n maxSquaredDistance = squaredDistance;\n }\n }\n if (maxSquaredDistance > squaredTolerance) {\n markers[(index - offset) / stride] = 1;\n if (first + stride < index) {\n stack.push(first, index);\n }\n if (index + stride < last) {\n stack.push(index, last);\n }\n }\n }\n for (let i = 0; i < n; ++i) {\n if (markers[i]) {\n simplifiedFlatCoordinates[simplifiedOffset++] =\n flatCoordinates[offset + i * stride];\n simplifiedFlatCoordinates[simplifiedOffset++] =\n flatCoordinates[offset + i * stride + 1];\n }\n }\n return simplifiedOffset;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array} ends Ends.\n * @param {number} stride Stride.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {Array} simplifiedFlatCoordinates Simplified flat\n * coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @param {Array} simplifiedEnds Simplified ends.\n * @return {number} Simplified offset.\n */\nexport function douglasPeuckerArray(\n flatCoordinates,\n offset,\n ends,\n stride,\n squaredTolerance,\n simplifiedFlatCoordinates,\n simplifiedOffset,\n simplifiedEnds,\n) {\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n const end = ends[i];\n simplifiedOffset = douglasPeucker(\n flatCoordinates,\n offset,\n end,\n stride,\n squaredTolerance,\n simplifiedFlatCoordinates,\n simplifiedOffset,\n );\n simplifiedEnds.push(simplifiedOffset);\n offset = end;\n }\n return simplifiedOffset;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array>} endss Endss.\n * @param {number} stride Stride.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {Array} simplifiedFlatCoordinates Simplified flat\n * coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @param {Array>} simplifiedEndss Simplified endss.\n * @return {number} Simplified offset.\n */\nexport function douglasPeuckerMultiArray(\n flatCoordinates,\n offset,\n endss,\n stride,\n squaredTolerance,\n simplifiedFlatCoordinates,\n simplifiedOffset,\n simplifiedEndss,\n) {\n for (let i = 0, ii = endss.length; i < ii; ++i) {\n const ends = endss[i];\n /** @type {Array} */\n const simplifiedEnds = [];\n simplifiedOffset = douglasPeuckerArray(\n flatCoordinates,\n offset,\n ends,\n stride,\n squaredTolerance,\n simplifiedFlatCoordinates,\n simplifiedOffset,\n simplifiedEnds,\n );\n simplifiedEndss.push(simplifiedEnds);\n offset = ends[ends.length - 1];\n }\n return simplifiedOffset;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} squaredTolerance Squared tolerance.\n * @param {Array} simplifiedFlatCoordinates Simplified flat\n * coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @return {number} Simplified offset.\n */\nexport function radialDistance(\n flatCoordinates,\n offset,\n end,\n stride,\n squaredTolerance,\n simplifiedFlatCoordinates,\n simplifiedOffset,\n) {\n if (end <= offset + stride) {\n // zero or one point, no simplification possible, so copy and return\n for (; offset < end; offset += stride) {\n simplifiedFlatCoordinates[simplifiedOffset++] = flatCoordinates[offset];\n simplifiedFlatCoordinates[simplifiedOffset++] =\n flatCoordinates[offset + 1];\n }\n return simplifiedOffset;\n }\n let x1 = flatCoordinates[offset];\n let y1 = flatCoordinates[offset + 1];\n // copy first point\n simplifiedFlatCoordinates[simplifiedOffset++] = x1;\n simplifiedFlatCoordinates[simplifiedOffset++] = y1;\n let x2 = x1;\n let y2 = y1;\n for (offset += stride; offset < end; offset += stride) {\n x2 = flatCoordinates[offset];\n y2 = flatCoordinates[offset + 1];\n if (squaredDistance(x1, y1, x2, y2) > squaredTolerance) {\n // copy point at offset\n simplifiedFlatCoordinates[simplifiedOffset++] = x2;\n simplifiedFlatCoordinates[simplifiedOffset++] = y2;\n x1 = x2;\n y1 = y2;\n }\n }\n if (x2 != x1 || y2 != y1) {\n // copy last point\n simplifiedFlatCoordinates[simplifiedOffset++] = x2;\n simplifiedFlatCoordinates[simplifiedOffset++] = y2;\n }\n return simplifiedOffset;\n}\n\n/**\n * @param {number} value Value.\n * @param {number} tolerance Tolerance.\n * @return {number} Rounded value.\n */\nexport function snap(value, tolerance) {\n return tolerance * Math.round(value / tolerance);\n}\n\n/**\n * Simplifies a line string using an algorithm designed by Tim Schaub.\n * Coordinates are snapped to the nearest value in a virtual grid and\n * consecutive duplicate coordinates are discarded. This effectively preserves\n * topology as the simplification of any subsection of a line string is\n * independent of the rest of the line string. This means that, for examples,\n * the common edge between two polygons will be simplified to the same line\n * string independently in both polygons. This implementation uses a single\n * pass over the coordinates and eliminates intermediate collinear points.\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} tolerance Tolerance.\n * @param {Array} simplifiedFlatCoordinates Simplified flat\n * coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @return {number} Simplified offset.\n */\nexport function quantize(\n flatCoordinates,\n offset,\n end,\n stride,\n tolerance,\n simplifiedFlatCoordinates,\n simplifiedOffset,\n) {\n // do nothing if the line is empty\n if (offset == end) {\n return simplifiedOffset;\n }\n // snap the first coordinate (P1)\n let x1 = snap(flatCoordinates[offset], tolerance);\n let y1 = snap(flatCoordinates[offset + 1], tolerance);\n offset += stride;\n // add the first coordinate to the output\n simplifiedFlatCoordinates[simplifiedOffset++] = x1;\n simplifiedFlatCoordinates[simplifiedOffset++] = y1;\n // find the next coordinate that does not snap to the same value as the first\n // coordinate (P2)\n let x2, y2;\n do {\n x2 = snap(flatCoordinates[offset], tolerance);\n y2 = snap(flatCoordinates[offset + 1], tolerance);\n offset += stride;\n if (offset == end) {\n // all coordinates snap to the same value, the line collapses to a point\n // push the last snapped value anyway to ensure that the output contains\n // at least two points\n // FIXME should we really return at least two points anyway?\n simplifiedFlatCoordinates[simplifiedOffset++] = x2;\n simplifiedFlatCoordinates[simplifiedOffset++] = y2;\n return simplifiedOffset;\n }\n } while (x2 == x1 && y2 == y1);\n while (offset < end) {\n // snap the next coordinate (P3)\n const x3 = snap(flatCoordinates[offset], tolerance);\n const y3 = snap(flatCoordinates[offset + 1], tolerance);\n offset += stride;\n // skip P3 if it is equal to P2\n if (x3 == x2 && y3 == y2) {\n continue;\n }\n // calculate the delta between P1 and P2\n const dx1 = x2 - x1;\n const dy1 = y2 - y1;\n // calculate the delta between P3 and P1\n const dx2 = x3 - x1;\n const dy2 = y3 - y1;\n // if P1, P2, and P3 are colinear and P3 is further from P1 than P2 is from\n // P1 in the same direction then P2 is on the straight line between P1 and\n // P3\n if (\n dx1 * dy2 == dy1 * dx2 &&\n ((dx1 < 0 && dx2 < dx1) || dx1 == dx2 || (dx1 > 0 && dx2 > dx1)) &&\n ((dy1 < 0 && dy2 < dy1) || dy1 == dy2 || (dy1 > 0 && dy2 > dy1))\n ) {\n // discard P2 and set P2 = P3\n x2 = x3;\n y2 = y3;\n continue;\n }\n // either P1, P2, and P3 are not colinear, or they are colinear but P3 is\n // between P3 and P1 or on the opposite half of the line to P2. add P2,\n // and continue with P1 = P2 and P2 = P3\n simplifiedFlatCoordinates[simplifiedOffset++] = x2;\n simplifiedFlatCoordinates[simplifiedOffset++] = y2;\n x1 = x2;\n y1 = y2;\n x2 = x3;\n y2 = y3;\n }\n // add the last point (P2)\n simplifiedFlatCoordinates[simplifiedOffset++] = x2;\n simplifiedFlatCoordinates[simplifiedOffset++] = y2;\n return simplifiedOffset;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array} ends Ends.\n * @param {number} stride Stride.\n * @param {number} tolerance Tolerance.\n * @param {Array} simplifiedFlatCoordinates Simplified flat\n * coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @param {Array} simplifiedEnds Simplified ends.\n * @return {number} Simplified offset.\n */\nexport function quantizeArray(\n flatCoordinates,\n offset,\n ends,\n stride,\n tolerance,\n simplifiedFlatCoordinates,\n simplifiedOffset,\n simplifiedEnds,\n) {\n for (let i = 0, ii = ends.length; i < ii; ++i) {\n const end = ends[i];\n simplifiedOffset = quantize(\n flatCoordinates,\n offset,\n end,\n stride,\n tolerance,\n simplifiedFlatCoordinates,\n simplifiedOffset,\n );\n simplifiedEnds.push(simplifiedOffset);\n offset = end;\n }\n return simplifiedOffset;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {Array>} endss Endss.\n * @param {number} stride Stride.\n * @param {number} tolerance Tolerance.\n * @param {Array} simplifiedFlatCoordinates Simplified flat\n * coordinates.\n * @param {number} simplifiedOffset Simplified offset.\n * @param {Array>} simplifiedEndss Simplified endss.\n * @return {number} Simplified offset.\n */\nexport function quantizeMultiArray(\n flatCoordinates,\n offset,\n endss,\n stride,\n tolerance,\n simplifiedFlatCoordinates,\n simplifiedOffset,\n simplifiedEndss,\n) {\n for (let i = 0, ii = endss.length; i < ii; ++i) {\n const ends = endss[i];\n /** @type {Array} */\n const simplifiedEnds = [];\n simplifiedOffset = quantizeArray(\n flatCoordinates,\n offset,\n ends,\n stride,\n tolerance,\n simplifiedFlatCoordinates,\n simplifiedOffset,\n simplifiedEnds,\n );\n simplifiedEndss.push(simplifiedEnds);\n offset = ends[ends.length - 1];\n }\n return simplifiedOffset;\n}\n","/**\n * @module ol/geom/flat/transform\n */\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {import(\"../../transform.js\").Transform} transform Transform.\n * @param {Array} [dest] Destination.\n * @return {Array} Transformed coordinates.\n */\nexport function transform2D(\n flatCoordinates,\n offset,\n end,\n stride,\n transform,\n dest,\n) {\n dest = dest ? dest : [];\n let i = 0;\n for (let j = offset; j < end; j += stride) {\n const x = flatCoordinates[j];\n const y = flatCoordinates[j + 1];\n dest[i++] = transform[0] * x + transform[2] * y + transform[4];\n dest[i++] = transform[1] * x + transform[3] * y + transform[5];\n }\n if (dest && dest.length != i) {\n dest.length = i;\n }\n return dest;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} angle Angle.\n * @param {Array} anchor Rotation anchor point.\n * @param {Array} [dest] Destination.\n * @return {Array} Transformed coordinates.\n */\nexport function rotate(\n flatCoordinates,\n offset,\n end,\n stride,\n angle,\n anchor,\n dest,\n) {\n dest = dest ? dest : [];\n const cos = Math.cos(angle);\n const sin = Math.sin(angle);\n const anchorX = anchor[0];\n const anchorY = anchor[1];\n let i = 0;\n for (let j = offset; j < end; j += stride) {\n const deltaX = flatCoordinates[j] - anchorX;\n const deltaY = flatCoordinates[j + 1] - anchorY;\n dest[i++] = anchorX + deltaX * cos - deltaY * sin;\n dest[i++] = anchorY + deltaX * sin + deltaY * cos;\n for (let k = j + 2; k < j + stride; ++k) {\n dest[i++] = flatCoordinates[k];\n }\n }\n if (dest && dest.length != i) {\n dest.length = i;\n }\n return dest;\n}\n\n/**\n * Scale the coordinates.\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} sx Scale factor in the x-direction.\n * @param {number} sy Scale factor in the y-direction.\n * @param {Array} anchor Scale anchor point.\n * @param {Array} [dest] Destination.\n * @return {Array} Transformed coordinates.\n */\nexport function scale(\n flatCoordinates,\n offset,\n end,\n stride,\n sx,\n sy,\n anchor,\n dest,\n) {\n dest = dest ? dest : [];\n const anchorX = anchor[0];\n const anchorY = anchor[1];\n let i = 0;\n for (let j = offset; j < end; j += stride) {\n const deltaX = flatCoordinates[j] - anchorX;\n const deltaY = flatCoordinates[j + 1] - anchorY;\n dest[i++] = anchorX + sx * deltaX;\n dest[i++] = anchorY + sy * deltaY;\n for (let k = j + 2; k < j + stride; ++k) {\n dest[i++] = flatCoordinates[k];\n }\n }\n if (dest && dest.length != i) {\n dest.length = i;\n }\n return dest;\n}\n\n/**\n * @param {Array} flatCoordinates Flat coordinates.\n * @param {number} offset Offset.\n * @param {number} end End.\n * @param {number} stride Stride.\n * @param {number} deltaX Delta X.\n * @param {number} deltaY Delta Y.\n * @param {Array} [dest] Destination.\n * @return {Array} Transformed coordinates.\n */\nexport function translate(\n flatCoordinates,\n offset,\n end,\n stride,\n deltaX,\n deltaY,\n dest,\n) {\n dest = dest ? dest : [];\n let i = 0;\n for (let j = offset; j < end; j += stride) {\n dest[i++] = flatCoordinates[j] + deltaX;\n dest[i++] = flatCoordinates[j + 1] + deltaY;\n for (let k = j + 2; k < j + stride; ++k) {\n dest[i++] = flatCoordinates[k];\n }\n }\n if (dest && dest.length != i) {\n dest.length = i;\n }\n return dest;\n}\n","/**\n * @module ol/has\n */\n\nconst ua =\n typeof navigator !== 'undefined' && typeof navigator.userAgent !== 'undefined'\n ? navigator.userAgent.toLowerCase()\n : '';\n\n/**\n * User agent string says we are dealing with Firefox as browser.\n * @type {boolean}\n */\nexport const FIREFOX = ua.includes('firefox');\n\n/**\n * User agent string says we are dealing with Safari as browser.\n * @type {boolean}\n */\nexport const SAFARI = ua.includes('safari') && !ua.includes('chrom');\n\n/**\n * https://bugs.webkit.org/show_bug.cgi?id=237906\n * @type {boolean}\n */\nexport const SAFARI_BUG_237906 =\n SAFARI &&\n (ua.includes('version/15.4') ||\n /cpu (os|iphone os) 15_4 like mac os x/.test(ua));\n\n/**\n * User agent string says we are dealing with a WebKit engine.\n * @type {boolean}\n */\nexport const WEBKIT = ua.includes('webkit') && !ua.includes('edge');\n\n/**\n * User agent string says we are dealing with a Mac as platform.\n * @type {boolean}\n */\nexport const MAC = ua.includes('macintosh');\n\n/**\n * The ratio between physical pixels and device-independent pixels\n * (dips) on the device (`window.devicePixelRatio`).\n * @const\n * @type {number}\n * @api\n */\nexport const DEVICE_PIXEL_RATIO =\n typeof devicePixelRatio !== 'undefined' ? devicePixelRatio : 1;\n\n/**\n * The execution context is a worker with OffscreenCanvas available.\n * @const\n * @type {boolean}\n */\nexport const WORKER_OFFSCREEN_CANVAS =\n typeof WorkerGlobalScope !== 'undefined' &&\n typeof OffscreenCanvas !== 'undefined' &&\n self instanceof WorkerGlobalScope; //eslint-disable-line\n\n/**\n * Image.prototype.decode() is supported.\n * @type {boolean}\n */\nexport const IMAGE_DECODE =\n typeof Image !== 'undefined' && Image.prototype.decode;\n\n/**\n * createImageBitmap() is supported.\n * @type {boolean}\n */\nexport const CREATE_IMAGE_BITMAP = typeof createImageBitmap === 'function';\n\n/**\n * @type {boolean}\n */\nexport const PASSIVE_EVENT_LISTENERS = (function () {\n let passive = false;\n try {\n const options = Object.defineProperty({}, 'passive', {\n get: function () {\n passive = true;\n },\n });\n\n // @ts-ignore Ignore invalid event type '_'\n window.addEventListener('_', null, options);\n // @ts-ignore Ignore invalid event type '_'\n window.removeEventListener('_', null, options);\n } catch (error) {\n // passive not supported\n }\n return passive;\n})();\n","/**\n * @module ol/layer/Base\n */\nimport BaseObject from '../Object.js';\nimport LayerProperty from './Property.js';\nimport {abstract} from '../util.js';\nimport {assert} from '../asserts.js';\nimport {clamp} from '../math.js';\n\n/**\n * A css color, or a function called with a view resolution returning a css color.\n *\n * @typedef {string|function(number):string} BackgroundColor\n * @api\n */\n\n/**\n * @typedef {import(\"../ObjectEventType\").Types|'change:extent'|'change:maxResolution'|'change:maxZoom'|\n * 'change:minResolution'|'change:minZoom'|'change:opacity'|'change:visible'|'change:zIndex'} BaseLayerObjectEventTypes\n */\n\n/***\n * @template Return\n * @typedef {import(\"../Observable\").OnSignature &\n * import(\"../Observable\").OnSignature &\n * import(\"../Observable\").CombinedOnSignature} BaseLayerOnSignature\n */\n\n/**\n * @typedef {Object} Options\n * @property {string} [className='ol-layer'] A CSS class name to set to the layer element.\n * @property {number} [opacity=1] Opacity (0, 1).\n * @property {boolean} [visible=true] Visibility.\n * @property {import(\"../extent.js\").Extent} [extent] The bounding extent for layer rendering. The layer will not be\n * rendered outside of this extent.\n * @property {number | undefined} [zIndex] The z-index for layer rendering. At rendering time, the layers\n * will be ordered, first by Z-index and then by position. When `undefined`, a `zIndex` of 0 is assumed\n * for layers that are added to the map's `layers` collection, or `Infinity` when the layer's `setMap()`\n * method was used.\n * @property {number} [minResolution] The minimum resolution (inclusive) at which this layer will be\n * visible.\n * @property {number} [maxResolution] The maximum resolution (exclusive) below which this layer will\n * be visible.\n * @property {number} [minZoom] The minimum view zoom level (exclusive) above which this layer will be\n * visible.\n * @property {number} [maxZoom] The maximum view zoom level (inclusive) at which this layer will\n * be visible.\n * @property {BackgroundColor} [background] Background color for the layer. If not specified, no background\n * will be rendered.\n * @property {Object} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @classdesc\n * Abstract base class; normally only used for creating subclasses and not\n * instantiated in apps.\n * Note that with {@link module:ol/layer/Base~BaseLayer} and all its subclasses, any property set in\n * the options is set as a {@link module:ol/Object~BaseObject} property on the layer object, so\n * is observable, and has get/set accessors.\n *\n * @api\n */\nclass BaseLayer extends BaseObject {\n /**\n * @param {Options} options Layer options.\n */\n constructor(options) {\n super();\n\n /***\n * @type {BaseLayerOnSignature}\n */\n this.on;\n\n /***\n * @type {BaseLayerOnSignature}\n */\n this.once;\n\n /***\n * @type {BaseLayerOnSignature}\n */\n this.un;\n\n /**\n * @type {BackgroundColor|false}\n * @private\n */\n this.background_ = options.background;\n\n /**\n * @type {Object}\n */\n const properties = Object.assign({}, options);\n if (typeof options.properties === 'object') {\n delete properties.properties;\n Object.assign(properties, options.properties);\n }\n\n properties[LayerProperty.OPACITY] =\n options.opacity !== undefined ? options.opacity : 1;\n assert(\n typeof properties[LayerProperty.OPACITY] === 'number',\n 'Layer opacity must be a number',\n );\n\n properties[LayerProperty.VISIBLE] =\n options.visible !== undefined ? options.visible : true;\n properties[LayerProperty.Z_INDEX] = options.zIndex;\n properties[LayerProperty.MAX_RESOLUTION] =\n options.maxResolution !== undefined ? options.maxResolution : Infinity;\n properties[LayerProperty.MIN_RESOLUTION] =\n options.minResolution !== undefined ? options.minResolution : 0;\n properties[LayerProperty.MIN_ZOOM] =\n options.minZoom !== undefined ? options.minZoom : -Infinity;\n properties[LayerProperty.MAX_ZOOM] =\n options.maxZoom !== undefined ? options.maxZoom : Infinity;\n\n /**\n * @type {string}\n * @private\n */\n this.className_ =\n properties.className !== undefined ? properties.className : 'ol-layer';\n delete properties.className;\n\n this.setProperties(properties);\n\n /**\n * @type {import(\"./Layer.js\").State}\n * @private\n */\n this.state_ = null;\n }\n\n /**\n * Get the background for this layer.\n * @return {BackgroundColor|false} Layer background.\n */\n getBackground() {\n return this.background_;\n }\n\n /**\n * @return {string} CSS class name.\n */\n getClassName() {\n return this.className_;\n }\n\n /**\n * This method is not meant to be called by layers or layer renderers because the state\n * is incorrect if the layer is included in a layer group.\n *\n * @param {boolean} [managed] Layer is managed.\n * @return {import(\"./Layer.js\").State} Layer state.\n */\n getLayerState(managed) {\n /** @type {import(\"./Layer.js\").State} */\n const state =\n this.state_ ||\n /** @type {?} */ ({\n layer: this,\n managed: managed === undefined ? true : managed,\n });\n const zIndex = this.getZIndex();\n state.opacity = clamp(Math.round(this.getOpacity() * 100) / 100, 0, 1);\n state.visible = this.getVisible();\n state.extent = this.getExtent();\n state.zIndex = zIndex === undefined && !state.managed ? Infinity : zIndex;\n state.maxResolution = this.getMaxResolution();\n state.minResolution = Math.max(this.getMinResolution(), 0);\n state.minZoom = this.getMinZoom();\n state.maxZoom = this.getMaxZoom();\n this.state_ = state;\n\n return state;\n }\n\n /**\n * @abstract\n * @param {Array} [array] Array of layers (to be\n * modified in place).\n * @return {Array} Array of layers.\n */\n getLayersArray(array) {\n return abstract();\n }\n\n /**\n * @abstract\n * @param {Array} [states] Optional list of layer\n * states (to be modified in place).\n * @return {Array} List of layer states.\n */\n getLayerStatesArray(states) {\n return abstract();\n }\n\n /**\n * Return the {@link module:ol/extent~Extent extent} of the layer or `undefined` if it\n * will be visible regardless of extent.\n * @return {import(\"../extent.js\").Extent|undefined} The layer extent.\n * @observable\n * @api\n */\n getExtent() {\n return /** @type {import(\"../extent.js\").Extent|undefined} */ (\n this.get(LayerProperty.EXTENT)\n );\n }\n\n /**\n * Return the maximum resolution of the layer. Returns Infinity if\n * the layer has no maximum resolution set.\n * @return {number} The maximum resolution of the layer.\n * @observable\n * @api\n */\n getMaxResolution() {\n return /** @type {number} */ (this.get(LayerProperty.MAX_RESOLUTION));\n }\n\n /**\n * Return the minimum resolution of the layer. Returns 0 if\n * the layer has no minimum resolution set.\n * @return {number} The minimum resolution of the layer.\n * @observable\n * @api\n */\n getMinResolution() {\n return /** @type {number} */ (this.get(LayerProperty.MIN_RESOLUTION));\n }\n\n /**\n * Return the minimum zoom level of the layer. Returns -Infinity if\n * the layer has no minimum zoom set.\n * @return {number} The minimum zoom level of the layer.\n * @observable\n * @api\n */\n getMinZoom() {\n return /** @type {number} */ (this.get(LayerProperty.MIN_ZOOM));\n }\n\n /**\n * Return the maximum zoom level of the layer. Returns Infinity if\n * the layer has no maximum zoom set.\n * @return {number} The maximum zoom level of the layer.\n * @observable\n * @api\n */\n getMaxZoom() {\n return /** @type {number} */ (this.get(LayerProperty.MAX_ZOOM));\n }\n\n /**\n * Return the opacity of the layer (between 0 and 1).\n * @return {number} The opacity of the layer.\n * @observable\n * @api\n */\n getOpacity() {\n return /** @type {number} */ (this.get(LayerProperty.OPACITY));\n }\n\n /**\n * @abstract\n * @return {import(\"../source/Source.js\").State} Source state.\n */\n getSourceState() {\n return abstract();\n }\n\n /**\n * Return the value of this layer's `visible` property. To find out whether the layer\n * is visible on a map, use `isVisible()` instead.\n * @return {boolean} The value of the `visible` property of the layer.\n * @observable\n * @api\n */\n getVisible() {\n return /** @type {boolean} */ (this.get(LayerProperty.VISIBLE));\n }\n\n /**\n * Return the Z-index of the layer, which is used to order layers before\n * rendering. Returns undefined if the layer is unmanaged.\n * @return {number|undefined} The Z-index of the layer.\n * @observable\n * @api\n */\n getZIndex() {\n return /** @type {number|undefined} */ (this.get(LayerProperty.Z_INDEX));\n }\n\n /**\n * Sets the background color.\n * @param {BackgroundColor} [background] Background color.\n */\n setBackground(background) {\n this.background_ = background;\n this.changed();\n }\n\n /**\n * Set the extent at which the layer is visible. If `undefined`, the layer\n * will be visible at all extents.\n * @param {import(\"../extent.js\").Extent|undefined} extent The extent of the layer.\n * @observable\n * @api\n */\n setExtent(extent) {\n this.set(LayerProperty.EXTENT, extent);\n }\n\n /**\n * Set the maximum resolution at which the layer is visible.\n * @param {number} maxResolution The maximum resolution of the layer.\n * @observable\n * @api\n */\n setMaxResolution(maxResolution) {\n this.set(LayerProperty.MAX_RESOLUTION, maxResolution);\n }\n\n /**\n * Set the minimum resolution at which the layer is visible.\n * @param {number} minResolution The minimum resolution of the layer.\n * @observable\n * @api\n */\n setMinResolution(minResolution) {\n this.set(LayerProperty.MIN_RESOLUTION, minResolution);\n }\n\n /**\n * Set the maximum zoom (exclusive) at which the layer is visible.\n * Note that the zoom levels for layer visibility are based on the\n * view zoom level, which may be different from a tile source zoom level.\n * @param {number} maxZoom The maximum zoom of the layer.\n * @observable\n * @api\n */\n setMaxZoom(maxZoom) {\n this.set(LayerProperty.MAX_ZOOM, maxZoom);\n }\n\n /**\n * Set the minimum zoom (inclusive) at which the layer is visible.\n * Note that the zoom levels for layer visibility are based on the\n * view zoom level, which may be different from a tile source zoom level.\n * @param {number} minZoom The minimum zoom of the layer.\n * @observable\n * @api\n */\n setMinZoom(minZoom) {\n this.set(LayerProperty.MIN_ZOOM, minZoom);\n }\n\n /**\n * Set the opacity of the layer, allowed values range from 0 to 1.\n * @param {number} opacity The opacity of the layer.\n * @observable\n * @api\n */\n setOpacity(opacity) {\n assert(typeof opacity === 'number', 'Layer opacity must be a number');\n this.set(LayerProperty.OPACITY, opacity);\n }\n\n /**\n * Set the visibility of the layer (`true` or `false`).\n * @param {boolean} visible The visibility of the layer.\n * @observable\n * @api\n */\n setVisible(visible) {\n this.set(LayerProperty.VISIBLE, visible);\n }\n\n /**\n * Set Z-index of the layer, which is used to order layers before rendering.\n * The default Z-index is 0.\n * @param {number} zindex The z-index of the layer.\n * @observable\n * @api\n */\n setZIndex(zindex) {\n this.set(LayerProperty.Z_INDEX, zindex);\n }\n\n /**\n * Clean up.\n * @override\n */\n disposeInternal() {\n if (this.state_) {\n this.state_.layer = null;\n this.state_ = null;\n }\n super.disposeInternal();\n }\n}\n\nexport default BaseLayer;\n","/**\n * @module ol/expr/expression\n */\nimport {ascending} from '../array.js';\nimport {fromString as colorFromString} from '../color.js';\nimport {toSize} from '../size.js';\n\n/**\n * @fileoverview This module includes types and functions for parsing array encoded expressions.\n * The result of parsing an encoded expression is one of the specific expression classes.\n * During parsing, information is added to the parsing context about the data accessed by the\n * expression.\n */\n\n/**\n * Base type used for literal style parameters; can be a number literal or the output of an operator,\n * which in turns takes {@link import(\"./expression.js\").ExpressionValue} arguments.\n *\n * See below for details on the available operators (with notes for those that are WebGL or Canvas only).\n *\n * * Reading operators:\n * * `['band', bandIndex, xOffset, yOffset]` For tile layers only. Fetches pixel values from band\n * `bandIndex` of the source's data. The first `bandIndex` of the source data is `1`. Fetched values\n * are in the 0..1 range. {@link import(\"../source/TileImage.js\").default} sources have 4 bands: red,\n * green, blue and alpha. {@link import(\"../source/DataTile.js\").default} sources can have any number\n * of bands, depending on the underlying data source and\n * {@link import(\"../source/GeoTIFF.js\").Options configuration}. `xOffset` and `yOffset` are optional\n * and allow specifying pixel offsets for x and y. This is used for sampling data from neighboring pixels (WebGL only).\n * * `['get', attributeName]` fetches a feature property value, similar to `feature.get('attributeName')`.\n * * `['get', attributeName, keyOrArrayIndex, ...]` (Canvas only) Access nested properties and array items of a\n * feature property. The result is `undefined` when there is nothing at the specified key or index.\n * * `['geometry-type']` returns a feature's geometry type as string, either: 'LineString', 'Point' or 'Polygon'\n * `Multi*` values are returned as their singular equivalent\n * `Circle` geometries are returned as 'Polygon'\n * `GeometryCollection` geometries are returned as the type of the first geometry found in the collection (WebGL only).\n * * `['resolution']` returns the current resolution\n * * `['time']` The time in seconds since the creation of the layer (WebGL only).\n * * `['var', 'varName']` fetches a value from the style variables; will throw an error if that variable is undefined\n * * `['zoom']` The current zoom level (WebGL only).\n *\n * * Math operators:\n * * `['*', value1, value2, ...]` multiplies the values (either numbers or colors)\n * * `['/', value1, value2]` divides `value1` by `value2`\n * * `['+', value1, value2, ...]` adds the values\n * * `['-', value1, value2]` subtracts `value2` from `value1`\n * * `['clamp', value, low, high]` clamps `value` between `low` and `high`\n * * `['%', value1, value2]` returns the result of `value1 % value2` (modulo)\n * * `['^', value1, value2]` returns the value of `value1` raised to the `value2` power\n * * `['abs', value1]` returns the absolute value of `value1`\n * * `['floor', value1]` returns the nearest integer less than or equal to `value1`\n * * `['round', value1]` returns the nearest integer to `value1`\n * * `['ceil', value1]` returns the nearest integer greater than or equal to `value1`\n * * `['sin', value1]` returns the sine of `value1`\n * * `['cos', value1]` returns the cosine of `value1`\n * * `['atan', value1, value2]` returns `atan2(value1, value2)`. If `value2` is not provided, returns `atan(value1)`\n * * `['sqrt', value1]` returns the square root of `value1`\n *\n * * Transform operators:\n * * `['case', condition1, output1, ...conditionN, outputN, fallback]` selects the first output whose corresponding\n * condition evaluates to `true`. If no match is found, returns the `fallback` value.\n * All conditions should be `boolean`, output and fallback can be any kind.\n * * `['match', input, match1, output1, ...matchN, outputN, fallback]` compares the `input` value against all\n * provided `matchX` values, returning the output associated with the first valid match. If no match is found,\n * returns the `fallback` value.\n * `input` and `matchX` values must all be of the same type, and can be `number` or `string`. `outputX` and\n * `fallback` values must be of the same type, and can be of any kind.\n * * `['interpolate', interpolation, input, stop1, output1, ...stopN, outputN]` returns a value by interpolating between\n * pairs of inputs and outputs; `interpolation` can either be `['linear']` or `['exponential', base]` where `base` is\n * the rate of increase from stop A to stop B (i.e. power to which the interpolation ratio is raised); a value\n * of 1 is equivalent to `['linear']`.\n * `input` and `stopX` values must all be of type `number`. `outputX` values can be `number` or `color` values.\n * Note: `input` will be clamped between `stop1` and `stopN`, meaning that all output values will be comprised\n * between `output1` and `outputN`.\n * * `['string', value1, value2, ...]` returns the first value in the list that evaluates to a string.\n * An example would be to provide a default value for get: `['string', ['get', 'propertyname'], 'default value']]`\n * (Canvas only).\n * * `['number', value1, value2, ...]` returns the first value in the list that evaluates to a number.\n * An example would be to provide a default value for get: `['string', ['get', 'propertyname'], 42]]`\n * (Canvas only).\n * * `['coalesce', value1, value2, ...]` returns the first value in the list which is not null or undefined.\n * An example would be to provide a default value for get: `['coalesce', ['get','propertyname'], 'default value']]`\n * (Canvas only).\n *\n * * Logical operators:\n * * `['<', value1, value2]` returns `true` if `value1` is strictly lower than `value2`, or `false` otherwise.\n * * `['<=', value1, value2]` returns `true` if `value1` is lower than or equals `value2`, or `false` otherwise.\n * * `['>', value1, value2]` returns `true` if `value1` is strictly greater than `value2`, or `false` otherwise.\n * * `['>=', value1, value2]` returns `true` if `value1` is greater than or equals `value2`, or `false` otherwise.\n * * `['==', value1, value2]` returns `true` if `value1` equals `value2`, or `false` otherwise.\n * * `['!=', value1, value2]` returns `true` if `value1` does not equal `value2`, or `false` otherwise.\n * * `['!', value1]` returns `false` if `value1` is `true` or greater than `0`, or `true` otherwise.\n * * `['all', value1, value2, ...]` returns `true` if all the inputs are `true`, `false` otherwise.\n * * `['any', value1, value2, ...]` returns `true` if any of the inputs are `true`, `false` otherwise.\n * * `['between', value1, value2, value3]` returns `true` if `value1` is contained between `value2` and `value3`\n * (inclusively), or `false` otherwise.\n * * `['in', needle, haystack]` returns `true` if `needle` is found in `haystack`, and\n * `false` otherwise.\n * This operator has the following limitations:\n * * `haystack` has to be an array of numbers or strings (searching for a substring in a string is not supported yet)\n * * Only literal arrays are supported as `haystack` for now; this means that `haystack` cannot be the result of an\n * expression. If `haystack` is an array of strings, use the `literal` operator to disambiguate from an expression:\n * `['literal', ['abc', 'def', 'ghi']]`\n *\n * * Conversion operators:\n * * `['array', value1, ...valueN]` creates a numerical array from `number` values; please note that the amount of\n * values can currently only be 2, 3 or 4 (WebGL only).\n * * `['color', red, green, blue, alpha]` or `['color', shade, alpha]` creates a `color` value from `number` values;\n * the `alpha` parameter is optional; if not specified, it will be set to 1 (WebGL only).\n * Note: `red`, `green` and `blue` or `shade` components must be values between 0 and 255; `alpha` between 0 and 1.\n * * `['palette', index, colors]` picks a `color` value from an array of colors using the given index; the `index`\n * expression must evaluate to a number; the items in the `colors` array must be strings with hex colors\n * (e.g. `'#86A136'`), colors using the rgba[a] functional notation (e.g. `'rgb(134, 161, 54)'` or `'rgba(134, 161, 54, 1)'`),\n * named colors (e.g. `'red'`), or array literals with 3 ([r, g, b]) or 4 ([r, g, b, a]) values (with r, g, and b\n * in the 0-255 range and a in the 0-1 range) (WebGL only).\n * * `['to-string', value]` converts the input value to a string. If the input is a boolean, the result is \"true\" or \"false\".\n * If the input is a number, it is converted to a string as specified by the \"NumberToString\" algorithm of the ECMAScript\n * Language Specification. If the input is a color, it is converted to a string of the form \"rgba(r,g,b,a)\". (Canvas only)\n *\n * Values can either be literals or another operator, as they will be evaluated recursively.\n * Literal values can be of the following types:\n * * `boolean`\n * * `number`\n * * `number[]` (number arrays can only have a length of 2, 3 or 4)\n * * `string`\n * * {@link module:ol/color~Color}\n *\n * @typedef {Array<*>|import(\"../color.js\").Color|string|number|boolean} ExpressionValue\n * @api\n */\n\nlet numTypes = 0;\nexport const NoneType = 0;\nexport const BooleanType = 1 << numTypes++;\nexport const NumberType = 1 << numTypes++;\nexport const StringType = 1 << numTypes++;\nexport const ColorType = 1 << numTypes++;\nexport const NumberArrayType = 1 << numTypes++;\nexport const SizeType = 1 << numTypes++;\nexport const AnyType = Math.pow(2, numTypes) - 1;\n\nconst typeNames = {\n [BooleanType]: 'boolean',\n [NumberType]: 'number',\n [StringType]: 'string',\n [ColorType]: 'color',\n [NumberArrayType]: 'number[]',\n [SizeType]: 'size',\n};\n\nconst namedTypes = Object.keys(typeNames).map(Number).sort(ascending);\n\n/**\n * @param {number} type The type.\n * @return {boolean} The type is one of the specific types (not any or a union type).\n */\nfunction isSpecific(type) {\n return type in typeNames;\n}\n\n/**\n * Get a string representation for a type.\n * @param {number} type The type.\n * @return {string} The type name.\n */\nexport function typeName(type) {\n const names = [];\n for (const namedType of namedTypes) {\n if (includesType(type, namedType)) {\n names.push(typeNames[namedType]);\n }\n }\n if (names.length === 0) {\n return 'untyped';\n }\n if (names.length < 3) {\n return names.join(' or ');\n }\n return names.slice(0, -1).join(', ') + ', or ' + names[names.length - 1];\n}\n\n/**\n * @param {number} broad The broad type.\n * @param {number} specific The specific type.\n * @return {boolean} The broad type includes the specific type.\n */\nexport function includesType(broad, specific) {\n return (broad & specific) === specific;\n}\n\n/**\n * @param {number} oneType One type.\n * @param {number} otherType Another type.\n * @return {boolean} The set of types overlap (share a common specific type)\n */\nexport function overlapsType(oneType, otherType) {\n return !!(oneType & otherType);\n}\n\n/**\n * @param {number} type The type.\n * @param {number} expected The expected type.\n * @return {boolean} The given type is exactly the expected type.\n */\nexport function isType(type, expected) {\n return type === expected;\n}\n\n/**\n * @typedef {boolean|number|string|Array} LiteralValue\n */\n\nexport class LiteralExpression {\n /**\n * @param {number} type The value type.\n * @param {LiteralValue} value The literal value.\n */\n constructor(type, value) {\n if (!isSpecific(type)) {\n throw new Error(\n `literal expressions must have a specific type, got ${typeName(type)}`,\n );\n }\n this.type = type;\n this.value = value;\n }\n}\n\nexport class CallExpression {\n /**\n * @param {number} type The return type.\n * @param {string} operator The operator.\n * @param {...Expression} args The arguments.\n */\n constructor(type, operator, ...args) {\n this.type = type;\n this.operator = operator;\n this.args = args;\n }\n}\n\n/**\n * @typedef {LiteralExpression|CallExpression} Expression\n */\n\n/**\n * @typedef {Object} ParsingContext\n * @property {Set} variables Variables referenced with the 'var' operator.\n * @property {Set} properties Properties referenced with the 'get' operator.\n * @property {boolean} featureId The style uses the feature id.\n * @property {boolean} geometryType The style uses the feature geometry type.\n */\n\n/**\n * @return {ParsingContext} A new parsing context.\n */\nexport function newParsingContext() {\n return {\n variables: new Set(),\n properties: new Set(),\n featureId: false,\n geometryType: false,\n };\n}\n\n/**\n * @typedef {LiteralValue|Array} EncodedExpression\n */\n\n/**\n * @param {EncodedExpression} encoded The encoded expression.\n * @param {number} expectedType The expected type.\n * @param {ParsingContext} context The parsing context.\n * @return {Expression} The parsed expression result.\n */\nexport function parse(encoded, expectedType, context) {\n switch (typeof encoded) {\n case 'boolean': {\n if (isType(expectedType, StringType)) {\n return new LiteralExpression(StringType, encoded ? 'true' : 'false');\n }\n if (!includesType(expectedType, BooleanType)) {\n throw new Error(\n `got a boolean, but expected ${typeName(expectedType)}`,\n );\n }\n return new LiteralExpression(BooleanType, encoded);\n }\n case 'number': {\n if (isType(expectedType, SizeType)) {\n return new LiteralExpression(SizeType, toSize(encoded));\n }\n if (isType(expectedType, BooleanType)) {\n return new LiteralExpression(BooleanType, !!encoded);\n }\n if (isType(expectedType, StringType)) {\n return new LiteralExpression(StringType, encoded.toString());\n }\n if (!includesType(expectedType, NumberType)) {\n throw new Error(`got a number, but expected ${typeName(expectedType)}`);\n }\n return new LiteralExpression(NumberType, encoded);\n }\n case 'string': {\n if (isType(expectedType, ColorType)) {\n return new LiteralExpression(ColorType, colorFromString(encoded));\n }\n if (isType(expectedType, BooleanType)) {\n return new LiteralExpression(BooleanType, !!encoded);\n }\n if (!includesType(expectedType, StringType)) {\n throw new Error(`got a string, but expected ${typeName(expectedType)}`);\n }\n return new LiteralExpression(StringType, encoded);\n }\n default: {\n // pass\n }\n }\n\n if (!Array.isArray(encoded)) {\n throw new Error('expression must be an array or a primitive value');\n }\n\n if (encoded.length === 0) {\n throw new Error('empty expression');\n }\n\n if (typeof encoded[0] === 'string') {\n return parseCallExpression(encoded, expectedType, context);\n }\n\n for (const item of encoded) {\n if (typeof item !== 'number') {\n throw new Error('expected an array of numbers');\n }\n }\n\n if (isType(expectedType, SizeType)) {\n if (encoded.length !== 2) {\n throw new Error(\n `expected an array of two values for a size, got ${encoded.length}`,\n );\n }\n return new LiteralExpression(SizeType, encoded);\n }\n\n if (isType(expectedType, ColorType)) {\n if (encoded.length === 3) {\n return new LiteralExpression(ColorType, [...encoded, 1]);\n }\n if (encoded.length === 4) {\n return new LiteralExpression(ColorType, encoded);\n }\n throw new Error(\n `expected an array of 3 or 4 values for a color, got ${encoded.length}`,\n );\n }\n\n if (!includesType(expectedType, NumberArrayType)) {\n throw new Error(\n `got an array of numbers, but expected ${typeName(expectedType)}`,\n );\n }\n\n return new LiteralExpression(NumberArrayType, encoded);\n}\n\n/**\n * @type {Object}\n */\nexport const Ops = {\n Get: 'get',\n Var: 'var',\n Concat: 'concat',\n GeometryType: 'geometry-type',\n Any: 'any',\n All: 'all',\n Not: '!',\n Resolution: 'resolution',\n Zoom: 'zoom',\n Time: 'time',\n Equal: '==',\n NotEqual: '!=',\n GreaterThan: '>',\n GreaterThanOrEqualTo: '>=',\n LessThan: '<',\n LessThanOrEqualTo: '<=',\n Multiply: '*',\n Divide: '/',\n Add: '+',\n Subtract: '-',\n Clamp: 'clamp',\n Mod: '%',\n Pow: '^',\n Abs: 'abs',\n Floor: 'floor',\n Ceil: 'ceil',\n Round: 'round',\n Sin: 'sin',\n Cos: 'cos',\n Atan: 'atan',\n Sqrt: 'sqrt',\n Match: 'match',\n Between: 'between',\n Interpolate: 'interpolate',\n Coalesce: 'coalesce',\n Case: 'case',\n In: 'in',\n Number: 'number',\n String: 'string',\n Array: 'array',\n Color: 'color',\n Id: 'id',\n Band: 'band',\n Palette: 'palette',\n ToString: 'to-string',\n};\n\n/**\n * @typedef {function(Array, number, ParsingContext):Expression} Parser\n *\n * Second argument is the expected type.\n */\n\n/**\n * @type {Object}\n */\nconst parsers = {\n [Ops.Get]: createCallExpressionParser(hasArgsCount(1, Infinity), withGetArgs),\n [Ops.Var]: createCallExpressionParser(hasArgsCount(1, 1), withVarArgs),\n [Ops.Id]: createCallExpressionParser(usesFeatureId, withNoArgs),\n [Ops.Concat]: createCallExpressionParser(\n hasArgsCount(2, Infinity),\n withArgsOfType(StringType),\n ),\n [Ops.GeometryType]: createCallExpressionParser(usesGeometryType, withNoArgs),\n [Ops.Resolution]: createCallExpressionParser(withNoArgs),\n [Ops.Zoom]: createCallExpressionParser(withNoArgs),\n [Ops.Time]: createCallExpressionParser(withNoArgs),\n [Ops.Any]: createCallExpressionParser(\n hasArgsCount(2, Infinity),\n withArgsOfType(BooleanType),\n ),\n [Ops.All]: createCallExpressionParser(\n hasArgsCount(2, Infinity),\n withArgsOfType(BooleanType),\n ),\n [Ops.Not]: createCallExpressionParser(\n hasArgsCount(1, 1),\n withArgsOfType(BooleanType),\n ),\n [Ops.Equal]: createCallExpressionParser(\n hasArgsCount(2, 2),\n withArgsOfType(AnyType),\n ),\n [Ops.NotEqual]: createCallExpressionParser(\n hasArgsCount(2, 2),\n withArgsOfType(AnyType),\n ),\n [Ops.GreaterThan]: createCallExpressionParser(\n hasArgsCount(2, 2),\n withArgsOfType(NumberType),\n ),\n [Ops.GreaterThanOrEqualTo]: createCallExpressionParser(\n hasArgsCount(2, 2),\n withArgsOfType(NumberType),\n ),\n [Ops.LessThan]: createCallExpressionParser(\n hasArgsCount(2, 2),\n withArgsOfType(NumberType),\n ),\n [Ops.LessThanOrEqualTo]: createCallExpressionParser(\n hasArgsCount(2, 2),\n withArgsOfType(NumberType),\n ),\n [Ops.Multiply]: createCallExpressionParser(\n hasArgsCount(2, Infinity),\n withArgsOfReturnType,\n ),\n [Ops.Coalesce]: createCallExpressionParser(\n hasArgsCount(2, Infinity),\n withArgsOfReturnType,\n ),\n [Ops.Divide]: createCallExpressionParser(\n hasArgsCount(2, 2),\n withArgsOfType(NumberType),\n ),\n [Ops.Add]: createCallExpressionParser(\n hasArgsCount(2, Infinity),\n withArgsOfType(NumberType),\n ),\n [Ops.Subtract]: createCallExpressionParser(\n hasArgsCount(2, 2),\n withArgsOfType(NumberType),\n ),\n [Ops.Clamp]: createCallExpressionParser(\n hasArgsCount(3, 3),\n withArgsOfType(NumberType),\n ),\n [Ops.Mod]: createCallExpressionParser(\n hasArgsCount(2, 2),\n withArgsOfType(NumberType),\n ),\n [Ops.Pow]: createCallExpressionParser(\n hasArgsCount(2, 2),\n withArgsOfType(NumberType),\n ),\n [Ops.Abs]: createCallExpressionParser(\n hasArgsCount(1, 1),\n withArgsOfType(NumberType),\n ),\n [Ops.Floor]: createCallExpressionParser(\n hasArgsCount(1, 1),\n withArgsOfType(NumberType),\n ),\n [Ops.Ceil]: createCallExpressionParser(\n hasArgsCount(1, 1),\n withArgsOfType(NumberType),\n ),\n [Ops.Round]: createCallExpressionParser(\n hasArgsCount(1, 1),\n withArgsOfType(NumberType),\n ),\n [Ops.Sin]: createCallExpressionParser(\n hasArgsCount(1, 1),\n withArgsOfType(NumberType),\n ),\n [Ops.Cos]: createCallExpressionParser(\n hasArgsCount(1, 1),\n withArgsOfType(NumberType),\n ),\n [Ops.Atan]: createCallExpressionParser(\n hasArgsCount(1, 2),\n withArgsOfType(NumberType),\n ),\n [Ops.Sqrt]: createCallExpressionParser(\n hasArgsCount(1, 1),\n withArgsOfType(NumberType),\n ),\n [Ops.Match]: createCallExpressionParser(\n hasArgsCount(4, Infinity),\n hasEvenArgs,\n withMatchArgs,\n ),\n [Ops.Between]: createCallExpressionParser(\n hasArgsCount(3, 3),\n withArgsOfType(NumberType),\n ),\n [Ops.Interpolate]: createCallExpressionParser(\n hasArgsCount(6, Infinity),\n hasEvenArgs,\n withInterpolateArgs,\n ),\n [Ops.Case]: createCallExpressionParser(\n hasArgsCount(3, Infinity),\n hasOddArgs,\n withCaseArgs,\n ),\n [Ops.In]: createCallExpressionParser(hasArgsCount(2, 2), withInArgs),\n [Ops.Number]: createCallExpressionParser(\n hasArgsCount(1, Infinity),\n withArgsOfType(AnyType),\n ),\n [Ops.String]: createCallExpressionParser(\n hasArgsCount(1, Infinity),\n withArgsOfType(AnyType),\n ),\n [Ops.Array]: createCallExpressionParser(\n hasArgsCount(1, Infinity),\n withArgsOfType(NumberType),\n ),\n [Ops.Color]: createCallExpressionParser(\n hasArgsCount(1, 4),\n withArgsOfType(NumberType),\n ),\n [Ops.Band]: createCallExpressionParser(\n hasArgsCount(1, 3),\n withArgsOfType(NumberType),\n ),\n [Ops.Palette]: createCallExpressionParser(\n hasArgsCount(2, 2),\n withPaletteArgs,\n ),\n [Ops.ToString]: createCallExpressionParser(\n hasArgsCount(1, 1),\n withArgsOfType(BooleanType | NumberType | StringType | ColorType),\n ),\n};\n\n/**\n * @typedef {function(Array, number, ParsingContext):Array|void} ArgValidator\n *\n * An argument validator applies various checks to an encoded expression arguments and\n * returns the parsed arguments if any. The second argument is the return type of the call expression.\n */\n\n/**\n * @type ArgValidator\n */\nfunction withGetArgs(encoded, returnType, context) {\n const argsCount = encoded.length - 1;\n const args = new Array(argsCount);\n for (let i = 0; i < argsCount; ++i) {\n const key = encoded[i + 1];\n switch (typeof key) {\n case 'number': {\n args[i] = new LiteralExpression(NumberType, key);\n break;\n }\n case 'string': {\n args[i] = new LiteralExpression(StringType, key);\n break;\n }\n default: {\n throw new Error(\n `expected a string key or numeric array index for a get operation, got ${key}`,\n );\n }\n }\n if (i === 0) {\n context.properties.add(String(key));\n }\n }\n return args;\n}\n\n/**\n * @type ArgValidator\n */\nfunction withVarArgs(encoded, returnType, context) {\n const name = encoded[1];\n if (typeof name !== 'string') {\n throw new Error('expected a string argument for var operation');\n }\n context.variables.add(name);\n\n return [new LiteralExpression(StringType, name)];\n}\n\n/**\n * @type ArgValidator\n */\nfunction usesFeatureId(encoded, returnType, context) {\n context.featureId = true;\n}\n\n/**\n * @type ArgValidator\n */\nfunction usesGeometryType(encoded, returnType, context) {\n context.geometryType = true;\n}\n\n/**\n * @type ArgValidator\n */\nfunction withNoArgs(encoded, returnType, context) {\n const operation = encoded[0];\n if (encoded.length !== 1) {\n throw new Error(`expected no arguments for ${operation} operation`);\n }\n return [];\n}\n\n/**\n * @param {number} minArgs The minimum number of arguments.\n * @param {number} maxArgs The maximum number of arguments.\n * @return {ArgValidator} The argument validator\n */\nfunction hasArgsCount(minArgs, maxArgs) {\n return function (encoded, returnType, context) {\n const operation = encoded[0];\n const argCount = encoded.length - 1;\n if (minArgs === maxArgs) {\n if (argCount !== minArgs) {\n const plural = minArgs === 1 ? '' : 's';\n throw new Error(\n `expected ${minArgs} argument${plural} for ${operation}, got ${argCount}`,\n );\n }\n } else if (argCount < minArgs || argCount > maxArgs) {\n const range =\n maxArgs === Infinity\n ? `${minArgs} or more`\n : `${minArgs} to ${maxArgs}`;\n throw new Error(\n `expected ${range} arguments for ${operation}, got ${argCount}`,\n );\n }\n };\n}\n\n/**\n * @type {ArgValidator}\n */\nfunction withArgsOfReturnType(encoded, returnType, context) {\n const argCount = encoded.length - 1;\n /**\n * @type {Array}\n */\n const args = new Array(argCount);\n for (let i = 0; i < argCount; ++i) {\n const expression = parse(encoded[i + 1], returnType, context);\n args[i] = expression;\n }\n return args;\n}\n\n/**\n * @param {number} argType The argument type.\n * @return {ArgValidator} The argument validator\n */\nfunction withArgsOfType(argType) {\n return function (encoded, returnType, context) {\n const argCount = encoded.length - 1;\n /**\n * @type {Array}\n */\n const args = new Array(argCount);\n for (let i = 0; i < argCount; ++i) {\n const expression = parse(encoded[i + 1], argType, context);\n args[i] = expression;\n }\n return args;\n };\n}\n\n/**\n * @type {ArgValidator}\n */\nfunction hasOddArgs(encoded, returnType, context) {\n const operation = encoded[0];\n const argCount = encoded.length - 1;\n if (argCount % 2 === 0) {\n throw new Error(\n `expected an odd number of arguments for ${operation}, got ${argCount} instead`,\n );\n }\n}\n\n/**\n * @type {ArgValidator}\n */\nfunction hasEvenArgs(encoded, returnType, context) {\n const operation = encoded[0];\n const argCount = encoded.length - 1;\n if (argCount % 2 === 1) {\n throw new Error(\n `expected an even number of arguments for operation ${operation}, got ${argCount} instead`,\n );\n }\n}\n\n/**\n * @type ArgValidator\n */\nfunction withMatchArgs(encoded, returnType, context) {\n const argsCount = encoded.length - 1;\n\n const inputType = StringType | NumberType | BooleanType;\n\n const input = parse(encoded[1], inputType, context);\n\n const fallback = parse(encoded[encoded.length - 1], returnType, context);\n\n const args = new Array(argsCount - 2);\n for (let i = 0; i < argsCount - 2; i += 2) {\n try {\n const match = parse(encoded[i + 2], input.type, context);\n args[i] = match;\n } catch (err) {\n throw new Error(\n `failed to parse argument ${i + 1} of match expression: ${err.message}`,\n );\n }\n try {\n const output = parse(encoded[i + 3], fallback.type, context);\n args[i + 1] = output;\n } catch (err) {\n throw new Error(\n `failed to parse argument ${i + 2} of match expression: ${err.message}`,\n );\n }\n }\n\n return [input, ...args, fallback];\n}\n\n/**\n * @type ArgValidator\n */\nfunction withInterpolateArgs(encoded, returnType, context) {\n const interpolationType = encoded[1];\n /**\n * @type {number}\n */\n let base;\n switch (interpolationType[0]) {\n case 'linear':\n base = 1;\n break;\n case 'exponential':\n const b = interpolationType[1];\n if (typeof b !== 'number' || b <= 0) {\n throw new Error(\n `expected a number base for exponential interpolation` +\n `, got ${JSON.stringify(b)} instead`,\n );\n }\n base = b;\n break;\n default:\n throw new Error(\n `invalid interpolation type: ${JSON.stringify(interpolationType)}`,\n );\n }\n\n const interpolation = new LiteralExpression(NumberType, base);\n\n let input;\n try {\n input = parse(encoded[2], NumberType, context);\n } catch (err) {\n throw new Error(\n `failed to parse argument 1 in interpolate expression: ${err.message}`,\n );\n }\n\n const args = new Array(encoded.length - 3);\n for (let i = 0; i < args.length; i += 2) {\n try {\n const stop = parse(encoded[i + 3], NumberType, context);\n args[i] = stop;\n } catch (err) {\n throw new Error(\n `failed to parse argument ${i + 2} for interpolate expression: ${err.message}`,\n );\n }\n try {\n const output = parse(encoded[i + 4], returnType, context);\n args[i + 1] = output;\n } catch (err) {\n throw new Error(\n `failed to parse argument ${i + 3} for interpolate expression: ${err.message}`,\n );\n }\n }\n\n return [interpolation, input, ...args];\n}\n\n/**\n * @type ArgValidator\n */\nfunction withCaseArgs(encoded, returnType, context) {\n const fallback = parse(encoded[encoded.length - 1], returnType, context);\n\n const args = new Array(encoded.length - 1);\n for (let i = 0; i < args.length - 1; i += 2) {\n try {\n const condition = parse(encoded[i + 1], BooleanType, context);\n args[i] = condition;\n } catch (err) {\n throw new Error(\n `failed to parse argument ${i} of case expression: ${err.message}`,\n );\n }\n try {\n const output = parse(encoded[i + 2], fallback.type, context);\n args[i + 1] = output;\n } catch (err) {\n throw new Error(\n `failed to parse argument ${i + 1} of case expression: ${err.message}`,\n );\n }\n }\n\n args[args.length - 1] = fallback;\n return args;\n}\n\n/**\n * @type ArgValidator\n */\nfunction withInArgs(encoded, returnType, context) {\n let haystack = encoded[2];\n if (!Array.isArray(haystack)) {\n throw new Error(\n `the second argument for the \"in\" operator must be an array`,\n );\n }\n /**\n * @type {number}\n */\n let needleType;\n if (typeof haystack[0] === 'string') {\n if (haystack[0] !== 'literal') {\n throw new Error(\n `for the \"in\" operator, a string array should be wrapped in a \"literal\" operator to disambiguate from expressions`,\n );\n }\n if (!Array.isArray(haystack[1])) {\n throw new Error(\n `failed to parse \"in\" expression: the literal operator must be followed by an array`,\n );\n }\n haystack = haystack[1];\n needleType = StringType;\n } else {\n needleType = NumberType;\n }\n\n const args = new Array(haystack.length);\n for (let i = 0; i < args.length; i++) {\n try {\n const arg = parse(haystack[i], needleType, context);\n args[i] = arg;\n } catch (err) {\n throw new Error(\n `failed to parse haystack item ${i} for \"in\" expression: ${err.message}`,\n );\n }\n }\n\n const needle = parse(encoded[1], needleType, context);\n return [needle, ...args];\n}\n\n/**\n * @type ArgValidator\n */\nfunction withPaletteArgs(encoded, returnType, context) {\n let index;\n try {\n index = parse(encoded[1], NumberType, context);\n } catch (err) {\n throw new Error(\n `failed to parse first argument in palette expression: ${err.message}`,\n );\n }\n const colors = encoded[2];\n if (!Array.isArray(colors)) {\n throw new Error('the second argument of palette must be an array');\n }\n const parsedColors = new Array(colors.length);\n for (let i = 0; i < parsedColors.length; i++) {\n let color;\n try {\n color = parse(colors[i], ColorType, context);\n } catch (err) {\n throw new Error(\n `failed to parse color at index ${i} in palette expression: ${err.message}`,\n );\n }\n if (!(color instanceof LiteralExpression)) {\n throw new Error(\n `the palette color at index ${i} must be a literal value`,\n );\n }\n parsedColors[i] = color;\n }\n return [index, ...parsedColors];\n}\n\n/**\n * @param {Array} validators A chain of argument validators. The last validator is expected\n * to return the parsed arguments.\n * @return {Parser} The parser.\n */\nfunction createCallExpressionParser(...validators) {\n return function (encoded, returnType, context) {\n const operator = encoded[0];\n\n /**\n * @type {Array}\n */\n let args;\n for (let i = 0; i < validators.length; i++) {\n const parsed = validators[i](encoded, returnType, context);\n if (i == validators.length - 1) {\n if (!parsed) {\n throw new Error(\n 'expected last argument validator to return the parsed args',\n );\n }\n args = parsed;\n }\n }\n return new CallExpression(returnType, operator, ...args);\n };\n}\n\n/**\n * @param {Array} encoded The encoded expression.\n * @param {number} returnType The expected return type of the call expression.\n * @param {ParsingContext} context The parsing context.\n * @return {Expression} The parsed expression.\n */\nfunction parseCallExpression(encoded, returnType, context) {\n const operator = encoded[0];\n\n const parser = parsers[operator];\n if (!parser) {\n throw new Error(`unknown operator: ${operator}`);\n }\n return parser(encoded, returnType, context);\n}\n\n/**\n * Returns a simplified geometry type suited for the `geometry-type` operator\n * @param {import('../geom/Geometry.js').default|import('../render/Feature.js').default} geometry Geometry object\n * @return {'Point'|'LineString'|'Polygon'|''} Simplified geometry type; empty string of no geometry found\n */\nexport function computeGeometryType(geometry) {\n if (!geometry) {\n return '';\n }\n const type = geometry.getType();\n switch (type) {\n case 'Point':\n case 'LineString':\n case 'Polygon':\n return type;\n case 'MultiPoint':\n case 'MultiLineString':\n case 'MultiPolygon':\n return /** @type {'Point'|'LineString'|'Polygon'} */ (type.substring(5));\n case 'Circle':\n return 'Polygon';\n case 'GeometryCollection':\n return computeGeometryType(\n /** @type {import(\"../geom/GeometryCollection.js\").default} */ (\n geometry\n ).getGeometries()[0],\n );\n default:\n return '';\n }\n}\n","/**\n * @module ol/expr/cpu\n */\n\nimport {ColorType, LiteralExpression, Ops, parse} from './expression.js';\nimport {\n fromString,\n lchaToRgba,\n normalize,\n rgbaToLcha,\n toString,\n withAlpha,\n} from '../color.js';\n\n/**\n * @fileoverview This module includes functions to build expressions for evaluation on the CPU.\n * Building is composed of two steps: parsing and compiling. The parsing step takes an encoded\n * expression and returns an instance of one of the expression classes. The compiling step takes\n * the expression instance and returns a function that can be evaluated in to return a literal\n * value. The evaluator function should do as little allocation and work as possible.\n */\n\n/**\n * @typedef {Object} EvaluationContext\n * @property {Object} properties The values for properties used in 'get' expressions.\n * @property {Object} variables The values for variables used in 'var' expressions.\n * @property {number} resolution The map resolution.\n * @property {string|number|null} featureId The feature id.\n * @property {string} geometryType Geometry type of the current object.\n */\n\n/**\n * @return {EvaluationContext} A new evaluation context.\n */\nexport function newEvaluationContext() {\n return {\n variables: {},\n properties: {},\n resolution: NaN,\n featureId: null,\n geometryType: '',\n };\n}\n\n/**\n * @typedef {function(EvaluationContext):import(\"./expression.js\").LiteralValue} ExpressionEvaluator\n */\n\n/**\n * @typedef {function(EvaluationContext):boolean} BooleanEvaluator\n */\n\n/**\n * @typedef {function(EvaluationContext):number} NumberEvaluator\n */\n\n/**\n * @typedef {function(EvaluationContext):string} StringEvaluator\n */\n\n/**\n * @typedef {function(EvaluationContext):(Array|string)} ColorLikeEvaluator\n */\n\n/**\n * @typedef {function(EvaluationContext):Array} NumberArrayEvaluator\n */\n\n/**\n * @typedef {function(EvaluationContext):Array} CoordinateEvaluator\n */\n\n/**\n * @typedef {function(EvaluationContext):(Array)} SizeEvaluator\n */\n\n/**\n * @typedef {function(EvaluationContext):(Array|number)} SizeLikeEvaluator\n */\n\n/**\n * @param {import('./expression.js').EncodedExpression} encoded The encoded expression.\n * @param {number} type The expected type.\n * @param {import('./expression.js').ParsingContext} context The parsing context.\n * @return {ExpressionEvaluator} The expression evaluator.\n */\nexport function buildExpression(encoded, type, context) {\n const expression = parse(encoded, type, context);\n return compileExpression(expression, context);\n}\n\n/**\n * @param {import(\"./expression.js\").Expression} expression The expression.\n * @param {import('./expression.js').ParsingContext} context The parsing context.\n * @return {ExpressionEvaluator} The evaluator function.\n */\nfunction compileExpression(expression, context) {\n if (expression instanceof LiteralExpression) {\n // convert colors to array if possible\n if (expression.type === ColorType && typeof expression.value === 'string') {\n const colorValue = fromString(expression.value);\n return function () {\n return colorValue;\n };\n }\n return function () {\n return expression.value;\n };\n }\n const operator = expression.operator;\n switch (operator) {\n case Ops.Number:\n case Ops.String:\n case Ops.Coalesce: {\n return compileAssertionExpression(expression, context);\n }\n case Ops.Get:\n case Ops.Var: {\n return compileAccessorExpression(expression, context);\n }\n case Ops.Id: {\n return (context) => context.featureId;\n }\n case Ops.GeometryType: {\n return (context) => context.geometryType;\n }\n case Ops.Concat: {\n const args = expression.args.map((e) => compileExpression(e, context));\n return (context) =>\n ''.concat(...args.map((arg) => arg(context).toString()));\n }\n case Ops.Resolution: {\n return (context) => context.resolution;\n }\n case Ops.Any:\n case Ops.All:\n case Ops.Between:\n case Ops.In:\n case Ops.Not: {\n return compileLogicalExpression(expression, context);\n }\n case Ops.Equal:\n case Ops.NotEqual:\n case Ops.LessThan:\n case Ops.LessThanOrEqualTo:\n case Ops.GreaterThan:\n case Ops.GreaterThanOrEqualTo: {\n return compileComparisonExpression(expression, context);\n }\n case Ops.Multiply:\n case Ops.Divide:\n case Ops.Add:\n case Ops.Subtract:\n case Ops.Clamp:\n case Ops.Mod:\n case Ops.Pow:\n case Ops.Abs:\n case Ops.Floor:\n case Ops.Ceil:\n case Ops.Round:\n case Ops.Sin:\n case Ops.Cos:\n case Ops.Atan:\n case Ops.Sqrt: {\n return compileNumericExpression(expression, context);\n }\n case Ops.Case: {\n return compileCaseExpression(expression, context);\n }\n case Ops.Match: {\n return compileMatchExpression(expression, context);\n }\n case Ops.Interpolate: {\n return compileInterpolateExpression(expression, context);\n }\n case Ops.ToString: {\n return compileConvertExpression(expression, context);\n }\n default: {\n throw new Error(`Unsupported operator ${operator}`);\n }\n // TODO: unimplemented\n // Ops.Zoom\n // Ops.Time\n // Ops.Array\n // Ops.Color\n // Ops.Band\n // Ops.Palette\n }\n}\n\n/**\n * @param {import('./expression.js').CallExpression} expression The call expression.\n * @param {import('./expression.js').ParsingContext} context The parsing context.\n * @return {ExpressionEvaluator} The evaluator function.\n */\nfunction compileAssertionExpression(expression, context) {\n const type = expression.operator;\n const length = expression.args.length;\n\n const args = new Array(length);\n for (let i = 0; i < length; ++i) {\n args[i] = compileExpression(expression.args[i], context);\n }\n switch (type) {\n case Ops.Coalesce: {\n return (context) => {\n for (let i = 0; i < length; ++i) {\n const value = args[i](context);\n if (typeof value !== 'undefined' && value !== null) {\n return value;\n }\n }\n throw new Error('Expected one of the values to be non-null');\n };\n }\n case Ops.Number:\n case Ops.String: {\n return (context) => {\n for (let i = 0; i < length; ++i) {\n const value = args[i](context);\n if (typeof value === type) {\n return value;\n }\n }\n throw new Error(`Expected one of the values to be a ${type}`);\n };\n }\n default: {\n throw new Error(`Unsupported assertion operator ${type}`);\n }\n }\n}\n\n/**\n * @param {import('./expression.js').CallExpression} expression The call expression.\n * @param {import('./expression.js').ParsingContext} context The parsing context.\n * @return {ExpressionEvaluator} The evaluator function.\n */\nfunction compileAccessorExpression(expression, context) {\n const nameExpression = /** @type {LiteralExpression} */ (expression.args[0]);\n const name = /** @type {string} */ (nameExpression.value);\n switch (expression.operator) {\n case Ops.Get: {\n return (context) => {\n const args = expression.args;\n let value = context.properties[name];\n for (let i = 1, ii = args.length; i < ii; ++i) {\n const keyExpression = /** @type {LiteralExpression} */ (args[i]);\n const key = /** @type {string|number} */ (keyExpression.value);\n value = value[key];\n }\n return value;\n };\n }\n case Ops.Var: {\n return (context) => context.variables[name];\n }\n default: {\n throw new Error(`Unsupported accessor operator ${expression.operator}`);\n }\n }\n}\n\n/**\n * @param {import('./expression.js').CallExpression} expression The call expression.\n * @param {import('./expression.js').ParsingContext} context The parsing context.\n * @return {BooleanEvaluator} The evaluator function.\n */\nfunction compileComparisonExpression(expression, context) {\n const op = expression.operator;\n const left = compileExpression(expression.args[0], context);\n const right = compileExpression(expression.args[1], context);\n switch (op) {\n case Ops.Equal: {\n return (context) => left(context) === right(context);\n }\n case Ops.NotEqual: {\n return (context) => left(context) !== right(context);\n }\n case Ops.LessThan: {\n return (context) => left(context) < right(context);\n }\n case Ops.LessThanOrEqualTo: {\n return (context) => left(context) <= right(context);\n }\n case Ops.GreaterThan: {\n return (context) => left(context) > right(context);\n }\n case Ops.GreaterThanOrEqualTo: {\n return (context) => left(context) >= right(context);\n }\n default: {\n throw new Error(`Unsupported comparison operator ${op}`);\n }\n }\n}\n\n/**\n * @param {import('./expression.js').CallExpression} expression The call expression.\n * @param {import('./expression.js').ParsingContext} context The parsing context.\n * @return {BooleanEvaluator} The evaluator function.\n */\nfunction compileLogicalExpression(expression, context) {\n const op = expression.operator;\n const length = expression.args.length;\n\n const args = new Array(length);\n for (let i = 0; i < length; ++i) {\n args[i] = compileExpression(expression.args[i], context);\n }\n switch (op) {\n case Ops.Any: {\n return (context) => {\n for (let i = 0; i < length; ++i) {\n if (args[i](context)) {\n return true;\n }\n }\n return false;\n };\n }\n case Ops.All: {\n return (context) => {\n for (let i = 0; i < length; ++i) {\n if (!args[i](context)) {\n return false;\n }\n }\n return true;\n };\n }\n case Ops.Between: {\n return (context) => {\n const value = args[0](context);\n const min = args[1](context);\n const max = args[2](context);\n return value >= min && value <= max;\n };\n }\n case Ops.In: {\n return (context) => {\n const value = args[0](context);\n for (let i = 1; i < length; ++i) {\n if (value === args[i](context)) {\n return true;\n }\n }\n return false;\n };\n }\n case Ops.Not: {\n return (context) => !args[0](context);\n }\n default: {\n throw new Error(`Unsupported logical operator ${op}`);\n }\n }\n}\n\n/**\n * @param {import('./expression.js').CallExpression} expression The call expression.\n * @param {import('./expression.js').ParsingContext} context The parsing context.\n * @return {NumberEvaluator} The evaluator function.\n */\nfunction compileNumericExpression(expression, context) {\n const op = expression.operator;\n const length = expression.args.length;\n\n const args = new Array(length);\n for (let i = 0; i < length; ++i) {\n args[i] = compileExpression(expression.args[i], context);\n }\n switch (op) {\n case Ops.Multiply: {\n return (context) => {\n let value = 1;\n for (let i = 0; i < length; ++i) {\n value *= args[i](context);\n }\n return value;\n };\n }\n case Ops.Divide: {\n return (context) => args[0](context) / args[1](context);\n }\n case Ops.Add: {\n return (context) => {\n let value = 0;\n for (let i = 0; i < length; ++i) {\n value += args[i](context);\n }\n return value;\n };\n }\n case Ops.Subtract: {\n return (context) => args[0](context) - args[1](context);\n }\n case Ops.Clamp: {\n return (context) => {\n const value = args[0](context);\n const min = args[1](context);\n if (value < min) {\n return min;\n }\n const max = args[2](context);\n if (value > max) {\n return max;\n }\n return value;\n };\n }\n case Ops.Mod: {\n return (context) => args[0](context) % args[1](context);\n }\n case Ops.Pow: {\n return (context) => Math.pow(args[0](context), args[1](context));\n }\n case Ops.Abs: {\n return (context) => Math.abs(args[0](context));\n }\n case Ops.Floor: {\n return (context) => Math.floor(args[0](context));\n }\n case Ops.Ceil: {\n return (context) => Math.ceil(args[0](context));\n }\n case Ops.Round: {\n return (context) => Math.round(args[0](context));\n }\n case Ops.Sin: {\n return (context) => Math.sin(args[0](context));\n }\n case Ops.Cos: {\n return (context) => Math.cos(args[0](context));\n }\n case Ops.Atan: {\n if (length === 2) {\n return (context) => Math.atan2(args[0](context), args[1](context));\n }\n return (context) => Math.atan(args[0](context));\n }\n case Ops.Sqrt: {\n return (context) => Math.sqrt(args[0](context));\n }\n default: {\n throw new Error(`Unsupported numeric operator ${op}`);\n }\n }\n}\n\n/**\n * @param {import('./expression.js').CallExpression} expression The call expression.\n * @param {import('./expression.js').ParsingContext} context The parsing context.\n * @return {ExpressionEvaluator} The evaluator function.\n */\nfunction compileCaseExpression(expression, context) {\n const length = expression.args.length;\n const args = new Array(length);\n for (let i = 0; i < length; ++i) {\n args[i] = compileExpression(expression.args[i], context);\n }\n return (context) => {\n for (let i = 0; i < length - 1; i += 2) {\n const condition = args[i](context);\n if (condition) {\n return args[i + 1](context);\n }\n }\n return args[length - 1](context);\n };\n}\n\n/**\n * @param {import('./expression.js').CallExpression} expression The call expression.\n * @param {import('./expression.js').ParsingContext} context The parsing context.\n * @return {ExpressionEvaluator} The evaluator function.\n */\nfunction compileMatchExpression(expression, context) {\n const length = expression.args.length;\n const args = new Array(length);\n for (let i = 0; i < length; ++i) {\n args[i] = compileExpression(expression.args[i], context);\n }\n return (context) => {\n const value = args[0](context);\n for (let i = 1; i < length; i += 2) {\n if (value === args[i](context)) {\n return args[i + 1](context);\n }\n }\n return args[length - 1](context);\n };\n}\n\n/**\n * @param {import('./expression.js').CallExpression} expression The call expression.\n * @param {import('./expression.js').ParsingContext} context The parsing context.\n * @return {ExpressionEvaluator} The evaluator function.\n */\nfunction compileInterpolateExpression(expression, context) {\n const length = expression.args.length;\n const args = new Array(length);\n for (let i = 0; i < length; ++i) {\n args[i] = compileExpression(expression.args[i], context);\n }\n return (context) => {\n const base = args[0](context);\n const value = args[1](context);\n\n let previousInput;\n let previousOutput;\n for (let i = 2; i < length; i += 2) {\n const input = args[i](context);\n let output = args[i + 1](context);\n const isColor = Array.isArray(output);\n if (isColor) {\n output = withAlpha(output);\n }\n if (input >= value) {\n if (i === 2) {\n return output;\n }\n if (isColor) {\n return interpolateColor(\n base,\n value,\n previousInput,\n previousOutput,\n input,\n output,\n );\n }\n return interpolateNumber(\n base,\n value,\n previousInput,\n previousOutput,\n input,\n output,\n );\n }\n previousInput = input;\n previousOutput = output;\n }\n return previousOutput;\n };\n}\n\n/**\n * @param {import('./expression.js').CallExpression} expression The call expression.\n * @param {import('./expression.js').ParsingContext} context The parsing context.\n * @return {ExpressionEvaluator} The evaluator function.\n */\nfunction compileConvertExpression(expression, context) {\n const op = expression.operator;\n const length = expression.args.length;\n\n const args = new Array(length);\n for (let i = 0; i < length; ++i) {\n args[i] = compileExpression(expression.args[i], context);\n }\n switch (op) {\n case Ops.ToString: {\n return (context) => {\n const value = args[0](context);\n if (expression.args[0].type === ColorType) {\n return toString(value);\n }\n return value.toString();\n };\n }\n default: {\n throw new Error(`Unsupported convert operator ${op}`);\n }\n }\n}\n\n/**\n * @param {number} base The base.\n * @param {number} value The value.\n * @param {number} input1 The first input value.\n * @param {number} output1 The first output value.\n * @param {number} input2 The second input value.\n * @param {number} output2 The second output value.\n * @return {number} The interpolated value.\n */\nfunction interpolateNumber(base, value, input1, output1, input2, output2) {\n const delta = input2 - input1;\n if (delta === 0) {\n return output1;\n }\n const along = value - input1;\n const factor =\n base === 1\n ? along / delta\n : (Math.pow(base, along) - 1) / (Math.pow(base, delta) - 1);\n return output1 + factor * (output2 - output1);\n}\n\n/**\n * @param {number} base The base.\n * @param {number} value The value.\n * @param {number} input1 The first input value.\n * @param {import('../color.js').Color} rgba1 The first output value.\n * @param {number} input2 The second input value.\n * @param {import('../color.js').Color} rgba2 The second output value.\n * @return {import('../color.js').Color} The interpolated color.\n */\nfunction interpolateColor(base, value, input1, rgba1, input2, rgba2) {\n const delta = input2 - input1;\n if (delta === 0) {\n return rgba1;\n }\n const lcha1 = rgbaToLcha(rgba1);\n const lcha2 = rgbaToLcha(rgba2);\n let deltaHue = lcha2[2] - lcha1[2];\n if (deltaHue > 180) {\n deltaHue -= 360;\n } else if (deltaHue < -180) {\n deltaHue += 360;\n }\n\n const lcha = [\n interpolateNumber(base, value, input1, lcha1[0], input2, lcha2[0]),\n interpolateNumber(base, value, input1, lcha1[1], input2, lcha2[1]),\n lcha1[2] + interpolateNumber(base, value, input1, 0, input2, deltaHue),\n interpolateNumber(base, value, input1, rgba1[3], input2, rgba2[3]),\n ];\n return normalize(lchaToRgba(lcha));\n}\n","/**\n * @module ol/render/canvas/style\n */\n\nimport Circle from '../../style/Circle.js';\nimport Fill from '../../style/Fill.js';\nimport Icon from '../../style/Icon.js';\nimport RegularShape from '../../style/RegularShape.js';\nimport Stroke from '../../style/Stroke.js';\nimport Style from '../../style/Style.js';\nimport Text from '../../style/Text.js';\nimport {\n BooleanType,\n ColorType,\n NumberArrayType,\n NumberType,\n StringType,\n computeGeometryType,\n newParsingContext,\n} from '../../expr/expression.js';\nimport {buildExpression, newEvaluationContext} from '../../expr/cpu.js';\nimport {isEmpty} from '../../obj.js';\nimport {toSize} from '../../size.js';\n\n/**\n * @fileoverview This module includes functions to build styles for the canvas renderer. Building\n * is composed of two steps: parsing and compiling. The parsing step takes an encoded expression\n * and returns an instance of one of the expression classes. The compiling step takes the\n * expression instance and returns a function that can be evaluated to return a literal value. The\n * evaluator function should do as little allocation and work as possible.\n */\n\n/**\n * @typedef {import(\"../../style/flat.js\").FlatStyle} FlatStyle\n */\n\n/**\n * @typedef {import(\"../../expr/expression.js\").EncodedExpression} EncodedExpression\n */\n\n/**\n * @typedef {import(\"../../expr/expression.js\").ParsingContext} ParsingContext\n */\n\n/**\n * @typedef {import(\"../../expr/expression.js\").CallExpression} CallExpression\n */\n\n/**\n * @typedef {import(\"../../expr/cpu.js\").EvaluationContext} EvaluationContext\n */\n\n/**\n * @typedef {import(\"../../expr/cpu.js\").ExpressionEvaluator} ExpressionEvaluator\n */\n\n/**\n * @param {EvaluationContext} context The evaluation context.\n * @return {boolean} Always true.\n */\nfunction always(context) {\n return true;\n}\n\n/**\n * This function adapts a rule evaluator to the existing style function interface.\n * After we have deprecated the style function, we can use the compiled rules directly\n * and pass a more complete evaluation context (variables, zoom, time, etc.).\n *\n * @param {Array} rules The rules.\n * @return {import('../../style/Style.js').StyleFunction} A style function.\n */\nexport function rulesToStyleFunction(rules) {\n const parsingContext = newParsingContext();\n const evaluator = buildRuleSet(rules, parsingContext);\n const evaluationContext = newEvaluationContext();\n return function (feature, resolution) {\n evaluationContext.properties = feature.getPropertiesInternal();\n evaluationContext.resolution = resolution;\n if (parsingContext.featureId) {\n const id = feature.getId();\n if (id !== undefined) {\n evaluationContext.featureId = id;\n } else {\n evaluationContext.featureId = null;\n }\n }\n if (parsingContext.geometryType) {\n evaluationContext.geometryType = computeGeometryType(\n feature.getGeometry(),\n );\n }\n return evaluator(evaluationContext);\n };\n}\n\n/**\n * This function adapts a style evaluator to the existing style function interface.\n * After we have deprecated the style function, we can use the compiled rules directly\n * and pass a more complete evaluation context (variables, zoom, time, etc.).\n *\n * @param {Array} flatStyles The flat styles.\n * @return {import('../../style/Style.js').StyleFunction} A style function.\n */\nexport function flatStylesToStyleFunction(flatStyles) {\n const parsingContext = newParsingContext();\n const length = flatStyles.length;\n\n /**\n * @type {Array}\n */\n const evaluators = new Array(length);\n for (let i = 0; i < length; ++i) {\n evaluators[i] = buildStyle(flatStyles[i], parsingContext);\n }\n const evaluationContext = newEvaluationContext();\n\n /**\n * @type {Array
\ No newline at end of file diff --git a/dist/examples/esri-4326.js b/dist/examples/esri-4326.js new file mode 100644 index 00000000..9bd818b6 --- /dev/null +++ b/dist/examples/esri-4326.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[58],{6223:(s,e,r)=>{r(8508),(0,r(316).Bb)("map","https://basemaps.arcgis.com/arcgis/rest/services/World_Basemap_GCS_v2/VectorTileServer/resources/styles/",{projection:"EPSG:4326"})}},s=>{s(s.s=6223)}]); +//# sourceMappingURL=esri-4326.js.map \ No newline at end of file diff --git a/dist/examples/esri-4326.js.map b/dist/examples/esri-4326.js.map new file mode 100644 index 00000000..6726002f --- /dev/null +++ b/dist/examples/esri-4326.js.map @@ -0,0 +1 @@ +{"version":3,"file":"esri-4326.js","mappings":"yHAGA,E,OAAA,IACE,MACA,2GACA,CACEA,WAAY,a","sources":["webpack://ol-mapbox-style/./examples/esri-4326.js"],"sourcesContent":["import 'ol/ol.css';\nimport {apply} from 'ol-mapbox-style';\n\napply(\n 'map',\n 'https://basemaps.arcgis.com/arcgis/rest/services/World_Basemap_GCS_v2/VectorTileServer/resources/styles/',\n {\n projection: 'EPSG:4326',\n },\n);\n"],"names":["projection"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/esri-transformrequest.css b/dist/examples/esri-transformrequest.css new file mode 100644 index 00000000..6e4620a7 --- /dev/null +++ b/dist/examples/esri-transformrequest.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=esri-transformrequest.css.map*/ \ No newline at end of file diff --git a/dist/examples/esri-transformrequest.css.map b/dist/examples/esri-transformrequest.css.map new file mode 100644 index 00000000..343af30a --- /dev/null +++ b/dist/examples/esri-transformrequest.css.map @@ -0,0 +1 @@ +{"version":3,"file":"esri-transformrequest.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/esri-transformrequest.html b/dist/examples/esri-transformrequest.html new file mode 100644 index 00000000..3b978109 --- /dev/null +++ b/dist/examples/esri-transformrequest.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/esri-transformrequest.js b/dist/examples/esri-transformrequest.js new file mode 100644 index 00000000..f3497bee --- /dev/null +++ b/dist/examples/esri-transformrequest.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[42],{3619:(e,s,r)=>{r(8508),(0,r(316).Ay)("map","https://www.arcgis.com/sharing/rest/content/items/2afe5b807fa74006be6363fd243ffb30/resources/styles/root.json",{transformRequest(e,s){if("Source"===s)return new Request(e.replace("/VectorTileServer","/VectorTileServer/"))}})}},e=>{e(e.s=3619)}]); +//# sourceMappingURL=esri-transformrequest.js.map \ No newline at end of file diff --git a/dist/examples/esri-transformrequest.js.map b/dist/examples/esri-transformrequest.js.map new file mode 100644 index 00000000..3e6a5808 --- /dev/null +++ b/dist/examples/esri-transformrequest.js.map @@ -0,0 +1 @@ +{"version":3,"file":"esri-transformrequest.js","mappings":"yHAGA,E,OAAA,IACE,MACA,gHACA,CACE,gBAAAA,CAAiBC,EAAKC,GACpB,GAAa,WAATA,EACF,OAAO,IAAIC,QACTF,EAAIG,QAAQ,oBAAqB,sBAGvC,G","sources":["webpack://ol-mapbox-style/./examples/esri-transformrequest.js"],"sourcesContent":["import 'ol/ol.css';\nimport olms from 'ol-mapbox-style';\n\nolms(\n 'map',\n 'https://www.arcgis.com/sharing/rest/content/items/2afe5b807fa74006be6363fd243ffb30/resources/styles/root.json',\n {\n transformRequest(url, type) {\n if (type === 'Source') {\n return new Request(\n url.replace('/VectorTileServer', '/VectorTileServer/'),\n );\n }\n },\n },\n);\n"],"names":["transformRequest","url","type","Request","replace"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/geojson-featurestate.css b/dist/examples/geojson-featurestate.css new file mode 100644 index 00000000..b2edabe6 --- /dev/null +++ b/dist/examples/geojson-featurestate.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=geojson-featurestate.css.map*/ \ No newline at end of file diff --git a/dist/examples/geojson-featurestate.css.map b/dist/examples/geojson-featurestate.css.map new file mode 100644 index 00000000..f5442cfa --- /dev/null +++ b/dist/examples/geojson-featurestate.css.map @@ -0,0 +1 @@ +{"version":3,"file":"geojson-featurestate.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/geojson-featurestate.html b/dist/examples/geojson-featurestate.html new file mode 100644 index 00000000..07013b07 --- /dev/null +++ b/dist/examples/geojson-featurestate.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/geojson-featurestate.js b/dist/examples/geojson-featurestate.js new file mode 100644 index 00000000..5bdd96b2 --- /dev/null +++ b/dist/examples/geojson-featurestate.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[736],{1657:(e,t,l)=>{l(8508);var s=l(316);const o="data/geojson.json";fetch(o).then((e=>e.json())).then((e=>(e.layers.push({id:"state-hover",type:"fill",source:"states",paint:{"fill-color":"red","fill-opacity":["case",["boolean",["feature-state","hover"],!1],.5,0]}}),(0,s.Ay)("map",e,{styleUrl:o})))).then((e=>{let t=null;e.on("pointermove",(function(l){const o=e.getFeaturesAtPixel(l.pixel);o.length>0?(null!==t&&(0,s.QD)(e,{source:"states",id:t},null),t=o[0].getId(),(0,s.QD)(e,{source:"states",id:t},{hover:!0})):null!==t&&((0,s.QD)(e,{source:"states",id:t},null),t=null)}))}))}},e=>{e(e.s=1657)}]); +//# sourceMappingURL=geojson-featurestate.js.map \ No newline at end of file diff --git a/dist/examples/geojson-featurestate.js.map b/dist/examples/geojson-featurestate.js.map new file mode 100644 index 00000000..795919b0 --- /dev/null +++ b/dist/examples/geojson-featurestate.js.map @@ -0,0 +1 @@ +{"version":3,"file":"geojson-featurestate.js","mappings":"sIAGA,MAAMA,EAAW,oBAEjBC,MAAMD,GACHE,MAAMC,GAAaA,EAASC,SAC5BF,MAAMG,IACLA,EAAQC,OAAOC,KAAK,CAClB,GAAM,cACN,KAAQ,OACR,OAAU,SACV,MAAS,CACP,aAAc,MACd,eAAgB,CACd,OACA,CAAC,UAAW,CAAC,gBAAiB,UAAU,GACxC,GACA,OAIC,QAAK,MAAOF,EAAS,CAACL,SAAUA,OAExCE,MAAMM,IACL,IAAIC,EAAiB,KACrBD,EAAIE,GAAG,eAAe,SAAUC,GAC9B,MAAMC,EAAWJ,EAAIK,mBAAmBF,EAAIG,OACxCF,EAASG,OAAS,GACG,OAAnBN,IACF,QAAgBD,EAAK,CAACQ,OAAQ,SAAUC,GAAIR,GAAiB,MAE/DA,EAAiBG,EAAS,GAAGM,SAC7B,QACEV,EACA,CAACQ,OAAQ,SAAUC,GAAIR,GACvB,CAACU,OAAO,KAEkB,OAAnBV,KACT,QAAgBD,EAAK,CAACQ,OAAQ,SAAUC,GAAIR,GAAiB,MAC7DA,EAAiB,KAErB,GAAE,G","sources":["webpack://ol-mapbox-style/./examples/geojson-featurestate.js"],"sourcesContent":["import 'ol/ol.css';\nimport olms, {setFeatureState} from 'ol-mapbox-style';\n\nconst styleUrl = 'data/geojson.json';\n\nfetch(styleUrl)\n .then((response) => response.json())\n .then((glStyle) => {\n glStyle.layers.push({\n 'id': 'state-hover',\n 'type': 'fill',\n 'source': 'states',\n 'paint': {\n 'fill-color': 'red',\n 'fill-opacity': [\n 'case',\n ['boolean', ['feature-state', 'hover'], false],\n 0.5,\n 0,\n ],\n },\n });\n return olms('map', glStyle, {styleUrl: styleUrl});\n })\n .then((map) => {\n let hoveredStateId = null;\n map.on('pointermove', function (evt) {\n const features = map.getFeaturesAtPixel(evt.pixel);\n if (features.length > 0) {\n if (hoveredStateId !== null) {\n setFeatureState(map, {source: 'states', id: hoveredStateId}, null);\n }\n hoveredStateId = features[0].getId();\n setFeatureState(\n map,\n {source: 'states', id: hoveredStateId},\n {hover: true},\n );\n } else if (hoveredStateId !== null) {\n setFeatureState(map, {source: 'states', id: hoveredStateId}, null);\n hoveredStateId = null;\n }\n });\n });\n"],"names":["styleUrl","fetch","then","response","json","glStyle","layers","push","map","hoveredStateId","on","evt","features","getFeaturesAtPixel","pixel","length","source","id","getId","hover"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/geojson-inline.css b/dist/examples/geojson-inline.css new file mode 100644 index 00000000..d87dec87 --- /dev/null +++ b/dist/examples/geojson-inline.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=geojson-inline.css.map*/ \ No newline at end of file diff --git a/dist/examples/geojson-inline.css.map b/dist/examples/geojson-inline.css.map new file mode 100644 index 00000000..eb3b1fc2 --- /dev/null +++ b/dist/examples/geojson-inline.css.map @@ -0,0 +1 @@ +{"version":3,"file":"geojson-inline.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/geojson-inline.html b/dist/examples/geojson-inline.html new file mode 100644 index 00000000..07803658 --- /dev/null +++ b/dist/examples/geojson-inline.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/geojson-inline.js b/dist/examples/geojson-inline.js new file mode 100644 index 00000000..ca9d4e28 --- /dev/null +++ b/dist/examples/geojson-inline.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[422],{8779:(s,e,a)=>{a(8508),(0,a(316).Bb)("map","data/geojson-inline.json")}},s=>{s(s.s=8779)}]); +//# sourceMappingURL=geojson-inline.js.map \ No newline at end of file diff --git a/dist/examples/geojson-inline.js.map b/dist/examples/geojson-inline.js.map new file mode 100644 index 00000000..52f78bee --- /dev/null +++ b/dist/examples/geojson-inline.js.map @@ -0,0 +1 @@ +{"version":3,"file":"geojson-inline.js","mappings":"0HAGA,E,OAAA,IAAM,MAAO,2B","sources":["webpack://ol-mapbox-style/./examples/geojson-inline.js"],"sourcesContent":["import 'ol/ol.css';\nimport {apply} from 'ol-mapbox-style';\n\napply('map', 'data/geojson-inline.json');\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/geojson-layer.css b/dist/examples/geojson-layer.css new file mode 100644 index 00000000..fae91fbb --- /dev/null +++ b/dist/examples/geojson-layer.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=geojson-layer.css.map*/ \ No newline at end of file diff --git a/dist/examples/geojson-layer.css.map b/dist/examples/geojson-layer.css.map new file mode 100644 index 00000000..ac6e34d7 --- /dev/null +++ b/dist/examples/geojson-layer.css.map @@ -0,0 +1 @@ +{"version":3,"file":"geojson-layer.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/geojson-layer.html b/dist/examples/geojson-layer.html new file mode 100644 index 00000000..c0f73e6e --- /dev/null +++ b/dist/examples/geojson-layer.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/geojson-layer.js b/dist/examples/geojson-layer.js new file mode 100644 index 00000000..4e304445 --- /dev/null +++ b/dist/examples/geojson-layer.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[556],{7657:(e,s,a)=>{a(8508);var o=a(2757),n=a(3317),t=a(1765),l=a(316),p=a(594);const w=new o.A;(0,l.AV)(w,"data/geojson.json"),new n.A({target:"map",layers:[w],view:new t.Ay({center:(0,p.Rb)([-122.19952899999998,51.920367528011525]),zoom:3})})}},e=>{e(e.s=7657)}]); +//# sourceMappingURL=geojson-layer.js.map \ No newline at end of file diff --git a/dist/examples/geojson-layer.js.map b/dist/examples/geojson-layer.js.map new file mode 100644 index 00000000..94339890 --- /dev/null +++ b/dist/examples/geojson-layer.js.map @@ -0,0 +1 @@ +{"version":3,"file":"geojson-layer.js","mappings":"6KAMA,MAAMA,EAAQ,IAAI,KAClB,QAAWA,EAAO,qBAClB,IAAI,IAAI,CACNC,OAAQ,MACRC,OAAQ,CAACF,GACTG,KAAM,IAAI,KAAK,CACbC,QAAQ,QAAW,EAAE,mBAAoB,qBACzCC,KAAM,K","sources":["webpack://ol-mapbox-style/./examples/geojson-layer.js"],"sourcesContent":["import 'ol/ol.css';\nimport VectorLayer from 'ol/layer/Vector.js';\nimport {Map, View} from 'ol';\nimport {applyStyle} from 'ol-mapbox-style';\nimport {fromLonLat} from 'ol/proj.js';\n\nconst layer = new VectorLayer();\napplyStyle(layer, 'data/geojson.json');\nnew Map({\n target: 'map',\n layers: [layer],\n view: new View({\n center: fromLonLat([-122.19952899999998, 51.920367528011525]),\n zoom: 3,\n }),\n});\n"],"names":["layer","target","layers","view","center","zoom"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/geojson-wfs.css b/dist/examples/geojson-wfs.css new file mode 100644 index 00000000..90f193ae --- /dev/null +++ b/dist/examples/geojson-wfs.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=geojson-wfs.css.map*/ \ No newline at end of file diff --git a/dist/examples/geojson-wfs.css.map b/dist/examples/geojson-wfs.css.map new file mode 100644 index 00000000..07e3a3ab --- /dev/null +++ b/dist/examples/geojson-wfs.css.map @@ -0,0 +1 @@ +{"version":3,"file":"geojson-wfs.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/geojson-wfs.html b/dist/examples/geojson-wfs.html new file mode 100644 index 00000000..afd2f98c --- /dev/null +++ b/dist/examples/geojson-wfs.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/geojson-wfs.js b/dist/examples/geojson-wfs.js new file mode 100644 index 00000000..941866c7 --- /dev/null +++ b/dist/examples/geojson-wfs.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[269],{3674:(s,e,a)=>{a(8508),(0,a(316).Bb)("map","data/geojson-wfs.json")}},s=>{s(s.s=3674)}]); +//# sourceMappingURL=geojson-wfs.js.map \ No newline at end of file diff --git a/dist/examples/geojson-wfs.js.map b/dist/examples/geojson-wfs.js.map new file mode 100644 index 00000000..a7e86ff7 --- /dev/null +++ b/dist/examples/geojson-wfs.js.map @@ -0,0 +1 @@ +{"version":3,"file":"geojson-wfs.js","mappings":"0HAGA,E,OAAA,IAAM,MAAO,wB","sources":["webpack://ol-mapbox-style/./examples/geojson-wfs.js"],"sourcesContent":["import 'ol/ol.css';\nimport {apply} from 'ol-mapbox-style';\n\napply('map', 'data/geojson-wfs.json');\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/geojson.css b/dist/examples/geojson.css new file mode 100644 index 00000000..75130f4d --- /dev/null +++ b/dist/examples/geojson.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=geojson.css.map*/ \ No newline at end of file diff --git a/dist/examples/geojson.css.map b/dist/examples/geojson.css.map new file mode 100644 index 00000000..4ba7460e --- /dev/null +++ b/dist/examples/geojson.css.map @@ -0,0 +1 @@ +{"version":3,"file":"geojson.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/geojson.html b/dist/examples/geojson.html new file mode 100644 index 00000000..c6266dd6 --- /dev/null +++ b/dist/examples/geojson.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/geojson.js b/dist/examples/geojson.js new file mode 100644 index 00000000..a79ed70a --- /dev/null +++ b/dist/examples/geojson.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[268],{3597:(s,e,a)=>{a(8508),(0,a(316).Bb)("map","data/geojson.json")}},s=>{s(s.s=3597)}]); +//# sourceMappingURL=geojson.js.map \ No newline at end of file diff --git a/dist/examples/geojson.js.map b/dist/examples/geojson.js.map new file mode 100644 index 00000000..4f0deeb3 --- /dev/null +++ b/dist/examples/geojson.js.map @@ -0,0 +1 @@ +{"version":3,"file":"geojson.js","mappings":"0HAGA,E,OAAA,IAAM,MAAO,oB","sources":["webpack://ol-mapbox-style/./examples/geojson.js"],"sourcesContent":["import 'ol/ol.css';\nimport {apply} from 'ol-mapbox-style';\n\napply('map', 'data/geojson.json');\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/index.html b/dist/examples/index.html new file mode 100644 index 00000000..70567803 --- /dev/null +++ b/dist/examples/index.html @@ -0,0 +1,39 @@ + + + + + + + ol-mapbox-style Examples + + + +

ol-mapbox-style Examples

+

To see the source code for the examples below, go to https://github.com/openlayers/ol-mapbox-style/tree/main/examples/.

+ + + diff --git a/dist/examples/mapbox.css b/dist/examples/mapbox.css new file mode 100644 index 00000000..aa2ef121 --- /dev/null +++ b/dist/examples/mapbox.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=mapbox.css.map*/ \ No newline at end of file diff --git a/dist/examples/mapbox.css.map b/dist/examples/mapbox.css.map new file mode 100644 index 00000000..c6dcae75 --- /dev/null +++ b/dist/examples/mapbox.css.map @@ -0,0 +1 @@ +{"version":3,"file":"mapbox.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/mapbox.html b/dist/examples/mapbox.html new file mode 100644 index 00000000..d635e8bf --- /dev/null +++ b/dist/examples/mapbox.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/mapbox.js b/dist/examples/mapbox.js new file mode 100644 index 00000000..e6d046a2 --- /dev/null +++ b/dist/examples/mapbox.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[626],{5103:(e,o,s)=>{s(8508);var c=s(316);let a=document.cookie.replace(/(?:(?:^|.*;\s*)mapbox_access_token\s*\=\s*([^;]*).*$)|^.*$/,"$1");a||(a=window.prompt("Enter your Mapbox API access token:"),a&&(document.cookie="mapbox_access_token="+a+"; expires=Fri, 31 Dec 9999 23:59:59 GMT")),(0,c.Ay)("map","mapbox://styles/mapbox/bright-v9",{accessToken:a})}},e=>{e(e.s=5103)}]); +//# sourceMappingURL=mapbox.js.map \ No newline at end of file diff --git a/dist/examples/mapbox.js.map b/dist/examples/mapbox.js.map new file mode 100644 index 00000000..d6365d86 --- /dev/null +++ b/dist/examples/mapbox.js.map @@ -0,0 +1 @@ +{"version":3,"file":"mapbox.js","mappings":"sIAGA,IAAIA,EAAMC,SAASC,OAAOC,QACxB,6DACA,MAEGH,IACHA,EAAMI,OAAOC,OAAO,uCAChBL,IACFC,SAASC,OACP,uBAAyBF,EAAM,6CAIrC,QAAK,MAAO,mCAAoC,CAACM,YAAaN,G","sources":["webpack://ol-mapbox-style/./examples/mapbox.js"],"sourcesContent":["import 'ol/ol.css';\nimport olms from 'ol-mapbox-style';\n\nlet key = document.cookie.replace(\n /(?:(?:^|.*;\\s*)mapbox_access_token\\s*\\=\\s*([^;]*).*$)|^.*$/,\n '$1',\n);\nif (!key) {\n key = window.prompt('Enter your Mapbox API access token:');\n if (key) {\n document.cookie =\n 'mapbox_access_token=' + key + '; expires=Fri, 31 Dec 9999 23:59:59 GMT';\n }\n}\n\nolms('map', 'mapbox://styles/mapbox/bright-v9', {accessToken: key});\n"],"names":["key","document","cookie","replace","window","prompt","accessToken"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/maptiler-hillshading.css b/dist/examples/maptiler-hillshading.css new file mode 100644 index 00000000..e00e26fe --- /dev/null +++ b/dist/examples/maptiler-hillshading.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=maptiler-hillshading.css.map*/ \ No newline at end of file diff --git a/dist/examples/maptiler-hillshading.css.map b/dist/examples/maptiler-hillshading.css.map new file mode 100644 index 00000000..51d0224b --- /dev/null +++ b/dist/examples/maptiler-hillshading.css.map @@ -0,0 +1 @@ +{"version":3,"file":"maptiler-hillshading.css","mappings":"AAAA;;EAEE,4BAA4B;EAC5B,qCAAqC;EACrC,uDAAuD;EACvD,wDAAwD;EACxD,8BAA8B;EAC9B,qCAAqC;EACrC,yBAAyB;AAC3B;;AAEA;EACE,sBAAsB;EACtB,kBAAkB;EAClB,8CAA8C;EAC9C,oDAAoD;AACtD;;AAEA;EACE,QAAQ;EACR,UAAU;EACV,kBAAkB;AACpB;;AAEA;EACE,8CAA8C;EAC9C,kBAAkB;EAClB,WAAW;EACX,SAAS;EACT,YAAY;EACZ,kBAAkB;AACpB;;AAEA;EACE,mDAAmD;EACnD,gBAAgB;EAChB,iCAAiC;EACjC,eAAe;EACf,kBAAkB;EAClB,WAAW;EACX,4BAA4B;EAC5B,qBAAqB;AACvB;;AAEA;EACE,kBAAkB;EAClB,WAAW;EACX,SAAS;AACX;;AAEA;EACE,aAAa;AACf;;AAEA;EACE,UAAU;EACV,YAAY;EACZ,4CAA4C;EAC5C,YAAY;EACZ,WAAW;AACb;;AAEA;EACE,kBAAkB;EAClB,YAAY;EACZ,eAAe;EACf,WAAW;EACX,iCAAiC;EACjC,6LAA6L;AAC/L;;AAEA;EACE,kBAAkB;EAClB,eAAe;EACf,kBAAkB;EAClB,YAAY;EACZ,iCAAiC;EACjC,6LAA6L;AAC/L;;AAEA;EACE,kBAAkB;EAClB,YAAY;EACZ,UAAU;EACV,sBAAsB;EACtB,4CAA4C;AAC9C;;AAEA;EACE,mDAAmD;AACrD;;AAEA;EACE,4CAA4C;AAC9C;;AAEA;EACE,aAAa;AACf;;AAEA;;EAEE,2BAA2B;EAC3B,yBAAyB;EACzB,sBAAsB;EACtB,iBAAiB;EACjB,wCAAwC;AAC1C;;AAEA;EACE,UAAU;EACV,gBAAgB;AAClB;;AAEA;EACE,yBAAyB;AAC3B;;AAEA;EACE,8BAA8B;EAC9B,yBAAyB;EACzB,sBAAsB;EACtB,iBAAiB;AACnB;;AAEA;EACE,wBAAwB;EACxB,qBAAqB;EACrB,gBAAgB;AAClB;;AAEA;EACE,YAAY;EACZ,oBAAoB;EACpB,iBAAiB;EACjB,YAAY;AACd;;AAEA;EACE,kBAAkB;EAClB,mDAAmD;EACnD,kBAAkB;AACpB;;AAEA;EACE,SAAS;EACT,UAAU;AACZ;;AAEA;EACE,SAAS;EACT,WAAW;EACX,qDAAqD;AACvD;;AAEA;EACE,UAAU;EACV,kBAAkB;EAClB,0DAA0D;AAC5D;;AAEA;EACE,YAAY;EACZ,UAAU;AACZ;;AAEA;EACE,WAAW;EACX,SAAS;AACX;;AAEA;EACE,cAAc;EACd,WAAW;EACX,UAAU;EACV,wCAAwC;EACxC,iBAAiB;EACjB,qBAAqB;EACrB,kBAAkB;EAClB,kBAAkB;EAClB,eAAe;EACf,cAAc;EACd,iBAAiB;EACjB,4CAA4C;EAC5C,YAAY;EACZ,kBAAkB;AACpB;;AAEA;EACE,YAAY;EACZ,UAAU;AACZ;;AAEA;EACE,kBAAkB;AACpB;;AAEA;EACE,cAAc;EACd,mBAAmB;EACnB,sBAAsB;AACxB;;AAEA;EACE,gBAAgB;AAClB;;AAEA;EACE,UAAU;AACZ;;AAEA;;EAEE,qBAAqB;EACrB,oDAAoD;EACpD,iCAAiC;AACnC;;AAEA;EACE,0BAA0B;AAC5B;;AAEA;EACE,0BAA0B;AAC5B;;AAEA;EACE,iBAAiB;EACjB,YAAY;EACZ,WAAW;EACX,6BAA6B;EAC7B,aAAa;EACb,sBAAsB;EACtB,mBAAmB;AACrB;;AAEA;EACE,wCAAwC;EACxC,qBAAqB;AACvB;;AAEA;EACE,SAAS;EACT,iBAAiB;EACjB,iCAAiC;EACjC,+CAA+C;EAC/C,eAAe;AACjB;;AAEA;EACE,eAAe;EACf,gBAAgB;AAClB;;AAEA;EACE,YAAY;AACd;;AAEA;EACE,eAAe;EACf,kBAAkB;EAClB,sBAAsB;AACxB;;AAEA;EACE,cAAc;AAChB;;AAEA;EACE,aAAa;AACf;;AAEA;EACE,8CAA8C;AAChD;;AAEA;EACE,SAAS;EACT,QAAQ;EACR,sBAAsB;AACxB;;AAEA;EACE,iBAAiB;EACjB,iBAAiB;AACnB;;AAEA;EACE,aAAa;AACf;;AAEA;EACE,UAAU;EACV,UAAU;EACV,aAAa;AACf;;AAEA;EACE,kBAAkB;EAClB,YAAY;AACd;;AAEA;EACE,UAAU;AACZ;;AAEA;EACE,WAAW;EACX,aAAa;AACf;;AAEA;EACE,SAAS;EACT,OAAO;EACP,wBAAwB;AAC1B;;AAEA;;EAEE,cAAc;AAChB;;AAEA;EACE,mDAAmD;EACnD,aAAa;EACb,YAAY;AACd;;AAEA;EACE,SAAS;EACT,OAAO;EACP,kBAAkB;AACpB;;AAEA;;EAEE,aAAa;AACf;;AAEA;EACE,6CAA6C;AAC/C;;AAEA;EACE,sDAAsD;AACxD;;AAEA;EACE,YAAY;AACd;;AAEA;EACE,eAAe;AACjB","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/maptiler-hillshading.html b/dist/examples/maptiler-hillshading.html new file mode 100644 index 00000000..d229829c --- /dev/null +++ b/dist/examples/maptiler-hillshading.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/maptiler-hillshading.js b/dist/examples/maptiler-hillshading.js new file mode 100644 index 00000000..51025a4a --- /dev/null +++ b/dist/examples/maptiler-hillshading.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[225],{9486:(e,t,o)=>{o(8508);var s=o(316);let c=document.cookie.replace(/(?:(?:^|.*;\s*)maptiler_access_token\s*\=\s*([^;]*).*$)|^.*$/,"$1");c||(c=window.prompt("Enter your MapTiler API access token:"),document.cookie="maptiler_access_token="+c+"; expires=Fri, 31 Dec 9999 23:59:59 GMT"),fetch(`https://api.maptiler.com/maps/outdoor-v2/style.json?key=${c}`).then((e=>e.json())).then((e=>{(0,s.Ay)("map",Object.assign({},e,{center:[13.783578,47.609499],zoom:11}),{webfont:"https://fonts.googleapis.com/css?family={Font+Family}:{fontweight}{fontstyle}"})}))}},e=>{e(e.s=9486)}]); +//# sourceMappingURL=maptiler-hillshading.js.map \ No newline at end of file diff --git a/dist/examples/maptiler-hillshading.js.map b/dist/examples/maptiler-hillshading.js.map new file mode 100644 index 00000000..0d2b67df --- /dev/null +++ b/dist/examples/maptiler-hillshading.js.map @@ -0,0 +1 @@ +{"version":3,"file":"maptiler-hillshading.js","mappings":"sIAGA,IAAIA,EAAMC,SAASC,OAAOC,QACxB,+DACA,MAEGH,IACHA,EAAMI,OAAOC,OAAO,yCACpBJ,SAASC,OACP,yBAA2BF,EAAM,2CAGrCM,MAAM,2DAA2DN,KAC9DO,MAAMC,GAAaA,EAASC,SAC5BF,MAAMG,KACL,QACE,MACAC,OAAOC,OAAO,CAAC,EAAGF,EAAO,CACvBG,OAAQ,CAAC,UAAW,WACpBC,KAAM,KAER,CACEC,QACE,iFAEL,G","sources":["webpack://ol-mapbox-style/./examples/maptiler-hillshading.js"],"sourcesContent":["import 'ol/ol.css';\nimport olms from 'ol-mapbox-style';\n\nlet key = document.cookie.replace(\n /(?:(?:^|.*;\\s*)maptiler_access_token\\s*\\=\\s*([^;]*).*$)|^.*$/,\n '$1',\n);\nif (!key) {\n key = window.prompt('Enter your MapTiler API access token:');\n document.cookie =\n 'maptiler_access_token=' + key + '; expires=Fri, 31 Dec 9999 23:59:59 GMT';\n}\n\nfetch(`https://api.maptiler.com/maps/outdoor-v2/style.json?key=${key}`)\n .then((response) => response.json())\n .then((style) => {\n olms(\n 'map',\n Object.assign({}, style, {\n center: [13.783578, 47.609499],\n zoom: 11,\n }),\n {\n webfont:\n 'https://fonts.googleapis.com/css?family={Font+Family}:{fontweight}{fontstyle}',\n },\n );\n });\n"],"names":["key","document","cookie","replace","window","prompt","fetch","then","response","json","style","Object","assign","center","zoom","webfont"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/openmaptiles-layer.css b/dist/examples/openmaptiles-layer.css new file mode 100644 index 00000000..8b27b784 --- /dev/null +++ b/dist/examples/openmaptiles-layer.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=openmaptiles-layer.css.map*/ \ No newline at end of file diff --git a/dist/examples/openmaptiles-layer.css.map b/dist/examples/openmaptiles-layer.css.map new file mode 100644 index 00000000..63d3d549 --- /dev/null +++ b/dist/examples/openmaptiles-layer.css.map @@ -0,0 +1 @@ +{"version":3,"file":"openmaptiles-layer.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/openmaptiles-layer.html b/dist/examples/openmaptiles-layer.html new file mode 100644 index 00000000..bffcf9fb --- /dev/null +++ b/dist/examples/openmaptiles-layer.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/openmaptiles-layer.js b/dist/examples/openmaptiles-layer.js new file mode 100644 index 00000000..123fa659 --- /dev/null +++ b/dist/examples/openmaptiles-layer.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[126],{5747:(e,s,t)=>{t(8508);var o=t(8063),c=t(3317),a=t(1765),p=t(316);let r=document.cookie.replace(/(?:(?:^|.*;\s*)maptiler_access_token\s*\=\s*([^;]*).*$)|^.*$/,"$1");r||(r=window.prompt("Enter your MapTiler API access token:"),document.cookie="maptiler_access_token="+r+"; expires=Fri, 31 Dec 9999 23:59:59 GMT");const l="https://api.maptiler.com/maps/basic/style.json?key="+r,n=new o.A({declutter:!0});(0,p.AV)(n,l),(0,p.V5)(n,l),new c.A({target:"map",layers:[n],view:new a.Ay({center:[0,0],zoom:2})})}},e=>{e(e.s=5747)}]); +//# sourceMappingURL=openmaptiles-layer.js.map \ No newline at end of file diff --git a/dist/examples/openmaptiles-layer.js.map b/dist/examples/openmaptiles-layer.js.map new file mode 100644 index 00000000..f9612efa --- /dev/null +++ b/dist/examples/openmaptiles-layer.js.map @@ -0,0 +1 @@ +{"version":3,"file":"openmaptiles-layer.js","mappings":"oKAOA,IAAIA,EAAMC,SAASC,OAAOC,QACxB,+DACA,MAEGH,IACHA,EAAMI,OAAOC,OAAO,yCACpBJ,SAASC,OACP,yBAA2BF,EAAM,2CAErC,MAAMM,EAAWC,sDAAoBP,EAE/BQ,EAAQ,IAAI,IAAgB,CAChCC,WAAW,KAEb,QAAWD,EAAOF,IAClB,QAAgBE,EAAOF,GACvB,IAAI,IAAI,CACNI,OAAQ,MACRC,OAAQ,CAACH,GACTI,KAAM,IAAI,KAAK,CACbC,OAAQ,CAAC,EAAG,GACZC,KAAM,K","sources":["webpack://ol-mapbox-style/./examples/openmaptiles-layer.js"],"sourcesContent":["import 'ol/ol.css';\nimport VectorTileLayer from 'ol/layer/VectorTile.js';\nimport {Map, View} from 'ol';\nimport {applyBackground, applyStyle} from 'ol-mapbox-style';\n\nconst baseUrl = 'https://api.maptiler.com/maps/basic/style.json';\n\nlet key = document.cookie.replace(\n /(?:(?:^|.*;\\s*)maptiler_access_token\\s*\\=\\s*([^;]*).*$)|^.*$/,\n '$1',\n);\nif (!key) {\n key = window.prompt('Enter your MapTiler API access token:');\n document.cookie =\n 'maptiler_access_token=' + key + '; expires=Fri, 31 Dec 9999 23:59:59 GMT';\n}\nconst styleUrl = baseUrl + '?key=' + key;\n\nconst layer = new VectorTileLayer({\n declutter: true,\n});\napplyStyle(layer, styleUrl);\napplyBackground(layer, styleUrl);\nnew Map({\n target: 'map',\n layers: [layer],\n view: new View({\n center: [0, 0],\n zoom: 2,\n }),\n});\n"],"names":["key","document","cookie","replace","window","prompt","styleUrl","baseUrl","layer","declutter","target","layers","view","center","zoom"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/openmaptiles.css b/dist/examples/openmaptiles.css new file mode 100644 index 00000000..5b9d618f --- /dev/null +++ b/dist/examples/openmaptiles.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=openmaptiles.css.map*/ \ No newline at end of file diff --git a/dist/examples/openmaptiles.css.map b/dist/examples/openmaptiles.css.map new file mode 100644 index 00000000..9421b695 --- /dev/null +++ b/dist/examples/openmaptiles.css.map @@ -0,0 +1 @@ +{"version":3,"file":"openmaptiles.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/openmaptiles.html b/dist/examples/openmaptiles.html new file mode 100644 index 00000000..e534d4bd --- /dev/null +++ b/dist/examples/openmaptiles.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/openmaptiles.js b/dist/examples/openmaptiles.js new file mode 100644 index 00000000..8453af7c --- /dev/null +++ b/dist/examples/openmaptiles.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[426],{1035:(e,s,o)=>{o(8508);var t=o(316);let a=document.cookie.replace(/(?:(?:^|.*;\s*)maptiler_access_token\s*\=\s*([^;]*).*$)|^.*$/,"$1");a||(a=window.prompt("Enter your MapTiler API access token:"),document.cookie="maptiler_access_token="+a+"; expires=Fri, 31 Dec 9999 23:59:59 GMT"),(0,t.Ay)("map","https://api.maptiler.com/maps/basic/style.json?key="+a)}},e=>{e(e.s=1035)}]); +//# sourceMappingURL=openmaptiles.js.map \ No newline at end of file diff --git a/dist/examples/openmaptiles.js.map b/dist/examples/openmaptiles.js.map new file mode 100644 index 00000000..0451e436 --- /dev/null +++ b/dist/examples/openmaptiles.js.map @@ -0,0 +1 @@ +{"version":3,"file":"openmaptiles.js","mappings":"sIAKA,IAAIA,EAAMC,SAASC,OAAOC,QACxB,+DACA,MAEGH,IACHA,EAAMI,OAAOC,OAAO,yCACpBJ,SAASC,OACP,yBAA2BF,EAAM,4CAGrC,QAAK,MAAOM,sDAAoBN,E","sources":["webpack://ol-mapbox-style/./examples/openmaptiles.js"],"sourcesContent":["import 'ol/ol.css';\nimport olms from 'ol-mapbox-style';\n\nconst baseUrl = 'https://api.maptiler.com/maps/basic/style.json';\n\nlet key = document.cookie.replace(\n /(?:(?:^|.*;\\s*)maptiler_access_token\\s*\\=\\s*([^;]*).*$)|^.*$/,\n '$1',\n);\nif (!key) {\n key = window.prompt('Enter your MapTiler API access token:');\n document.cookie =\n 'maptiler_access_token=' + key + '; expires=Fri, 31 Dec 9999 23:59:59 GMT';\n}\n\nolms('map', baseUrl + '?key=' + key);\n"],"names":["key","document","cookie","replace","window","prompt","baseUrl"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/pmtiles.css b/dist/examples/pmtiles.css new file mode 100644 index 00000000..e5d3c026 --- /dev/null +++ b/dist/examples/pmtiles.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=pmtiles.css.map*/ \ No newline at end of file diff --git a/dist/examples/pmtiles.css.map b/dist/examples/pmtiles.css.map new file mode 100644 index 00000000..361698fb --- /dev/null +++ b/dist/examples/pmtiles.css.map @@ -0,0 +1 @@ +{"version":3,"file":"pmtiles.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/pmtiles.html b/dist/examples/pmtiles.html new file mode 100644 index 00000000..c43cfb03 --- /dev/null +++ b/dist/examples/pmtiles.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/pmtiles.js b/dist/examples/pmtiles.js new file mode 100644 index 00000000..c2b5f05d --- /dev/null +++ b/dist/examples/pmtiles.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[497],{1922:(e,t,n)=>{n(8508);var r=n(316),i=Math.pow,o=(e,t,n)=>new Promise(((r,i)=>{var o=e=>{try{a(n.next(e))}catch(e){i(e)}},s=e=>{try{a(n.throw(e))}catch(e){i(e)}},a=e=>e.done?r(e.value):Promise.resolve(e.value).then(o,s);a((n=n.apply(e,t)).next())})),s=Uint8Array,a=Uint16Array,c=Int32Array,l=new s([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,0,0,0]),u=new s([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13,0,0]),h=new s([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),f=function(e,t){for(var n=new a(31),r=0;r<31;++r)n[r]=t+=1<>1|(21845&D)<<1))>>2|(13107&y)<<2))>>4|(3855&y)<<4,v[D]=((65280&y)>>8|(255&y)<<8)>>1;var x=function(e,t,n){for(var r=e.length,i=0,o=new a(t);i>l]=u}else for(s=new a(r),i=0;i>15-e[i]);return s},b=new s(288);for(D=0;D<144;++D)b[D]=8;for(D=144;D<256;++D)b[D]=9;for(D=256;D<280;++D)b[D]=7;for(D=280;D<288;++D)b[D]=8;var D,U=new s(32);for(D=0;D<32;++D)U[D]=5;var L=x(b,9,1),T=x(U,5,1),E=function(e){for(var t=e[0],n=1;nt&&(t=e[n]);return t},C=function(e,t,n){var r=t/8|0;return(e[r]|e[r+1]<<8)>>(7&t)&n},z=function(e,t){var n=t/8|0;return(e[n]|e[n+1]<<8|e[n+2]<<16)>>(7&t)},M=["unexpected EOF","invalid block type","invalid length/literal","invalid distance","stream finished","no stream handler",,"no callback","invalid UTF-8 data","extra field too long","date not in range 1980-2099","filename too long","stream finishing","invalid zip data"],A=function(e,t,n){var r=new Error(t||M[e]);if(r.code=e,Error.captureStackTrace&&Error.captureStackTrace(r,A),!n)throw r;return r},O=function(e,t,n,r){var i=e.length,o=r?r.length:0;if(!i||t.f&&!t.l)return n||new s(0);var a=!n||2!=t.i,c=t.i;n||(n=new s(3*i));var f=function(e){var t=n.length;if(e>t){var r=new s(Math.max(2*t,e));r.set(n),n=r}},d=t.f||0,p=t.p||0,y=t.b||0,m=t.l,v=t.d,b=t.m,D=t.n,U=8*i;do{if(!m){d=C(e,p,1);var M=C(e,p+1,3);if(p+=3,!M){var O=e[(I=4+((p+7)/8|0))-4]|e[I-3]<<8,$=I+O;if($>i){c&&A(0);break}a&&f(y+O),n.set(e.subarray(I,$),y),t.b=y+=O,t.p=p=8*$,t.f=d;continue}if(1==M)m=L,v=T,b=9,D=5;else if(2==M){var B=C(e,p,31)+257,H=C(e,p+10,15)+4,Z=B+C(e,p+5,31)+1;p+=14;for(var P=new s(Z),k=new s(19),V=0;V>4)<16)P[V++]=I;else{var W=0,J=0;for(16==I?(J=3+C(e,p,3),p+=2,W=P[V-1]):17==I?(J=3+C(e,p,7),p+=3):18==I&&(J=11+C(e,p,127),p+=7);J--;)P[V++]=W}}var K=P.subarray(0,B),_=P.subarray(B);b=E(K),D=E(_),m=x(K,b,1),v=x(_,D,1)}else A(1);if(p>U){c&&A(0);break}}a&&f(y+131072);for(var q=(1<>4;if((p+=15&W)>U){c&&A(0);break}if(W||A(2),X<256)n[y++]=X;else{if(256==X){G=p,m=null;break}var Q=X-254;if(X>264){var Y=l[V=X-257];Q=C(e,p,(1<>4;if(ee||A(3),p+=15&ee,_=w[te],te>3&&(Y=u[te],_+=z(e,p)&(1<U){c&&A(0);break}a&&f(y+131072);var ne=y+Q;if(y<_){var re=o-_,ie=Math.min(_,ne);for(re+y<0&&A(3);ye.length)&&(n=e.length);var r=new s(n-t);return r.set(e.subarray(t,n)),r}(n,0,y)},$=new s(0),B=function(e){31==e[0]&&139==e[1]&&8==e[2]||A(6,"invalid gzip data");var t=e[3],n=10;4&t&&(n+=2+(e[10]|e[11]<<8));for(var r=(t>>3&1)+(t>>4&1);r>0;r-=!e[n++]);return n+(2&t)},H=function(e){var t=e.length;return(e[t-4]|e[t-3]<<8|e[t-2]<<16|e[t-1]<<24)>>>0},Z=function(e,t){return(8!=(15&e[0])||e[0]>>4>7||(e[0]<<8|e[1])%31)&&A(6,"invalid zlib data"),(e[1]>>5&1)==+!t&&A(6,"invalid zlib data: "+(32&e[1]?"need":"unexpected")+" dictionary"),2+(e[1]>>3&4)};function P(e,t){return 31==e[0]&&139==e[1]&&8==e[2]?function(e,t){var n=B(e);return n+8>e.length&&A(6,"invalid gzip data"),O(e.subarray(n,-8),{i:2},t&&t.out||new s(H(e)),t&&t.dictionary)}(e,t):8!=(15&e[0])||e[0]>>4>7||(e[0]<<8|e[1])%31?function(e,t){return O(e,{i:2},t&&t.out,t&&t.dictionary)}(e,t):function(e,t){return O(e.subarray(Z(e,t&&t.dictionary),-4),{i:2},t&&t.out,t&&t.dictionary)}(e,t)}var k="undefined"!=typeof TextDecoder&&new TextDecoder;try{k.decode($,{stream:!0})}catch(e){}var V=(e,t)=>e*i(2,t),R=(e,t)=>Math.floor(e/i(2,t)),j=(e,t)=>V(e.getUint16(t+1,!0),8)+e.getUint8(t),S=(e,t)=>V(e.getUint32(t+2,!0),16)+e.getUint16(t,!0),I=(e,t,n,r,i)=>{if(e!==r.getUint8(i))return e-r.getUint8(i);const o=j(r,i+1);if(t!==o)return t-o;const s=j(r,i+4);return n!==s?n-s:0},N=(e,t,n,r)=>{const i=W(e,t,n,r);return i?{z:t,x:n,y:r,offset:i[0],length:i[1],isDir:!1}:null},W=(e,t,n,r)=>{let i=0,o=e.byteLength/17-1;for(;i<=o;){const s=o+i>>1,a=I(t,n,r,e,17*s);if(a>0)i=s+1;else{if(!(a<0))return[S(e,17*s+7),e.getUint32(17*s+13,!0)];o=s-1}}return null},J=(e,t)=>e.isDir&&!t.isDir?1:!e.isDir&&t.isDir?-1:e.z!==t.z?e.z-t.z:e.x!==t.x?e.x-t.x:e.y-t.y,K=(e,t)=>{const n=e.getUint8(17*t);return{z:127&n,x:j(e,17*t+1),y:j(e,17*t+4),offset:S(e,17*t+7),length:e.getUint32(17*t+13,!0),isDir:n>>7==1}},_=e=>{const t=[],n=new DataView(e);for(let e=0;e{e.sort(J);const t=new ArrayBuffer(17*e.length),n=new Uint8Array(t);for(let t=0;t>8&255,n[17*t+3]=r.x>>16&255,n[17*t+4]=255&r.y,n[17*t+5]=r.y>>8&255,n[17*t+6]=r.y>>16&255,n[17*t+7]=255&r.offset,n[17*t+8]=255&R(r.offset,8),n[17*t+9]=255&R(r.offset,16),n[17*t+10]=255&R(r.offset,24),n[17*t+11]=255&R(r.offset,32),n[17*t+12]=255&R(r.offset,48),n[17*t+13]=255&r.length,n[17*t+14]=r.length>>8&255,n[17*t+15]=r.length>>16&255,n[17*t+16]=r.length>>24&255}return t},F={getHeader:function(e){return o(this,null,(function*(){const t=yield e.getBytes(0,512e3),n=new DataView(t.data),r=n.getUint32(4,!0),i=n.getUint16(8,!0),o=new TextDecoder("utf-8"),s=JSON.parse(o.decode(new DataView(t.data,10,r)));let a=0;"gzip"===s.compression&&(a=2);let c=0;"minzoom"in s&&(c=+s.minzoom);let l=0;"maxzoom"in s&&(l=+s.maxzoom);let u=0,h=0,f=0,d=-180,g=-85,p=180,y=85;if(s.bounds){const e=s.bounds.split(",");d=+e[0],g=+e[1],p=+e[2],y=+e[3]}if(s.center){const e=s.center.split(",");u=+e[0],h=+e[1],f=+e[2]}return{specVersion:n.getUint16(2,!0),rootDirectoryOffset:10+r,rootDirectoryLength:17*i,jsonMetadataOffset:10,jsonMetadataLength:r,leafDirectoryOffset:0,leafDirectoryLength:void 0,tileDataOffset:0,tileDataLength:void 0,numAddressedTiles:0,numTileEntries:0,numTileContents:0,clustered:!1,internalCompression:1,tileCompression:a,tileType:1,minZoom:c,maxZoom:l,minLon:d,minLat:g,maxLon:p,maxLat:y,centerZoom:f,centerLon:u,centerLat:h,etag:t.etag}}))},getZxy:function(e,t,n,r,i,s,a){return o(this,null,(function*(){let o=yield n.getArrayBuffer(t,e.rootDirectoryOffset,e.rootDirectoryLength,e);1===e.specVersion&&(o=_(o));const c=N(new DataView(o),r,i,s);if(c){let e=(yield t.getBytes(c.offset,c.length,a)).data;const n=new DataView(e);return 31===n.getUint8(0)&&139===n.getUint8(1)&&(e=P(new Uint8Array(e))),{data:e}}const l=((e,t)=>{if(e.byteLength<17)return null;const n=e.byteLength/17,r=K(e,n-1);if(r.isDir){const e=r.z,n=t.z-e;return{z:e,x:Math.trunc(t.x/(1<{const i=W(e,128|t,n,r);return i?{z:t,x:n,y:r,offset:i[0],length:i[1],isDir:!0}:null})(new DataView(o),l.z,l.x,l.y);if(c){let o=yield n.getArrayBuffer(t,c.offset,c.length,e);1===e.specVersion&&(o=_(o));const l=N(new DataView(o),r,i,s);if(l){let e=(yield t.getBytes(l.offset,l.length,a)).data;const n=new DataView(e);return 31===n.getUint8(0)&&139===n.getUint8(1)&&(e=P(new Uint8Array(e))),{data:e}}}}}))}};function G(e,t){return 4294967296*(t>>>0)+(e>>>0)}function X(e){const t=e.buf;let n=t[e.pos++],r=127&n;return n<128?r:(n=t[e.pos++],r|=(127&n)<<7,n<128?r:(n=t[e.pos++],r|=(127&n)<<14,n<128?r:(n=t[e.pos++],r|=(127&n)<<21,n<128?r:(n=t[e.pos],r|=(15&n)<<28,function(e,t){const n=t.buf;let r=n[t.pos++],i=(112&r)>>4;if(r<128)return G(e,i);if(r=n[t.pos++],i|=(127&r)<<3,r<128)return G(e,i);if(r=n[t.pos++],i|=(127&r)<<10,r<128)return G(e,i);if(r=n[t.pos++],i|=(127&r)<<17,r<128)return G(e,i);if(r=n[t.pos++],i|=(127&r)<<24,r<128)return G(e,i);if(r=n[t.pos++],i|=(1&r)<<31,r<128)return G(e,i);throw new Error("Expected varint not more than 10 bytes")}(r,e)))))}function Q(e,t,n,r){if(0===r){1===n&&(t[0]=e-1-t[0],t[1]=e-1-t[1]);const r=t[0];t[0]=t[1],t[1]=r}}var Y=[0,1,5,21,85,341,1365,5461,21845,87381,349525,1398101,5592405,22369621,89478485,357913941,1431655765,5726623061,22906492245,91625968981,366503875925,1466015503701,5864062014805,23456248059221,93824992236885,375299968947541,0x5555555555555];function ee(e,t){return o(this,null,(function*(){if(1===t||0===t)return e;if(2===t){if(void 0===globalThis.DecompressionStream)return P(new Uint8Array(e));const t=new Response(e).body;if(!t)throw Error("Failed to read response stream");const n=t.pipeThrough(new globalThis.DecompressionStream("gzip"));return new Response(n).arrayBuffer()}throw Error("Compression method not supported")}))}function te(e,t){let n=0,r=e.length-1;for(;n<=r;){const i=r+n>>1,o=t-e[i].tileId;if(o>0)n=i+1;else{if(!(o<0))return e[i];r=i-1}}if(r>=0){if(0===e[r].runLength)return e[r];if(t-e[r].tileId-1,i=/Chrome|Chromium|Edg|OPR|Brave/.test(n);this.chromeWindowsNoCache=!1,r&&i&&(this.chromeWindowsNoCache=!0)}getKey(){return this.url}setHeaders(e){this.customHeaders=e}getBytes(e,t,n,r){return o(this,null,(function*(){let i,o;n?o=n:(i=new AbortController,o=i.signal);const s=new Headers(this.customHeaders);let a;s.set("range",`bytes=${e}-${e+t-1}`),this.mustReload?a="reload":this.chromeWindowsNoCache&&(a="no-store");let c=yield fetch(this.url,{signal:o,cache:a,headers:s});if(0===e&&416===c.status){const e=c.headers.get("Content-Range");if(!e||!e.startsWith("bytes */"))throw Error("Missing content-length on 416 response");const t=+e.substr(8);c=yield fetch(this.url,{signal:o,cache:"reload",headers:{range:"bytes=0-"+(t-1)}})}let l=c.headers.get("Etag");if((null==l?void 0:l.startsWith("W/"))&&(l=null),416===c.status||r&&l&&l!==r)throw this.mustReload=!0,new oe(`Server returned non-matching ETag ${r} after one retry. Check browser extensions and servers for issues that may affect correct ETag headers.`);if(c.status>=300)throw Error(`Bad response code: ${c.status}`);const u=c.headers.get("Content-Length");if(200===c.status&&(!u||+u>t))throw i&&i.abort(),Error("Server returned no content-length header or content-length exceeding request. Check that your storage backend supports HTTP Byte Serving.");return{data:yield c.arrayBuffer(),etag:l||void 0,cacheControl:c.headers.get("Cache-Control")||void 0,expires:c.headers.get("Expires")||void 0}}))}};function re(e,t){const n=e.getUint32(t+4,!0),r=e.getUint32(t+0,!0);return n*i(2,32)+r}function ie(e){const t={buf:new Uint8Array(e),pos:0},n=X(t),r=[];let i=0;for(let e=0;e0?r[e-1].offset+r[e-1].length:n-1}return r}var oe=class extends Error{};var se=class{constructor(e=100,t=!0,n=ee){this.cache=new Map,this.invalidations=new Map,this.maxCacheEntries=e,this.counter=1,this.decompress=n}getHeader(e){return o(this,null,(function*(){const t=e.getKey(),n=this.cache.get(t);if(n)return n.lastUsed=this.counter++,yield n.data;const r=new Promise(((t,n)=>{(function(e,t){return o(this,null,(function*(){const n=yield e.getBytes(0,16384);if(19792!==new DataView(n.data).getUint16(0,!0))throw new Error("Wrong magic number for PMTiles archive");if(function(e){const t=new DataView(e);return 2===t.getUint16(2,!0)?(console.warn("PMTiles spec version 2 has been deprecated; please see github.com/protomaps/PMTiles for tools to upgrade"),2):1===t.getUint16(2,!0)?(console.warn("PMTiles spec version 1 has been deprecated; please see github.com/protomaps/PMTiles for tools to upgrade"),1):3}(n.data)<3)return[yield F.getHeader(e)];const r=function(e,t){const n=new DataView(e),r=n.getUint8(7);if(r>3)throw Error(`Archive is spec version ${r} but this library supports up to spec version 3`);return{specVersion:r,rootDirectoryOffset:re(n,8),rootDirectoryLength:re(n,16),jsonMetadataOffset:re(n,24),jsonMetadataLength:re(n,32),leafDirectoryOffset:re(n,40),leafDirectoryLength:re(n,48),tileDataOffset:re(n,56),tileDataLength:re(n,64),numAddressedTiles:re(n,72),numTileEntries:re(n,80),numTileContents:re(n,88),clustered:1===n.getUint8(96),internalCompression:n.getUint8(97),tileCompression:n.getUint8(98),tileType:n.getUint8(99),minZoom:n.getUint8(100),maxZoom:n.getUint8(101),minLon:n.getInt32(102,!0)/1e7,minLat:n.getInt32(106,!0)/1e7,maxLon:n.getInt32(110,!0)/1e7,maxLat:n.getInt32(114,!0)/1e7,centerZoom:n.getUint8(118),centerLon:n.getInt32(119,!0)/1e7,centerLat:n.getInt32(123,!0)/1e7,etag:t}}(n.data.slice(0,127),n.etag),i=n.data.slice(r.rootDirectoryOffset,r.rootDirectoryOffset+r.rootDirectoryLength),o=`${e.getKey()}|${r.etag||""}|${r.rootDirectoryOffset}|${r.rootDirectoryLength}`,s=ie(yield t(i,r.internalCompression));return[r,[o,s.length,s]]}))})(e,this.decompress).then((e=>{e[1]&&this.cache.set(e[1][0],{lastUsed:this.counter++,data:Promise.resolve(e[1][2])}),t(e[0]),this.prune()})).catch((e=>{n(e)}))}));return this.cache.set(t,{lastUsed:this.counter++,data:r}),r}))}getDirectory(e,t,n,r){return o(this,null,(function*(){const i=`${e.getKey()}|${r.etag||""}|${t}|${n}`,s=this.cache.get(i);if(s)return s.lastUsed=this.counter++,yield s.data;const a=new Promise(((i,s)=>{(function(e,t,n,r,i){return o(this,null,(function*(){const o=yield e.getBytes(n,r,void 0,i.etag),s=ie(yield t(o.data,i.internalCompression));if(0===s.length)throw new Error("Empty directory is invalid");return s}))})(e,this.decompress,t,n,r).then((e=>{i(e),this.prune()})).catch((e=>{s(e)}))}));return this.cache.set(i,{lastUsed:this.counter++,data:a}),a}))}getArrayBuffer(e,t,n,r){return o(this,null,(function*(){const i=`${e.getKey()}|${r.etag||""}|${t}|${n}`,o=this.cache.get(i);if(o)return o.lastUsed=this.counter++,yield o.data;const s=new Promise(((o,s)=>{e.getBytes(t,n,void 0,r.etag).then((e=>{o(e.data),this.cache.has(i),this.prune()})).catch((e=>{s(e)}))}));return this.cache.set(i,{lastUsed:this.counter++,data:s}),s}))}prune(){if(this.cache.size>=this.maxCacheEntries){let e,t=1/0;this.cache.forEach(((n,r)=>{n.lastUsed{this.getHeader(e).then((e=>{n(),this.invalidations.delete(t)})).catch((e=>{r(e)}))}));this.invalidations.set(t,n)}))}},ae=class{constructor(e,t,n){this.source="string"==typeof e?new ne(e):e,this.decompress=n||ee,this.cache=t||new se}getHeader(){return o(this,null,(function*(){return yield this.cache.getHeader(this.source)}))}getZxyAttempt(e,t,n,r){return o(this,null,(function*(){const o=function(e,t,n){if(e>26)throw Error("Tile zoom level exceeds max safe number limit (26)");if(t>i(2,e)-1||n>i(2,e)-1)throw Error("tile x/y outside zoom level bounds");const r=Y[e];let o=0,s=0,a=0;const c=[t,n];let l=i(2,e)/2;for(;l>0;)o=(c[0]&l)>0?1:0,s=(c[1]&l)>0?1:0,a+=l*l*(3*o^s),Q(l,c,o,s),l/=2;return r+a}(e,t,n),s=yield this.cache.getHeader(this.source);if(s.specVersion<3)return F.getZxy(s,this.source,this.cache,e,t,n,r);if(es.maxZoom)return;let a=s.rootDirectoryOffset,c=s.rootDirectoryLength;for(let e=0;e<=3;e++){const e=te(yield this.cache.getDirectory(this.source,a,c,s),o);if(!e)return;if(e.runLength>0){const t=yield this.source.getBytes(s.tileDataOffset+e.offset,e.length,r,s.etag);return{data:yield this.decompress(t.data,s.tileCompression),cacheControl:t.cacheControl,expires:t.expires}}a=s.leafDirectoryOffset+e.offset,c=e.length}throw Error("Maximum directory depth exceeded")}))}getZxy(e,t,n,r){return o(this,null,(function*(){try{return yield this.getZxyAttempt(e,t,n,r)}catch(i){if(i instanceof oe)return this.cache.invalidate(this.source),yield this.getZxyAttempt(e,t,n,r);throw i}}))}getMetadataAttempt(){return o(this,null,(function*(){const e=yield this.cache.getHeader(this.source),t=yield this.source.getBytes(e.jsonMetadataOffset,e.jsonMetadataLength,void 0,e.etag),n=yield this.decompress(t.data,e.internalCompression),r=new TextDecoder("utf-8");return JSON.parse(r.decode(n))}))}getMetadata(){return o(this,null,(function*(){try{return yield this.getMetadataAttempt()}catch(e){if(e instanceof oe)return this.cache.invalidate(this.source),yield this.getMetadataAttempt();throw e}}))}getTileJson(e){return o(this,null,(function*(){const t=yield this.getHeader(),n=yield this.getMetadata(),r=1===(i=t.tileType)?".mvt":2===i?".png":3===i?".jpg":4===i?".webp":5===i?".avif":"";var i;return{tilejson:"3.0.0",scheme:"xyz",tiles:[`${e}/{z}/{x}/{y}${r}`],vector_layers:n.vector_layers,attribution:n.attribution,description:n.description,name:n.name,version:n.version,bounds:[t.minLon,t.minLat,t.maxLon,t.maxLat],center:[t.centerLon,t.centerLat,t.centerZoom],minzoom:t.minZoom,maxzoom:t.maxZoom}}))}};const ce=["application/octet-stream","application/x-protobuf","image/png","image/jpeg","image/webp","image/avif"],le=/\/([0-9]+)\/([0-9]+)\/([0-9]+).(mvt|png|jpg|webp|avif)$/,ue=/^pmtiles:\/\//,he=/^http(s?)\/\//,fe={},{fetch:de,XMLHttpRequest:ge}=window,pe=new Proxy(de,{apply:async(e,t,[n,r])=>{let i;if(n instanceof Request){if("GET"!==n.method)return e.call(t,n,r);i=n.url}else i=n.toString();if(!ue.test(i))return e.call(t,n,r);i=i.replace(ue,"").replace(he,"http$1://");let o=i,s=null;if(le.test(i)&&(o=i.replace(le,""),s=i.match(le)?.slice(1).map(Number)),o in fe||(fe[o]=new ae(o)),s){const e=await fe[o].getZxy(...s);if(!e)return new Response(null,{status:404});const t=await fe[o].getHeader();return new Response(e.data,{headers:{"Content-Type":ce[t.tileType]}})}{const e=await fe[o].getTileJson("pmtiles://"+o);return new Response(JSON.stringify(e),{headers:{"Content-Type":"application/json"}})}}});window.fetch=pe,window.XMLHttpRequest=class extends ge{constructor(){let e,t,n,r,i,o;super();let s=null;return new Proxy(this,{get:(a,c)=>"open"===c?(t,n,r=!0,i,o)=>{if("GET"!==t||!ue.test(n))return this.open(t,n,r,i,o);n=n.replace(ue,"").replace(he,"http$1://"),e=n,le.test(n)&&(e=n.replace(le,""),s=n.match(le)?.slice(1).map(Number)||null),e in fe||(fe[e]=new ae(e))}:"send"===c?async a=>{if(!e)return this.send(a);try{const n=new ProgressEvent("load");if(s){const i=await fe[e].getZxy(s[0],s[1],s[2]);i?(o=200,r=i.data):(o=404,r=null),this.dispatchEvent(n),t&&t(n)}else{const r=await fe[e].getTileJson("pmtiles://"+e);o=200,i=JSON.stringify(r),this.dispatchEvent(n),t&&t(n)}}catch(e){console.error(e);const t=new ProgressEvent("error");this.dispatchEvent(t),n&&n(t)}}:"response"===c&&r?r:"responseText"===c&&i?i:"status"===c&&o?o:a[c],set:(e,r,i)=>("onload"===r?t=i:"onerror"===r&&(n=i),e[r]=i,!0)})}},(0,r.Bb)("map","data/protomaps-dark-style.json")}},e=>{e(e.s=1922)}]); +//# sourceMappingURL=pmtiles.js.map \ No newline at end of file diff --git a/dist/examples/pmtiles.js.map b/dist/examples/pmtiles.js.map new file mode 100644 index 00000000..6cd5d233 --- /dev/null +++ b/dist/examples/pmtiles.js.map @@ -0,0 +1 @@ +{"version":3,"file":"pmtiles.js","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/pmtiles/dist/index.js","webpack://ol-mapbox-style/./node_modules/pmtiles-protocol/index.js","webpack://ol-mapbox-style/./examples/pmtiles.js"],"sourcesContent":["var __pow = Math.pow;\nvar __async = (__this, __arguments, generator) => {\n return new Promise((resolve, reject) => {\n var fulfilled = (value) => {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n };\n var rejected = (value) => {\n try {\n step(generator.throw(value));\n } catch (e) {\n reject(e);\n }\n };\n var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);\n step((generator = generator.apply(__this, __arguments)).next());\n });\n};\n\n// node_modules/fflate/esm/browser.js\nvar u8 = Uint8Array;\nvar u16 = Uint16Array;\nvar i32 = Int32Array;\nvar fleb = new u8([\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 0,\n 1,\n 1,\n 1,\n 1,\n 2,\n 2,\n 2,\n 2,\n 3,\n 3,\n 3,\n 3,\n 4,\n 4,\n 4,\n 4,\n 5,\n 5,\n 5,\n 5,\n 0,\n /* unused */\n 0,\n 0,\n /* impossible */\n 0\n]);\nvar fdeb = new u8([\n 0,\n 0,\n 0,\n 0,\n 1,\n 1,\n 2,\n 2,\n 3,\n 3,\n 4,\n 4,\n 5,\n 5,\n 6,\n 6,\n 7,\n 7,\n 8,\n 8,\n 9,\n 9,\n 10,\n 10,\n 11,\n 11,\n 12,\n 12,\n 13,\n 13,\n /* unused */\n 0,\n 0\n]);\nvar clim = new u8([16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15]);\nvar freb = function(eb, start) {\n var b = new u16(31);\n for (var i = 0; i < 31; ++i) {\n b[i] = start += 1 << eb[i - 1];\n }\n var r = new i32(b[30]);\n for (var i = 1; i < 30; ++i) {\n for (var j = b[i]; j < b[i + 1]; ++j) {\n r[j] = j - b[i] << 5 | i;\n }\n }\n return { b, r };\n};\nvar _a = freb(fleb, 2);\nvar fl = _a.b;\nvar revfl = _a.r;\nfl[28] = 258, revfl[258] = 28;\nvar _b = freb(fdeb, 0);\nvar fd = _b.b;\nvar revfd = _b.r;\nvar rev = new u16(32768);\nfor (i = 0; i < 32768; ++i) {\n x = (i & 43690) >> 1 | (i & 21845) << 1;\n x = (x & 52428) >> 2 | (x & 13107) << 2;\n x = (x & 61680) >> 4 | (x & 3855) << 4;\n rev[i] = ((x & 65280) >> 8 | (x & 255) << 8) >> 1;\n}\nvar x;\nvar i;\nvar hMap = function(cd, mb, r) {\n var s = cd.length;\n var i = 0;\n var l = new u16(mb);\n for (; i < s; ++i) {\n if (cd[i])\n ++l[cd[i] - 1];\n }\n var le = new u16(mb);\n for (i = 1; i < mb; ++i) {\n le[i] = le[i - 1] + l[i - 1] << 1;\n }\n var co;\n if (r) {\n co = new u16(1 << mb);\n var rvb = 15 - mb;\n for (i = 0; i < s; ++i) {\n if (cd[i]) {\n var sv = i << 4 | cd[i];\n var r_1 = mb - cd[i];\n var v = le[cd[i] - 1]++ << r_1;\n for (var m = v | (1 << r_1) - 1; v <= m; ++v) {\n co[rev[v] >> rvb] = sv;\n }\n }\n }\n } else {\n co = new u16(s);\n for (i = 0; i < s; ++i) {\n if (cd[i]) {\n co[i] = rev[le[cd[i] - 1]++] >> 15 - cd[i];\n }\n }\n }\n return co;\n};\nvar flt = new u8(288);\nfor (i = 0; i < 144; ++i)\n flt[i] = 8;\nvar i;\nfor (i = 144; i < 256; ++i)\n flt[i] = 9;\nvar i;\nfor (i = 256; i < 280; ++i)\n flt[i] = 7;\nvar i;\nfor (i = 280; i < 288; ++i)\n flt[i] = 8;\nvar i;\nvar fdt = new u8(32);\nfor (i = 0; i < 32; ++i)\n fdt[i] = 5;\nvar i;\nvar flrm = /* @__PURE__ */ hMap(flt, 9, 1);\nvar fdrm = /* @__PURE__ */ hMap(fdt, 5, 1);\nvar max = function(a) {\n var m = a[0];\n for (var i = 1; i < a.length; ++i) {\n if (a[i] > m)\n m = a[i];\n }\n return m;\n};\nvar bits = function(d, p, m) {\n var o = p / 8 | 0;\n return (d[o] | d[o + 1] << 8) >> (p & 7) & m;\n};\nvar bits16 = function(d, p) {\n var o = p / 8 | 0;\n return (d[o] | d[o + 1] << 8 | d[o + 2] << 16) >> (p & 7);\n};\nvar shft = function(p) {\n return (p + 7) / 8 | 0;\n};\nvar slc = function(v, s, e) {\n if (s == null || s < 0)\n s = 0;\n if (e == null || e > v.length)\n e = v.length;\n var n = new u8(e - s);\n n.set(v.subarray(s, e));\n return n;\n};\nvar ec = [\n \"unexpected EOF\",\n \"invalid block type\",\n \"invalid length/literal\",\n \"invalid distance\",\n \"stream finished\",\n \"no stream handler\",\n ,\n \"no callback\",\n \"invalid UTF-8 data\",\n \"extra field too long\",\n \"date not in range 1980-2099\",\n \"filename too long\",\n \"stream finishing\",\n \"invalid zip data\"\n // determined by unknown compression method\n];\nvar err = function(ind, msg, nt) {\n var e = new Error(msg || ec[ind]);\n e.code = ind;\n if (Error.captureStackTrace)\n Error.captureStackTrace(e, err);\n if (!nt)\n throw e;\n return e;\n};\nvar inflt = function(dat, st, buf, dict) {\n var sl = dat.length, dl = dict ? dict.length : 0;\n if (!sl || st.f && !st.l)\n return buf || new u8(0);\n var noBuf = !buf || st.i != 2;\n var noSt = st.i;\n if (!buf)\n buf = new u8(sl * 3);\n var cbuf = function(l2) {\n var bl = buf.length;\n if (l2 > bl) {\n var nbuf = new u8(Math.max(bl * 2, l2));\n nbuf.set(buf);\n buf = nbuf;\n }\n };\n var final = st.f || 0, pos = st.p || 0, bt = st.b || 0, lm = st.l, dm = st.d, lbt = st.m, dbt = st.n;\n var tbts = sl * 8;\n do {\n if (!lm) {\n final = bits(dat, pos, 1);\n var type = bits(dat, pos + 1, 3);\n pos += 3;\n if (!type) {\n var s = shft(pos) + 4, l = dat[s - 4] | dat[s - 3] << 8, t = s + l;\n if (t > sl) {\n if (noSt)\n err(0);\n break;\n }\n if (noBuf)\n cbuf(bt + l);\n buf.set(dat.subarray(s, t), bt);\n st.b = bt += l, st.p = pos = t * 8, st.f = final;\n continue;\n } else if (type == 1)\n lm = flrm, dm = fdrm, lbt = 9, dbt = 5;\n else if (type == 2) {\n var hLit = bits(dat, pos, 31) + 257, hcLen = bits(dat, pos + 10, 15) + 4;\n var tl = hLit + bits(dat, pos + 5, 31) + 1;\n pos += 14;\n var ldt = new u8(tl);\n var clt = new u8(19);\n for (var i = 0; i < hcLen; ++i) {\n clt[clim[i]] = bits(dat, pos + i * 3, 7);\n }\n pos += hcLen * 3;\n var clb = max(clt), clbmsk = (1 << clb) - 1;\n var clm = hMap(clt, clb, 1);\n for (var i = 0; i < tl; ) {\n var r = clm[bits(dat, pos, clbmsk)];\n pos += r & 15;\n var s = r >> 4;\n if (s < 16) {\n ldt[i++] = s;\n } else {\n var c = 0, n = 0;\n if (s == 16)\n n = 3 + bits(dat, pos, 3), pos += 2, c = ldt[i - 1];\n else if (s == 17)\n n = 3 + bits(dat, pos, 7), pos += 3;\n else if (s == 18)\n n = 11 + bits(dat, pos, 127), pos += 7;\n while (n--)\n ldt[i++] = c;\n }\n }\n var lt = ldt.subarray(0, hLit), dt = ldt.subarray(hLit);\n lbt = max(lt);\n dbt = max(dt);\n lm = hMap(lt, lbt, 1);\n dm = hMap(dt, dbt, 1);\n } else\n err(1);\n if (pos > tbts) {\n if (noSt)\n err(0);\n break;\n }\n }\n if (noBuf)\n cbuf(bt + 131072);\n var lms = (1 << lbt) - 1, dms = (1 << dbt) - 1;\n var lpos = pos;\n for (; ; lpos = pos) {\n var c = lm[bits16(dat, pos) & lms], sym = c >> 4;\n pos += c & 15;\n if (pos > tbts) {\n if (noSt)\n err(0);\n break;\n }\n if (!c)\n err(2);\n if (sym < 256)\n buf[bt++] = sym;\n else if (sym == 256) {\n lpos = pos, lm = null;\n break;\n } else {\n var add = sym - 254;\n if (sym > 264) {\n var i = sym - 257, b = fleb[i];\n add = bits(dat, pos, (1 << b) - 1) + fl[i];\n pos += b;\n }\n var d = dm[bits16(dat, pos) & dms], dsym = d >> 4;\n if (!d)\n err(3);\n pos += d & 15;\n var dt = fd[dsym];\n if (dsym > 3) {\n var b = fdeb[dsym];\n dt += bits16(dat, pos) & (1 << b) - 1, pos += b;\n }\n if (pos > tbts) {\n if (noSt)\n err(0);\n break;\n }\n if (noBuf)\n cbuf(bt + 131072);\n var end = bt + add;\n if (bt < dt) {\n var shift2 = dl - dt, dend = Math.min(dt, end);\n if (shift2 + bt < 0)\n err(3);\n for (; bt < dend; ++bt)\n buf[bt] = dict[shift2 + bt];\n }\n for (; bt < end; bt += 4) {\n buf[bt] = buf[bt - dt];\n buf[bt + 1] = buf[bt + 1 - dt];\n buf[bt + 2] = buf[bt + 2 - dt];\n buf[bt + 3] = buf[bt + 3 - dt];\n }\n bt = end;\n }\n }\n st.l = lm, st.p = lpos, st.b = bt, st.f = final;\n if (lm)\n final = 1, st.m = lbt, st.d = dm, st.n = dbt;\n } while (!final);\n return bt == buf.length ? buf : slc(buf, 0, bt);\n};\nvar et = /* @__PURE__ */ new u8(0);\nvar gzs = function(d) {\n if (d[0] != 31 || d[1] != 139 || d[2] != 8)\n err(6, \"invalid gzip data\");\n var flg = d[3];\n var st = 10;\n if (flg & 4)\n st += (d[10] | d[11] << 8) + 2;\n for (var zs = (flg >> 3 & 1) + (flg >> 4 & 1); zs > 0; zs -= !d[st++])\n ;\n return st + (flg & 2);\n};\nvar gzl = function(d) {\n var l = d.length;\n return (d[l - 4] | d[l - 3] << 8 | d[l - 2] << 16 | d[l - 1] << 24) >>> 0;\n};\nvar zls = function(d, dict) {\n if ((d[0] & 15) != 8 || d[0] >> 4 > 7 || (d[0] << 8 | d[1]) % 31)\n err(6, \"invalid zlib data\");\n if ((d[1] >> 5 & 1) == +!dict)\n err(6, \"invalid zlib data: \" + (d[1] & 32 ? \"need\" : \"unexpected\") + \" dictionary\");\n return (d[1] >> 3 & 4) + 2;\n};\nfunction inflateSync(data, opts) {\n return inflt(data, { i: 2 }, opts && opts.out, opts && opts.dictionary);\n}\nfunction gunzipSync(data, opts) {\n var st = gzs(data);\n if (st + 8 > data.length)\n err(6, \"invalid gzip data\");\n return inflt(data.subarray(st, -8), { i: 2 }, opts && opts.out || new u8(gzl(data)), opts && opts.dictionary);\n}\nfunction unzlibSync(data, opts) {\n return inflt(data.subarray(zls(data, opts && opts.dictionary), -4), { i: 2 }, opts && opts.out, opts && opts.dictionary);\n}\nfunction decompressSync(data, opts) {\n return data[0] == 31 && data[1] == 139 && data[2] == 8 ? gunzipSync(data, opts) : (data[0] & 15) != 8 || data[0] >> 4 > 7 || (data[0] << 8 | data[1]) % 31 ? inflateSync(data, opts) : unzlibSync(data, opts);\n}\nvar td = typeof TextDecoder != \"undefined\" && /* @__PURE__ */ new TextDecoder();\nvar tds = 0;\ntry {\n td.decode(et, { stream: true });\n tds = 1;\n} catch (e) {\n}\n\n// v2.ts\nvar shift = (n, shift2) => {\n return n * __pow(2, shift2);\n};\nvar unshift = (n, shift2) => {\n return Math.floor(n / __pow(2, shift2));\n};\nvar getUint24 = (view, pos) => {\n return shift(view.getUint16(pos + 1, true), 8) + view.getUint8(pos);\n};\nvar getUint48 = (view, pos) => {\n return shift(view.getUint32(pos + 2, true), 16) + view.getUint16(pos, true);\n};\nvar compare = (tz, tx, ty, view, i) => {\n if (tz !== view.getUint8(i))\n return tz - view.getUint8(i);\n const x = getUint24(view, i + 1);\n if (tx !== x)\n return tx - x;\n const y = getUint24(view, i + 4);\n if (ty !== y)\n return ty - y;\n return 0;\n};\nvar queryLeafdir = (view, z, x, y) => {\n const offsetLen = queryView(view, z | 128, x, y);\n if (offsetLen) {\n return {\n z,\n x,\n y,\n offset: offsetLen[0],\n length: offsetLen[1],\n isDir: true\n };\n }\n return null;\n};\nvar queryTile = (view, z, x, y) => {\n const offsetLen = queryView(view, z, x, y);\n if (offsetLen) {\n return {\n z,\n x,\n y,\n offset: offsetLen[0],\n length: offsetLen[1],\n isDir: false\n };\n }\n return null;\n};\nvar queryView = (view, z, x, y) => {\n let m = 0;\n let n = view.byteLength / 17 - 1;\n while (m <= n) {\n const k = n + m >> 1;\n const cmp = compare(z, x, y, view, k * 17);\n if (cmp > 0) {\n m = k + 1;\n } else if (cmp < 0) {\n n = k - 1;\n } else {\n return [getUint48(view, k * 17 + 7), view.getUint32(k * 17 + 13, true)];\n }\n }\n return null;\n};\nvar entrySort = (a, b) => {\n if (a.isDir && !b.isDir) {\n return 1;\n }\n if (!a.isDir && b.isDir) {\n return -1;\n }\n if (a.z !== b.z) {\n return a.z - b.z;\n }\n if (a.x !== b.x) {\n return a.x - b.x;\n }\n return a.y - b.y;\n};\nvar parseEntry = (dataview, i) => {\n const zRaw = dataview.getUint8(i * 17);\n const z = zRaw & 127;\n return {\n z,\n x: getUint24(dataview, i * 17 + 1),\n y: getUint24(dataview, i * 17 + 4),\n offset: getUint48(dataview, i * 17 + 7),\n length: dataview.getUint32(i * 17 + 13, true),\n isDir: zRaw >> 7 === 1\n };\n};\nvar sortDir = (a) => {\n const entries = [];\n const view = new DataView(a);\n for (let i = 0; i < view.byteLength / 17; i++) {\n entries.push(parseEntry(view, i));\n }\n return createDirectory(entries);\n};\nvar createDirectory = (entries) => {\n entries.sort(entrySort);\n const buffer = new ArrayBuffer(17 * entries.length);\n const arr = new Uint8Array(buffer);\n for (let i = 0; i < entries.length; i++) {\n const entry = entries[i];\n let z = entry.z;\n if (entry.isDir)\n z = z | 128;\n arr[i * 17] = z;\n arr[i * 17 + 1] = entry.x & 255;\n arr[i * 17 + 2] = entry.x >> 8 & 255;\n arr[i * 17 + 3] = entry.x >> 16 & 255;\n arr[i * 17 + 4] = entry.y & 255;\n arr[i * 17 + 5] = entry.y >> 8 & 255;\n arr[i * 17 + 6] = entry.y >> 16 & 255;\n arr[i * 17 + 7] = entry.offset & 255;\n arr[i * 17 + 8] = unshift(entry.offset, 8) & 255;\n arr[i * 17 + 9] = unshift(entry.offset, 16) & 255;\n arr[i * 17 + 10] = unshift(entry.offset, 24) & 255;\n arr[i * 17 + 11] = unshift(entry.offset, 32) & 255;\n arr[i * 17 + 12] = unshift(entry.offset, 48) & 255;\n arr[i * 17 + 13] = entry.length & 255;\n arr[i * 17 + 14] = entry.length >> 8 & 255;\n arr[i * 17 + 15] = entry.length >> 16 & 255;\n arr[i * 17 + 16] = entry.length >> 24 & 255;\n }\n return buffer;\n};\nvar deriveLeaf = (view, tile) => {\n if (view.byteLength < 17)\n return null;\n const numEntries = view.byteLength / 17;\n const entry = parseEntry(view, numEntries - 1);\n if (entry.isDir) {\n const leafLevel = entry.z;\n const levelDiff = tile.z - leafLevel;\n const leafX = Math.trunc(tile.x / (1 << levelDiff));\n const leafY = Math.trunc(tile.y / (1 << levelDiff));\n return { z: leafLevel, x: leafX, y: leafY };\n }\n return null;\n};\nfunction getHeader(source) {\n return __async(this, null, function* () {\n const resp = yield source.getBytes(0, 512e3);\n const dataview = new DataView(resp.data);\n const jsonSize = dataview.getUint32(4, true);\n const rootEntries = dataview.getUint16(8, true);\n const dec = new TextDecoder(\"utf-8\");\n const jsonMetadata = JSON.parse(\n dec.decode(new DataView(resp.data, 10, jsonSize))\n );\n let tileCompression = 0 /* Unknown */;\n if (jsonMetadata.compression === \"gzip\") {\n tileCompression = 2 /* Gzip */;\n }\n let minzoom = 0;\n if (\"minzoom\" in jsonMetadata) {\n minzoom = +jsonMetadata.minzoom;\n }\n let maxzoom = 0;\n if (\"maxzoom\" in jsonMetadata) {\n maxzoom = +jsonMetadata.maxzoom;\n }\n let centerLon = 0;\n let centerLat = 0;\n let centerZoom = 0;\n let minLon = -180;\n let minLat = -85;\n let maxLon = 180;\n let maxLat = 85;\n if (jsonMetadata.bounds) {\n const split = jsonMetadata.bounds.split(\",\");\n minLon = +split[0];\n minLat = +split[1];\n maxLon = +split[2];\n maxLat = +split[3];\n }\n if (jsonMetadata.center) {\n const split = jsonMetadata.center.split(\",\");\n centerLon = +split[0];\n centerLat = +split[1];\n centerZoom = +split[2];\n }\n const header = {\n specVersion: dataview.getUint16(2, true),\n rootDirectoryOffset: 10 + jsonSize,\n rootDirectoryLength: rootEntries * 17,\n jsonMetadataOffset: 10,\n jsonMetadataLength: jsonSize,\n leafDirectoryOffset: 0,\n leafDirectoryLength: void 0,\n tileDataOffset: 0,\n tileDataLength: void 0,\n numAddressedTiles: 0,\n numTileEntries: 0,\n numTileContents: 0,\n clustered: false,\n internalCompression: 1 /* None */,\n tileCompression,\n tileType: 1 /* Mvt */,\n minZoom: minzoom,\n maxZoom: maxzoom,\n minLon,\n minLat,\n maxLon,\n maxLat,\n centerZoom,\n centerLon,\n centerLat,\n etag: resp.etag\n };\n return header;\n });\n}\nfunction getZxy(header, source, cache, z, x, y, signal) {\n return __async(this, null, function* () {\n let rootDir = yield cache.getArrayBuffer(\n source,\n header.rootDirectoryOffset,\n header.rootDirectoryLength,\n header\n );\n if (header.specVersion === 1) {\n rootDir = sortDir(rootDir);\n }\n const entry = queryTile(new DataView(rootDir), z, x, y);\n if (entry) {\n const resp = yield source.getBytes(entry.offset, entry.length, signal);\n let tileData = resp.data;\n const view = new DataView(tileData);\n if (view.getUint8(0) === 31 && view.getUint8(1) === 139) {\n tileData = decompressSync(new Uint8Array(tileData));\n }\n return {\n data: tileData\n };\n }\n const leafcoords = deriveLeaf(new DataView(rootDir), { z, x, y });\n if (leafcoords) {\n const leafdirEntry = queryLeafdir(\n new DataView(rootDir),\n leafcoords.z,\n leafcoords.x,\n leafcoords.y\n );\n if (leafdirEntry) {\n let leafDir = yield cache.getArrayBuffer(\n source,\n leafdirEntry.offset,\n leafdirEntry.length,\n header\n );\n if (header.specVersion === 1) {\n leafDir = sortDir(leafDir);\n }\n const tileEntry = queryTile(new DataView(leafDir), z, x, y);\n if (tileEntry) {\n const resp = yield source.getBytes(\n tileEntry.offset,\n tileEntry.length,\n signal\n );\n let tileData = resp.data;\n const view = new DataView(tileData);\n if (view.getUint8(0) === 31 && view.getUint8(1) === 139) {\n tileData = decompressSync(new Uint8Array(tileData));\n }\n return {\n data: tileData\n };\n }\n }\n }\n return void 0;\n });\n}\nvar v2_default = {\n getHeader,\n getZxy\n};\n\n// adapters.ts\nvar leafletRasterLayer = (source, options) => {\n let loaded = false;\n let mimeType = \"\";\n const cls = L.GridLayer.extend({\n createTile: (coord, done) => {\n const el = document.createElement(\"img\");\n const controller = new AbortController();\n const signal = controller.signal;\n el.cancel = () => {\n controller.abort();\n };\n if (!loaded) {\n source.getHeader().then((header) => {\n if (header.tileType === 1 /* Mvt */) {\n console.error(\n \"Error: archive contains MVT vector tiles, but leafletRasterLayer is for displaying raster tiles. See https://github.com/protomaps/PMTiles/tree/main/js for details.\"\n );\n } else if (header.tileType === 2) {\n mimeType = \"image/png\";\n } else if (header.tileType === 3) {\n mimeType = \"image/jpeg\";\n } else if (header.tileType === 4) {\n mimeType = \"image/webp\";\n } else if (header.tileType === 5) {\n mimeType = \"image/avif\";\n }\n });\n loaded = true;\n }\n source.getZxy(coord.z, coord.x, coord.y, signal).then((arr) => {\n if (arr) {\n const blob = new Blob([arr.data], { type: mimeType });\n const imageUrl = window.URL.createObjectURL(blob);\n el.src = imageUrl;\n el.cancel = void 0;\n done(void 0, el);\n }\n }).catch((e) => {\n if (e.name !== \"AbortError\") {\n throw e;\n }\n });\n return el;\n },\n _removeTile: function(key) {\n const tile = this._tiles[key];\n if (!tile) {\n return;\n }\n if (tile.el.cancel)\n tile.el.cancel();\n tile.el.width = 0;\n tile.el.height = 0;\n tile.el.deleted = true;\n L.DomUtil.remove(tile.el);\n delete this._tiles[key];\n this.fire(\"tileunload\", {\n tile: tile.el,\n coords: this._keyToTileCoords(key)\n });\n }\n });\n return new cls(options);\n};\nvar v3compat = (v4) => (requestParameters, arg2) => {\n if (arg2 instanceof AbortController) {\n return v4(requestParameters, arg2);\n }\n const abortController = new AbortController();\n v4(requestParameters, abortController).then(\n (result) => {\n return arg2(\n void 0,\n result.data,\n result.cacheControl || \"\",\n result.expires || \"\"\n );\n },\n (err2) => {\n return arg2(err2);\n }\n ).catch((e) => {\n return arg2(e);\n });\n return { cancel: () => abortController.abort() };\n};\nvar Protocol = class {\n /**\n * Initialize the MapLibre PMTiles protocol.\n *\n * * metadata: also load the metadata section of the PMTiles. required for some \"inspect\" functionality\n * and to automatically populate the map attribution. Requires an extra HTTP request.\n */\n constructor(options) {\n /** @hidden */\n this.tilev4 = (params, abortController) => __async(this, null, function* () {\n if (params.type === \"json\") {\n const pmtilesUrl2 = params.url.substr(10);\n let instance2 = this.tiles.get(pmtilesUrl2);\n if (!instance2) {\n instance2 = new PMTiles(pmtilesUrl2);\n this.tiles.set(pmtilesUrl2, instance2);\n }\n if (this.metadata) {\n return {\n data: yield instance2.getTileJson(params.url)\n };\n }\n const h = yield instance2.getHeader();\n return {\n data: {\n tiles: [`${params.url}/{z}/{x}/{y}`],\n minzoom: h.minZoom,\n maxzoom: h.maxZoom,\n bounds: [h.minLon, h.minLat, h.maxLon, h.maxLat]\n }\n };\n }\n const re = new RegExp(/pmtiles:\\/\\/(.+)\\/(\\d+)\\/(\\d+)\\/(\\d+)/);\n const result = params.url.match(re);\n if (!result) {\n throw new Error(\"Invalid PMTiles protocol URL\");\n }\n const pmtilesUrl = result[1];\n let instance = this.tiles.get(pmtilesUrl);\n if (!instance) {\n instance = new PMTiles(pmtilesUrl);\n this.tiles.set(pmtilesUrl, instance);\n }\n const z = result[2];\n const x = result[3];\n const y = result[4];\n const header = yield instance.getHeader();\n const resp = yield instance == null ? void 0 : instance.getZxy(+z, +x, +y, abortController.signal);\n if (resp) {\n return {\n data: new Uint8Array(resp.data),\n cacheControl: resp.cacheControl,\n expires: resp.expires\n };\n }\n if (header.tileType === 1 /* Mvt */) {\n return { data: new Uint8Array() };\n }\n return { data: null };\n });\n this.tile = v3compat(this.tilev4);\n this.tiles = /* @__PURE__ */ new Map();\n this.metadata = (options == null ? void 0 : options.metadata) || false;\n }\n /**\n * Add a {@link PMTiles} instance to the global protocol instance.\n *\n * For remote fetch sources, references in MapLibre styles like pmtiles://http://...\n * will resolve to the same instance if the URLs match.\n */\n add(p) {\n this.tiles.set(p.source.getKey(), p);\n }\n /**\n * Fetch a {@link PMTiles} instance by URL, for remote PMTiles instances.\n */\n get(url) {\n return this.tiles.get(url);\n }\n};\n\n// index.ts\nfunction toNum(low, high) {\n return (high >>> 0) * 4294967296 + (low >>> 0);\n}\nfunction readVarintRemainder(l, p) {\n const buf = p.buf;\n let b = buf[p.pos++];\n let h = (b & 112) >> 4;\n if (b < 128)\n return toNum(l, h);\n b = buf[p.pos++];\n h |= (b & 127) << 3;\n if (b < 128)\n return toNum(l, h);\n b = buf[p.pos++];\n h |= (b & 127) << 10;\n if (b < 128)\n return toNum(l, h);\n b = buf[p.pos++];\n h |= (b & 127) << 17;\n if (b < 128)\n return toNum(l, h);\n b = buf[p.pos++];\n h |= (b & 127) << 24;\n if (b < 128)\n return toNum(l, h);\n b = buf[p.pos++];\n h |= (b & 1) << 31;\n if (b < 128)\n return toNum(l, h);\n throw new Error(\"Expected varint not more than 10 bytes\");\n}\nfunction readVarint(p) {\n const buf = p.buf;\n let b = buf[p.pos++];\n let val = b & 127;\n if (b < 128)\n return val;\n b = buf[p.pos++];\n val |= (b & 127) << 7;\n if (b < 128)\n return val;\n b = buf[p.pos++];\n val |= (b & 127) << 14;\n if (b < 128)\n return val;\n b = buf[p.pos++];\n val |= (b & 127) << 21;\n if (b < 128)\n return val;\n b = buf[p.pos];\n val |= (b & 15) << 28;\n return readVarintRemainder(val, p);\n}\nfunction rotate(n, xy, rx, ry) {\n if (ry === 0) {\n if (rx === 1) {\n xy[0] = n - 1 - xy[0];\n xy[1] = n - 1 - xy[1];\n }\n const t = xy[0];\n xy[0] = xy[1];\n xy[1] = t;\n }\n}\nfunction idOnLevel(z, pos) {\n const n = __pow(2, z);\n let rx = pos;\n let ry = pos;\n let t = pos;\n const xy = [0, 0];\n let s = 1;\n while (s < n) {\n rx = 1 & t / 2;\n ry = 1 & (t ^ rx);\n rotate(s, xy, rx, ry);\n xy[0] += s * rx;\n xy[1] += s * ry;\n t = t / 4;\n s *= 2;\n }\n return [z, xy[0], xy[1]];\n}\nvar tzValues = [\n 0,\n 1,\n 5,\n 21,\n 85,\n 341,\n 1365,\n 5461,\n 21845,\n 87381,\n 349525,\n 1398101,\n 5592405,\n 22369621,\n 89478485,\n 357913941,\n 1431655765,\n 5726623061,\n 22906492245,\n 91625968981,\n 366503875925,\n 1466015503701,\n 5864062014805,\n 23456248059221,\n 93824992236885,\n 375299968947541,\n 1501199875790165\n];\nfunction zxyToTileId(z, x, y) {\n if (z > 26) {\n throw Error(\"Tile zoom level exceeds max safe number limit (26)\");\n }\n if (x > __pow(2, z) - 1 || y > __pow(2, z) - 1) {\n throw Error(\"tile x/y outside zoom level bounds\");\n }\n const acc = tzValues[z];\n const n = __pow(2, z);\n let rx = 0;\n let ry = 0;\n let d = 0;\n const xy = [x, y];\n let s = n / 2;\n while (s > 0) {\n rx = (xy[0] & s) > 0 ? 1 : 0;\n ry = (xy[1] & s) > 0 ? 1 : 0;\n d += s * s * (3 * rx ^ ry);\n rotate(s, xy, rx, ry);\n s = s / 2;\n }\n return acc + d;\n}\nfunction tileIdToZxy(i) {\n let acc = 0;\n const z = 0;\n for (let z2 = 0; z2 < 27; z2++) {\n const numTiles = (1 << z2) * (1 << z2);\n if (acc + numTiles > i) {\n return idOnLevel(z2, i - acc);\n }\n acc += numTiles;\n }\n throw Error(\"Tile zoom level exceeds max safe number limit (26)\");\n}\nvar Compression = /* @__PURE__ */ ((Compression2) => {\n Compression2[Compression2[\"Unknown\"] = 0] = \"Unknown\";\n Compression2[Compression2[\"None\"] = 1] = \"None\";\n Compression2[Compression2[\"Gzip\"] = 2] = \"Gzip\";\n Compression2[Compression2[\"Brotli\"] = 3] = \"Brotli\";\n Compression2[Compression2[\"Zstd\"] = 4] = \"Zstd\";\n return Compression2;\n})(Compression || {});\nfunction defaultDecompress(buf, compression) {\n return __async(this, null, function* () {\n if (compression === 1 /* None */ || compression === 0 /* Unknown */) {\n return buf;\n }\n if (compression === 2 /* Gzip */) {\n if (typeof globalThis.DecompressionStream === \"undefined\") {\n return decompressSync(new Uint8Array(buf));\n }\n const stream = new Response(buf).body;\n if (!stream) {\n throw Error(\"Failed to read response stream\");\n }\n const result = stream.pipeThrough(\n // biome-ignore lint: needed to detect DecompressionStream in browser+node+cloudflare workers\n new globalThis.DecompressionStream(\"gzip\")\n );\n return new Response(result).arrayBuffer();\n }\n throw Error(\"Compression method not supported\");\n });\n}\nvar TileType = /* @__PURE__ */ ((TileType2) => {\n TileType2[TileType2[\"Unknown\"] = 0] = \"Unknown\";\n TileType2[TileType2[\"Mvt\"] = 1] = \"Mvt\";\n TileType2[TileType2[\"Png\"] = 2] = \"Png\";\n TileType2[TileType2[\"Jpeg\"] = 3] = \"Jpeg\";\n TileType2[TileType2[\"Webp\"] = 4] = \"Webp\";\n TileType2[TileType2[\"Avif\"] = 5] = \"Avif\";\n return TileType2;\n})(TileType || {});\nfunction tileTypeExt(t) {\n if (t === 1 /* Mvt */)\n return \".mvt\";\n if (t === 2 /* Png */)\n return \".png\";\n if (t === 3 /* Jpeg */)\n return \".jpg\";\n if (t === 4 /* Webp */)\n return \".webp\";\n if (t === 5 /* Avif */)\n return \".avif\";\n return \"\";\n}\nvar HEADER_SIZE_BYTES = 127;\nfunction findTile(entries, tileId) {\n let m = 0;\n let n = entries.length - 1;\n while (m <= n) {\n const k = n + m >> 1;\n const cmp = tileId - entries[k].tileId;\n if (cmp > 0) {\n m = k + 1;\n } else if (cmp < 0) {\n n = k - 1;\n } else {\n return entries[k];\n }\n }\n if (n >= 0) {\n if (entries[n].runLength === 0) {\n return entries[n];\n }\n if (tileId - entries[n].tileId < entries[n].runLength) {\n return entries[n];\n }\n }\n return null;\n}\nvar FileSource = class {\n constructor(file) {\n this.file = file;\n }\n getKey() {\n return this.file.name;\n }\n getBytes(offset, length) {\n return __async(this, null, function* () {\n const blob = this.file.slice(offset, offset + length);\n const a = yield blob.arrayBuffer();\n return { data: a };\n });\n }\n};\nvar FetchSource = class {\n constructor(url, customHeaders = new Headers()) {\n this.url = url;\n this.customHeaders = customHeaders;\n this.mustReload = false;\n let userAgent = \"\";\n if (\"navigator\" in globalThis) {\n userAgent = globalThis.navigator.userAgent || \"\";\n }\n const isWindows = userAgent.indexOf(\"Windows\") > -1;\n const isChromiumBased = /Chrome|Chromium|Edg|OPR|Brave/.test(userAgent);\n this.chromeWindowsNoCache = false;\n if (isWindows && isChromiumBased) {\n this.chromeWindowsNoCache = true;\n }\n }\n getKey() {\n return this.url;\n }\n /**\n * Mutate the custom [Headers](https://developer.mozilla.org/en-US/docs/Web/API/Headers) set for all requests to the remote archive.\n */\n setHeaders(customHeaders) {\n this.customHeaders = customHeaders;\n }\n getBytes(offset, length, passedSignal, etag) {\n return __async(this, null, function* () {\n let controller;\n let signal;\n if (passedSignal) {\n signal = passedSignal;\n } else {\n controller = new AbortController();\n signal = controller.signal;\n }\n const requestHeaders = new Headers(this.customHeaders);\n requestHeaders.set(\"range\", `bytes=${offset}-${offset + length - 1}`);\n let cache;\n if (this.mustReload) {\n cache = \"reload\";\n } else if (this.chromeWindowsNoCache) {\n cache = \"no-store\";\n }\n let resp = yield fetch(this.url, {\n signal,\n cache,\n headers: requestHeaders\n //biome-ignore lint: \"cache\" is incompatible between cloudflare workers and browser\n });\n if (offset === 0 && resp.status === 416) {\n const contentRange = resp.headers.get(\"Content-Range\");\n if (!contentRange || !contentRange.startsWith(\"bytes */\")) {\n throw Error(\"Missing content-length on 416 response\");\n }\n const actualLength = +contentRange.substr(8);\n resp = yield fetch(this.url, {\n signal,\n cache: \"reload\",\n headers: { range: `bytes=0-${actualLength - 1}` }\n //biome-ignore lint: \"cache\" is incompatible between cloudflare workers and browser\n });\n }\n let newEtag = resp.headers.get(\"Etag\");\n if (newEtag == null ? void 0 : newEtag.startsWith(\"W/\")) {\n newEtag = null;\n }\n if (resp.status === 416 || etag && newEtag && newEtag !== etag) {\n this.mustReload = true;\n throw new EtagMismatch(\n `Server returned non-matching ETag ${etag} after one retry. Check browser extensions and servers for issues that may affect correct ETag headers.`\n );\n }\n if (resp.status >= 300) {\n throw Error(`Bad response code: ${resp.status}`);\n }\n const contentLength = resp.headers.get(\"Content-Length\");\n if (resp.status === 200 && (!contentLength || +contentLength > length)) {\n if (controller)\n controller.abort();\n throw Error(\n \"Server returned no content-length header or content-length exceeding request. Check that your storage backend supports HTTP Byte Serving.\"\n );\n }\n const a = yield resp.arrayBuffer();\n return {\n data: a,\n etag: newEtag || void 0,\n cacheControl: resp.headers.get(\"Cache-Control\") || void 0,\n expires: resp.headers.get(\"Expires\") || void 0\n };\n });\n }\n};\nfunction getUint64(v, offset) {\n const wh = v.getUint32(offset + 4, true);\n const wl = v.getUint32(offset + 0, true);\n return wh * __pow(2, 32) + wl;\n}\nfunction bytesToHeader(bytes, etag) {\n const v = new DataView(bytes);\n const specVersion = v.getUint8(7);\n if (specVersion > 3) {\n throw Error(\n `Archive is spec version ${specVersion} but this library supports up to spec version 3`\n );\n }\n return {\n specVersion,\n rootDirectoryOffset: getUint64(v, 8),\n rootDirectoryLength: getUint64(v, 16),\n jsonMetadataOffset: getUint64(v, 24),\n jsonMetadataLength: getUint64(v, 32),\n leafDirectoryOffset: getUint64(v, 40),\n leafDirectoryLength: getUint64(v, 48),\n tileDataOffset: getUint64(v, 56),\n tileDataLength: getUint64(v, 64),\n numAddressedTiles: getUint64(v, 72),\n numTileEntries: getUint64(v, 80),\n numTileContents: getUint64(v, 88),\n clustered: v.getUint8(96) === 1,\n internalCompression: v.getUint8(97),\n tileCompression: v.getUint8(98),\n tileType: v.getUint8(99),\n minZoom: v.getUint8(100),\n maxZoom: v.getUint8(101),\n minLon: v.getInt32(102, true) / 1e7,\n minLat: v.getInt32(106, true) / 1e7,\n maxLon: v.getInt32(110, true) / 1e7,\n maxLat: v.getInt32(114, true) / 1e7,\n centerZoom: v.getUint8(118),\n centerLon: v.getInt32(119, true) / 1e7,\n centerLat: v.getInt32(123, true) / 1e7,\n etag\n };\n}\nfunction deserializeIndex(buffer) {\n const p = { buf: new Uint8Array(buffer), pos: 0 };\n const numEntries = readVarint(p);\n const entries = [];\n let lastId = 0;\n for (let i = 0; i < numEntries; i++) {\n const v = readVarint(p);\n entries.push({ tileId: lastId + v, offset: 0, length: 0, runLength: 1 });\n lastId += v;\n }\n for (let i = 0; i < numEntries; i++) {\n entries[i].runLength = readVarint(p);\n }\n for (let i = 0; i < numEntries; i++) {\n entries[i].length = readVarint(p);\n }\n for (let i = 0; i < numEntries; i++) {\n const v = readVarint(p);\n if (v === 0 && i > 0) {\n entries[i].offset = entries[i - 1].offset + entries[i - 1].length;\n } else {\n entries[i].offset = v - 1;\n }\n }\n return entries;\n}\nfunction detectVersion(a) {\n const v = new DataView(a);\n if (v.getUint16(2, true) === 2) {\n console.warn(\n \"PMTiles spec version 2 has been deprecated; please see github.com/protomaps/PMTiles for tools to upgrade\"\n );\n return 2;\n }\n if (v.getUint16(2, true) === 1) {\n console.warn(\n \"PMTiles spec version 1 has been deprecated; please see github.com/protomaps/PMTiles for tools to upgrade\"\n );\n return 1;\n }\n return 3;\n}\nvar EtagMismatch = class extends Error {\n};\nfunction getHeaderAndRoot(source, decompress) {\n return __async(this, null, function* () {\n const resp = yield source.getBytes(0, 16384);\n const v = new DataView(resp.data);\n if (v.getUint16(0, true) !== 19792) {\n throw new Error(\"Wrong magic number for PMTiles archive\");\n }\n if (detectVersion(resp.data) < 3) {\n return [yield v2_default.getHeader(source)];\n }\n const headerData = resp.data.slice(0, HEADER_SIZE_BYTES);\n const header = bytesToHeader(headerData, resp.etag);\n const rootDirData = resp.data.slice(\n header.rootDirectoryOffset,\n header.rootDirectoryOffset + header.rootDirectoryLength\n );\n const dirKey = `${source.getKey()}|${header.etag || \"\"}|${header.rootDirectoryOffset}|${header.rootDirectoryLength}`;\n const rootDir = deserializeIndex(\n yield decompress(rootDirData, header.internalCompression)\n );\n return [header, [dirKey, rootDir.length, rootDir]];\n });\n}\nfunction getDirectory(source, decompress, offset, length, header) {\n return __async(this, null, function* () {\n const resp = yield source.getBytes(offset, length, void 0, header.etag);\n const data = yield decompress(resp.data, header.internalCompression);\n const directory = deserializeIndex(data);\n if (directory.length === 0) {\n throw new Error(\"Empty directory is invalid\");\n }\n return directory;\n });\n}\nvar ResolvedValueCache = class {\n constructor(maxCacheEntries = 100, prefetch = true, decompress = defaultDecompress) {\n this.cache = /* @__PURE__ */ new Map();\n this.maxCacheEntries = maxCacheEntries;\n this.counter = 1;\n this.decompress = decompress;\n }\n getHeader(source) {\n return __async(this, null, function* () {\n const cacheKey = source.getKey();\n const cacheValue = this.cache.get(cacheKey);\n if (cacheValue) {\n cacheValue.lastUsed = this.counter++;\n const data = cacheValue.data;\n return data;\n }\n const res = yield getHeaderAndRoot(source, this.decompress);\n if (res[1]) {\n this.cache.set(res[1][0], {\n lastUsed: this.counter++,\n data: res[1][2]\n });\n }\n this.cache.set(cacheKey, {\n lastUsed: this.counter++,\n data: res[0]\n });\n this.prune();\n return res[0];\n });\n }\n getDirectory(source, offset, length, header) {\n return __async(this, null, function* () {\n const cacheKey = `${source.getKey()}|${header.etag || \"\"}|${offset}|${length}`;\n const cacheValue = this.cache.get(cacheKey);\n if (cacheValue) {\n cacheValue.lastUsed = this.counter++;\n const data = cacheValue.data;\n return data;\n }\n const directory = yield getDirectory(\n source,\n this.decompress,\n offset,\n length,\n header\n );\n this.cache.set(cacheKey, {\n lastUsed: this.counter++,\n data: directory\n });\n this.prune();\n return directory;\n });\n }\n // for v2 backwards compatibility\n getArrayBuffer(source, offset, length, header) {\n return __async(this, null, function* () {\n const cacheKey = `${source.getKey()}|${header.etag || \"\"}|${offset}|${length}`;\n const cacheValue = this.cache.get(cacheKey);\n if (cacheValue) {\n cacheValue.lastUsed = this.counter++;\n const data = yield cacheValue.data;\n return data;\n }\n const resp = yield source.getBytes(offset, length, void 0, header.etag);\n this.cache.set(cacheKey, {\n lastUsed: this.counter++,\n data: resp.data\n });\n this.prune();\n return resp.data;\n });\n }\n prune() {\n if (this.cache.size > this.maxCacheEntries) {\n let minUsed = Infinity;\n let minKey = void 0;\n this.cache.forEach((cacheValue, key) => {\n if (cacheValue.lastUsed < minUsed) {\n minUsed = cacheValue.lastUsed;\n minKey = key;\n }\n });\n if (minKey) {\n this.cache.delete(minKey);\n }\n }\n }\n invalidate(source) {\n return __async(this, null, function* () {\n this.cache.delete(source.getKey());\n });\n }\n};\nvar SharedPromiseCache = class {\n constructor(maxCacheEntries = 100, prefetch = true, decompress = defaultDecompress) {\n this.cache = /* @__PURE__ */ new Map();\n this.invalidations = /* @__PURE__ */ new Map();\n this.maxCacheEntries = maxCacheEntries;\n this.counter = 1;\n this.decompress = decompress;\n }\n getHeader(source) {\n return __async(this, null, function* () {\n const cacheKey = source.getKey();\n const cacheValue = this.cache.get(cacheKey);\n if (cacheValue) {\n cacheValue.lastUsed = this.counter++;\n const data = yield cacheValue.data;\n return data;\n }\n const p = new Promise((resolve, reject) => {\n getHeaderAndRoot(source, this.decompress).then((res) => {\n if (res[1]) {\n this.cache.set(res[1][0], {\n lastUsed: this.counter++,\n data: Promise.resolve(res[1][2])\n });\n }\n resolve(res[0]);\n this.prune();\n }).catch((e) => {\n reject(e);\n });\n });\n this.cache.set(cacheKey, { lastUsed: this.counter++, data: p });\n return p;\n });\n }\n getDirectory(source, offset, length, header) {\n return __async(this, null, function* () {\n const cacheKey = `${source.getKey()}|${header.etag || \"\"}|${offset}|${length}`;\n const cacheValue = this.cache.get(cacheKey);\n if (cacheValue) {\n cacheValue.lastUsed = this.counter++;\n const data = yield cacheValue.data;\n return data;\n }\n const p = new Promise((resolve, reject) => {\n getDirectory(source, this.decompress, offset, length, header).then((directory) => {\n resolve(directory);\n this.prune();\n }).catch((e) => {\n reject(e);\n });\n });\n this.cache.set(cacheKey, { lastUsed: this.counter++, data: p });\n return p;\n });\n }\n // for v2 backwards compatibility\n getArrayBuffer(source, offset, length, header) {\n return __async(this, null, function* () {\n const cacheKey = `${source.getKey()}|${header.etag || \"\"}|${offset}|${length}`;\n const cacheValue = this.cache.get(cacheKey);\n if (cacheValue) {\n cacheValue.lastUsed = this.counter++;\n const data = yield cacheValue.data;\n return data;\n }\n const p = new Promise((resolve, reject) => {\n source.getBytes(offset, length, void 0, header.etag).then((resp) => {\n resolve(resp.data);\n if (this.cache.has(cacheKey)) {\n }\n this.prune();\n }).catch((e) => {\n reject(e);\n });\n });\n this.cache.set(cacheKey, { lastUsed: this.counter++, data: p });\n return p;\n });\n }\n prune() {\n if (this.cache.size >= this.maxCacheEntries) {\n let minUsed = Infinity;\n let minKey = void 0;\n this.cache.forEach((cacheValue, key) => {\n if (cacheValue.lastUsed < minUsed) {\n minUsed = cacheValue.lastUsed;\n minKey = key;\n }\n });\n if (minKey) {\n this.cache.delete(minKey);\n }\n }\n }\n invalidate(source) {\n return __async(this, null, function* () {\n const key = source.getKey();\n if (this.invalidations.get(key)) {\n return yield this.invalidations.get(key);\n }\n this.cache.delete(source.getKey());\n const p = new Promise((resolve, reject) => {\n this.getHeader(source).then((h) => {\n resolve();\n this.invalidations.delete(key);\n }).catch((e) => {\n reject(e);\n });\n });\n this.invalidations.set(key, p);\n });\n }\n};\nvar PMTiles = class {\n constructor(source, cache, decompress) {\n if (typeof source === \"string\") {\n this.source = new FetchSource(source);\n } else {\n this.source = source;\n }\n if (decompress) {\n this.decompress = decompress;\n } else {\n this.decompress = defaultDecompress;\n }\n if (cache) {\n this.cache = cache;\n } else {\n this.cache = new SharedPromiseCache();\n }\n }\n /**\n * Return the header of the archive,\n * including information such as tile type, min/max zoom, bounds, and summary statistics.\n */\n getHeader() {\n return __async(this, null, function* () {\n return yield this.cache.getHeader(this.source);\n });\n }\n /** @hidden */\n getZxyAttempt(z, x, y, signal) {\n return __async(this, null, function* () {\n const tileId = zxyToTileId(z, x, y);\n const header = yield this.cache.getHeader(this.source);\n if (header.specVersion < 3) {\n return v2_default.getZxy(header, this.source, this.cache, z, x, y, signal);\n }\n if (z < header.minZoom || z > header.maxZoom) {\n return void 0;\n }\n let dO = header.rootDirectoryOffset;\n let dL = header.rootDirectoryLength;\n for (let depth = 0; depth <= 3; depth++) {\n const directory = yield this.cache.getDirectory(\n this.source,\n dO,\n dL,\n header\n );\n const entry = findTile(directory, tileId);\n if (entry) {\n if (entry.runLength > 0) {\n const resp = yield this.source.getBytes(\n header.tileDataOffset + entry.offset,\n entry.length,\n signal,\n header.etag\n );\n return {\n data: yield this.decompress(resp.data, header.tileCompression),\n cacheControl: resp.cacheControl,\n expires: resp.expires\n };\n }\n dO = header.leafDirectoryOffset + entry.offset;\n dL = entry.length;\n } else {\n return void 0;\n }\n }\n throw Error(\"Maximum directory depth exceeded\");\n });\n }\n /**\n * Primary method to get a single tile's bytes from an archive.\n *\n * Returns undefined if the tile does not exist in the archive.\n */\n getZxy(z, x, y, signal) {\n return __async(this, null, function* () {\n try {\n return yield this.getZxyAttempt(z, x, y, signal);\n } catch (e) {\n if (e instanceof EtagMismatch) {\n this.cache.invalidate(this.source);\n return yield this.getZxyAttempt(z, x, y, signal);\n }\n throw e;\n }\n });\n }\n /** @hidden */\n getMetadataAttempt() {\n return __async(this, null, function* () {\n const header = yield this.cache.getHeader(this.source);\n const resp = yield this.source.getBytes(\n header.jsonMetadataOffset,\n header.jsonMetadataLength,\n void 0,\n header.etag\n );\n const decompressed = yield this.decompress(\n resp.data,\n header.internalCompression\n );\n const dec = new TextDecoder(\"utf-8\");\n return JSON.parse(dec.decode(decompressed));\n });\n }\n /**\n * Return the arbitrary JSON metadata of the archive.\n */\n getMetadata() {\n return __async(this, null, function* () {\n try {\n return yield this.getMetadataAttempt();\n } catch (e) {\n if (e instanceof EtagMismatch) {\n this.cache.invalidate(this.source);\n return yield this.getMetadataAttempt();\n }\n throw e;\n }\n });\n }\n /**\n * Construct a [TileJSON](https://github.com/mapbox/tilejson-spec) object.\n *\n * baseTilesUrl is the desired tiles URL, excluding the suffix `/{z}/{x}/{y}.{ext}`.\n * For example, if the desired URL is `http://example.com/tileset/{z}/{x}/{y}.mvt`,\n * the baseTilesUrl should be `https://example.com/tileset`.\n */\n getTileJson(baseTilesUrl) {\n return __async(this, null, function* () {\n const header = yield this.getHeader();\n const metadata = yield this.getMetadata();\n const ext = tileTypeExt(header.tileType);\n return {\n tilejson: \"3.0.0\",\n scheme: \"xyz\",\n tiles: [`${baseTilesUrl}/{z}/{x}/{y}${ext}`],\n // biome-ignore lint: TileJSON spec\n vector_layers: metadata.vector_layers,\n attribution: metadata.attribution,\n description: metadata.description,\n name: metadata.name,\n version: metadata.version,\n bounds: [header.minLon, header.minLat, header.maxLon, header.maxLat],\n center: [header.centerLon, header.centerLat, header.centerZoom],\n minzoom: header.minZoom,\n maxzoom: header.maxZoom\n };\n });\n }\n};\nexport {\n Compression,\n EtagMismatch,\n FetchSource,\n FileSource,\n PMTiles,\n Protocol,\n ResolvedValueCache,\n SharedPromiseCache,\n TileType,\n bytesToHeader,\n findTile,\n getUint64,\n leafletRasterLayer,\n readVarint,\n tileIdToZxy,\n tileTypeExt,\n zxyToTileId\n};\n","import { PMTiles } from 'pmtiles';\n\nconst contentType = [\n 'application/octet-stream',\n 'application/x-protobuf',\n 'image/png',\n 'image/jpeg',\n 'image/webp',\n 'image/avif',\n];\n\nconst tileUrlRegex = /\\/([0-9]+)\\/([0-9]+)\\/([0-9]+).(mvt|png|jpg|webp|avif)$/;\nconst protocolRegex = /^pmtiles:\\/\\//;\nconst fixUrlRegex = /^http(s?)\\/\\//; // workaround for broken URLs in Safari\n/** @type {Object} */\nconst pmtilesByUrl = {};\n\nconst { fetch: originalFetch, XMLHttpRequest: OriginalXHR } = window;\n\nexport const fetch = new Proxy(originalFetch, {\n apply: async (target, that, [input, init]) => {\n /** @type {string} */\n let url;\n if (input instanceof Request) {\n if (input.method !== 'GET') {\n return target.call(that, input, init);\n }\n url = input.url;\n } else {\n url = input.toString();\n }\n if (!protocolRegex.test(url)) {\n return target.call(that, input, init);\n }\n url = url.replace(protocolRegex, '').replace(fixUrlRegex, 'http$1://');\n let baseUrl = url;\n /** @type {[number, number, number]|null} */\n let zxy = null;\n if (tileUrlRegex.test(url)) {\n baseUrl = url.replace(tileUrlRegex, '');\n zxy = /** @type {[number, number, number]} */ (\n url.match(tileUrlRegex)?.slice(1).map(Number)\n );\n }\n if (!(baseUrl in pmtilesByUrl)) {\n pmtilesByUrl[baseUrl] = new PMTiles(baseUrl);\n }\n if (zxy) {\n const tileResult = await pmtilesByUrl[baseUrl].getZxy(...zxy);\n if (!tileResult) {\n return new Response(null, { status: 404 });\n }\n const header = await pmtilesByUrl[baseUrl].getHeader();\n return new Response(tileResult.data, {\n headers: { 'Content-Type': contentType[header.tileType] },\n });\n } else {\n const data = await pmtilesByUrl[baseUrl].getTileJson(\n 'pmtiles://' + baseUrl,\n );\n return new Response(JSON.stringify(data), {\n headers: { 'Content-Type': 'application/json' },\n });\n }\n },\n});\n\nexport class XMLHttpRequest extends OriginalXHR {\n constructor() {\n super();\n /** @type {string} */\n let baseUrl;\n /** @type {undefined|((event: ProgressEvent) => void)} */\n let onload;\n /** @type {undefined|((event: ProgressEvent) => void)} */\n let onerror;\n /** @type {ArrayBuffer|null} */\n let response;\n /** @type {string|null} */\n let responseText,\n /** @type {200 | 404} */\n status;\n /** @type {Array|null} */\n let zxy = null;\n return new Proxy(this, {\n get: (target, prop) => {\n if (prop === 'open') {\n /**\n * @param {string} method\n * @param {string} url\n * @param {boolean} async\n * @param {string} user\n * @param {string} password\n */\n return (method, url, async = true, user, password) => {\n if (method !== 'GET' || !protocolRegex.test(url)) {\n return this.open(method, url, async, user, password);\n }\n url = url\n .replace(protocolRegex, '')\n .replace(fixUrlRegex, 'http$1://');\n baseUrl = url;\n /** @type {[number, number, number]} */\n if (tileUrlRegex.test(url)) {\n baseUrl = url.replace(tileUrlRegex, '');\n zxy = url.match(tileUrlRegex)?.slice(1).map(Number) || null;\n }\n if (!(baseUrl in pmtilesByUrl)) {\n pmtilesByUrl[baseUrl] = new PMTiles(baseUrl);\n }\n };\n } else if (prop === 'send') {\n /**\n * @param {XMLHttpRequestBodyInit|Document|null} [body]\n */\n return async (body) => {\n if (!baseUrl) {\n return this.send(body);\n }\n try {\n const loadEvent = new ProgressEvent('load');\n if (zxy) {\n const tileResult = await pmtilesByUrl[baseUrl].getZxy(\n zxy[0],\n zxy[1],\n zxy[2],\n );\n if (tileResult) {\n status = 200;\n response = tileResult.data;\n } else {\n status = 404;\n response = null;\n }\n this.dispatchEvent(loadEvent);\n if (onload) {\n onload(loadEvent);\n }\n } else {\n const tileResult = await pmtilesByUrl[baseUrl].getTileJson(\n 'pmtiles://' + baseUrl,\n );\n status = 200;\n responseText = JSON.stringify(tileResult);\n this.dispatchEvent(loadEvent);\n if (onload) {\n onload(loadEvent);\n }\n }\n } catch (e) {\n console.error(e);\n const errorEvent = new ProgressEvent('error');\n this.dispatchEvent(errorEvent);\n if (onerror) {\n onerror(errorEvent);\n }\n }\n };\n } else if (prop === 'response' && response) {\n return response;\n } else if (prop === 'responseText' && responseText) {\n return responseText;\n } else if (prop === 'status' && status) {\n return status;\n }\n // @ts-expect-error\n return target[prop];\n },\n set: (target, prop, value) => {\n if (prop === 'onload') {\n onload = value;\n } else if (prop === 'onerror') {\n onerror = value;\n }\n // @ts-expect-error\n target[prop] = value;\n return true;\n },\n });\n }\n}\n\n/**\n * Registers fetch and XMLHttpRequest global overrides.\n * @returns {() => void} Unregister function\n */\nexport const register = () => {\n window.fetch = fetch;\n window.XMLHttpRequest = XMLHttpRequest;\n return () => {\n window.fetch = originalFetch;\n window.XMLHttpRequest = OriginalXHR;\n };\n};\n","import 'ol/ol.css';\nimport {apply} from 'ol-mapbox-style';\nimport {register as registerPMTiles} from 'pmtiles-protocol';\n\nregisterPMTiles();\n\napply('map', 'data/protomaps-dark-style.json');\n"],"names":["__pow","Math","pow","__async","__this","__arguments","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","throw","x","done","then","apply","u8","Uint8Array","u16","Uint16Array","i32","Int32Array","fleb","fdeb","clim","freb","eb","start","b","i","r","j","_a","fl","revfl","_b","fd","rev","hMap","cd","mb","s","length","l","co","le","rvb","sv","r_1","v","m","flt","fdt","flrm","fdrm","max","a","bits","d","p","o","bits16","ec","err","ind","msg","nt","Error","code","captureStackTrace","inflt","dat","st","buf","dict","sl","dl","f","noBuf","noSt","cbuf","l2","bl","nbuf","set","final","pos","bt","lm","dm","lbt","dbt","n","tbts","type","t","subarray","hLit","hcLen","tl","ldt","clt","clb","clbmsk","clm","c","lt","dt","lms","dms","lpos","sym","add","dsym","end","shift2","dend","min","slc","et","gzs","flg","zs","gzl","zls","decompressSync","data","opts","out","dictionary","gunzipSync","inflateSync","unzlibSync","td","TextDecoder","decode","stream","shift","unshift","floor","getUint24","view","getUint16","getUint8","getUint48","getUint32","compare","tz","tx","ty","y","queryTile","z","offsetLen","queryView","offset","isDir","byteLength","k","cmp","entrySort","parseEntry","dataview","zRaw","sortDir","entries","DataView","push","createDirectory","sort","buffer","ArrayBuffer","arr","entry","v2_default","getHeader","source","this","resp","getBytes","jsonSize","rootEntries","dec","jsonMetadata","JSON","parse","tileCompression","compression","minzoom","maxzoom","centerLon","centerLat","centerZoom","minLon","minLat","maxLon","maxLat","bounds","split","center","specVersion","rootDirectoryOffset","rootDirectoryLength","jsonMetadataOffset","jsonMetadataLength","leafDirectoryOffset","leafDirectoryLength","tileDataOffset","tileDataLength","numAddressedTiles","numTileEntries","numTileContents","clustered","internalCompression","tileType","minZoom","maxZoom","etag","getZxy","header","cache","signal","rootDir","getArrayBuffer","tileData","leafcoords","tile","numEntries","leafLevel","levelDiff","trunc","deriveLeaf","leafdirEntry","queryLeafdir","leafDir","tileEntry","toNum","low","high","readVarint","val","h","readVarintRemainder","rotate","xy","rx","ry","tzValues","defaultDecompress","globalThis","DecompressionStream","Response","body","result","pipeThrough","arrayBuffer","findTile","tileId","runLength","FetchSource","constructor","url","customHeaders","Headers","mustReload","userAgent","navigator","isWindows","indexOf","isChromiumBased","test","chromeWindowsNoCache","getKey","setHeaders","passedSignal","controller","AbortController","requestHeaders","fetch","headers","status","contentRange","get","startsWith","actualLength","substr","range","newEtag","EtagMismatch","contentLength","abort","cacheControl","expires","getUint64","wh","wl","deserializeIndex","lastId","SharedPromiseCache","maxCacheEntries","prefetch","decompress","Map","invalidations","counter","cacheKey","cacheValue","lastUsed","console","warn","detectVersion","bytes","getInt32","bytesToHeader","slice","rootDirData","dirKey","getHeaderAndRoot","res","prune","catch","getDirectory","directory","has","size","minKey","minUsed","Infinity","forEach","key","delete","invalidate","PMTiles","getZxyAttempt","acc","zxyToTileId","dO","dL","depth","getMetadataAttempt","decompressed","getMetadata","getTileJson","baseTilesUrl","metadata","ext","tilejson","scheme","tiles","vector_layers","attribution","description","name","version","contentType","tileUrlRegex","protocolRegex","fixUrlRegex","pmtilesByUrl","originalFetch","XMLHttpRequest","OriginalXHR","window","Proxy","async","target","that","input","init","Request","method","call","toString","replace","baseUrl","zxy","match","map","Number","tileResult","stringify","onload","onerror","response","responseText","super","prop","user","password","open","send","loadEvent","ProgressEvent","dispatchEvent","error","errorEvent"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/sdf-sprites.css b/dist/examples/sdf-sprites.css new file mode 100644 index 00000000..3f94407a --- /dev/null +++ b/dist/examples/sdf-sprites.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=sdf-sprites.css.map*/ \ No newline at end of file diff --git a/dist/examples/sdf-sprites.css.map b/dist/examples/sdf-sprites.css.map new file mode 100644 index 00000000..96fea86a --- /dev/null +++ b/dist/examples/sdf-sprites.css.map @@ -0,0 +1 @@ +{"version":3,"file":"sdf-sprites.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/sdf-sprites.html b/dist/examples/sdf-sprites.html new file mode 100644 index 00000000..b8e0c68e --- /dev/null +++ b/dist/examples/sdf-sprites.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/sdf-sprites.js b/dist/examples/sdf-sprites.js new file mode 100644 index 00000000..55c7eaf9 --- /dev/null +++ b/dist/examples/sdf-sprites.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[281],{4054:(e,s,t)=>{t(8508);var o=t(316);let p=document.cookie.replace(/(?:(?:^|.*;\s*)maptiler_access_token\s*\=\s*([^;]*).*$)|^.*$/,"$1");p||(p=window.prompt("Enter your MapTiler API access token:"),document.cookie="maptiler_access_token="+p+"; expires=Fri, 31 Dec 9999 23:59:59 GMT"),(0,o.Ay)("map","https://api.maptiler.com/maps/test-bright/style.json?key="+p)}},e=>{e(e.s=4054)}]); +//# sourceMappingURL=sdf-sprites.js.map \ No newline at end of file diff --git a/dist/examples/sdf-sprites.js.map b/dist/examples/sdf-sprites.js.map new file mode 100644 index 00000000..21c7df56 --- /dev/null +++ b/dist/examples/sdf-sprites.js.map @@ -0,0 +1 @@ +{"version":3,"file":"sdf-sprites.js","mappings":"sIAKA,IAAIA,EAAMC,SAASC,OAAOC,QACxB,+DACA,MAEGH,IACHA,EAAMI,OAAOC,OAAO,yCACpBJ,SAASC,OACP,yBAA2BF,EAAM,4CAGrC,QAAK,MAAOM,4DAAoBN,E","sources":["webpack://ol-mapbox-style/./examples/sdf-sprites.js"],"sourcesContent":["import 'ol/ol.css';\nimport olms from 'ol-mapbox-style';\n\nconst baseUrl = 'https://api.maptiler.com/maps/test-bright/style.json';\n\nlet key = document.cookie.replace(\n /(?:(?:^|.*;\\s*)maptiler_access_token\\s*\\=\\s*([^;]*).*$)|^.*$/,\n '$1',\n);\nif (!key) {\n key = window.prompt('Enter your MapTiler API access token:');\n document.cookie =\n 'maptiler_access_token=' + key + '; expires=Fri, 31 Dec 9999 23:59:59 GMT';\n}\n\nolms('map', baseUrl + '?key=' + key);\n"],"names":["key","document","cookie","replace","window","prompt","baseUrl"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/stylefunction.css b/dist/examples/stylefunction.css new file mode 100644 index 00000000..97b2c1a0 --- /dev/null +++ b/dist/examples/stylefunction.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=stylefunction.css.map*/ \ No newline at end of file diff --git a/dist/examples/stylefunction.css.map b/dist/examples/stylefunction.css.map new file mode 100644 index 00000000..2dfe30c8 --- /dev/null +++ b/dist/examples/stylefunction.css.map @@ -0,0 +1 @@ +{"version":3,"file":"stylefunction.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/stylefunction.html b/dist/examples/stylefunction.html new file mode 100644 index 00000000..29212f10 --- /dev/null +++ b/dist/examples/stylefunction.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/stylefunction.js b/dist/examples/stylefunction.js new file mode 100644 index 00000000..24875ea1 --- /dev/null +++ b/dist/examples/stylefunction.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[70],{6055:(e,t,s)=>{s(8508);var a=s(1365),n=s(3317),o=s(2757),r=s(8738),c=s(1765),l=s(316);const w=new o.A({declutter:!0,source:new r.A({format:new a.A,url:"data/states.geojson"})}),u=new n.A({target:"map",view:new c.Ay({center:[-13603186.115192635,6785744.563386],zoom:2})});fetch("data/states.json").then((e=>e.json())).then((e=>{(0,l.mt)(w,e,"states"),-1===u.getLayers().getArray().indexOf(w)&&u.addLayer(w)}))}},e=>{e(e.s=6055)}]); +//# sourceMappingURL=stylefunction.js.map \ No newline at end of file diff --git a/dist/examples/stylefunction.js.map b/dist/examples/stylefunction.js.map new file mode 100644 index 00000000..77bad735 --- /dev/null +++ b/dist/examples/stylefunction.js.map @@ -0,0 +1 @@ +{"version":3,"file":"stylefunction.js","mappings":"uLASA,MAAMA,EAAQ,IAAI,IAAY,CAC5BC,WAAW,EACXC,OAAQ,IAAI,IAAa,CACvBC,OAAQ,IAAI,IACZC,IAAK,0BAIHC,EAAM,IAAI,IAAI,CAClBC,OAAQ,MACRC,KAAM,IAAI,KAAK,CACbC,OAAQ,EAAE,mBAAoB,gBAC9BC,KAAM,MAIVC,MAAM,oBACHC,MAAMC,GAAMA,EAAEC,SACdF,MAAMG,KACL,QAAcd,EAAOc,EAAS,WACqB,IAA/CT,EAAIU,YAAYC,WAAWC,QAAQjB,IACrCK,EAAIa,SAASlB,EACf,G","sources":["webpack://ol-mapbox-style/./examples/stylefunction.js"],"sourcesContent":["import 'ol/ol.css';\nimport GeoJsonFormat from 'ol/format/GeoJSON.js';\nimport Map from 'ol/Map.js';\nimport VectorLayer from 'ol/layer/Vector.js';\nimport VectorSource from 'ol/source/Vector.js';\nimport View from 'ol/View.js';\n\nimport {stylefunction} from 'ol-mapbox-style';\n\nconst layer = new VectorLayer({\n declutter: true,\n source: new VectorSource({\n format: new GeoJsonFormat(),\n url: 'data/states.geojson',\n }),\n});\n\nconst map = new Map({\n target: 'map',\n view: new View({\n center: [-13603186.115192635, 6785744.563386],\n zoom: 2,\n }),\n});\n\nfetch('data/states.json')\n .then((r) => r.json())\n .then((glStyle) => {\n stylefunction(layer, glStyle, 'states');\n if (map.getLayers().getArray().indexOf(layer) === -1) {\n map.addLayer(layer);\n }\n });\n"],"names":["layer","declutter","source","format","url","map","target","view","center","zoom","fetch","then","r","json","glStyle","getLayers","getArray","indexOf","addLayer"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/terrarium-hillshading.css b/dist/examples/terrarium-hillshading.css new file mode 100644 index 00000000..b30d98ae --- /dev/null +++ b/dist/examples/terrarium-hillshading.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=terrarium-hillshading.css.map*/ \ No newline at end of file diff --git a/dist/examples/terrarium-hillshading.css.map b/dist/examples/terrarium-hillshading.css.map new file mode 100644 index 00000000..58caddb0 --- /dev/null +++ b/dist/examples/terrarium-hillshading.css.map @@ -0,0 +1 @@ +{"version":3,"file":"terrarium-hillshading.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/terrarium-hillshading.html b/dist/examples/terrarium-hillshading.html new file mode 100644 index 00000000..4aea6f89 --- /dev/null +++ b/dist/examples/terrarium-hillshading.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/terrarium-hillshading.js b/dist/examples/terrarium-hillshading.js new file mode 100644 index 00000000..fbedd96d --- /dev/null +++ b/dist/examples/terrarium-hillshading.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[52],{5989:(e,t,r)=>{r(8508),(0,r(316).Ay)("map",{version:8,name:"Terrarium",center:[13.783578,47.609499],zoom:11,sources:{osm:{type:"raster",attribution:'© OpenStreetMap contributors.',tileSize:256,tiles:["https://tile.openstreetmap.org/{z}/{x}/{y}.png"],maxzoom:19},terrarium:{type:"raster-dem",attribution:'Data sources and attribution',tileSize:256,tiles:["https://s3.amazonaws.com/elevation-tiles-prod/terrarium/{z}/{x}/{y}.png"],maxzoom:15,encoding:"terrarium"}},layers:[{id:"osm",type:"raster",source:"osm"},{id:"hillshade",type:"hillshade",source:"terrarium",paint:{"hillshade-accent-color":"#D8E8CF","hillshade-exaggeration":{stops:[[6,.4],[14,.35],[18,.25]]},"hillshade-shadow-color":"#6C6665","hillshade-highlight-color":"#B8AAA3"}}]})}},e=>{e(e.s=5989)}]); +//# sourceMappingURL=terrarium-hillshading.js.map \ No newline at end of file diff --git a/dist/examples/terrarium-hillshading.js.map b/dist/examples/terrarium-hillshading.js.map new file mode 100644 index 00000000..01092ade --- /dev/null +++ b/dist/examples/terrarium-hillshading.js.map @@ -0,0 +1 @@ +{"version":3,"file":"terrarium-hillshading.js","mappings":"yHAuDA,E,OAAA,IAAK,MApDS,CACZA,QAAS,EACTC,KAAM,YACNC,OAAQ,CAAC,UAAW,WACpBC,KAAM,GACNC,QAAS,CACPC,IAAK,CACHC,KAAM,SACNC,YACE,2FACFC,SAAU,IACVC,MAAO,CAAC,kDACRC,QAAS,IAEXC,UAAW,CACTL,KAAM,aACNC,YACE,8HACFC,SAAU,IACVC,MAAO,CACL,2EAEFC,QAAS,GACTE,SAAU,cAGdC,OAAQ,CACN,CACEC,GAAI,MACJR,KAAM,SACNS,OAAQ,OAEV,CACED,GAAI,YACJR,KAAM,YACNS,OAAQ,YACRC,MAAO,CACL,yBAA0B,UAC1B,yBAA0B,CACxBC,MAAO,CACL,CAAC,EAAG,IACJ,CAAC,GAAI,KACL,CAAC,GAAI,OAGT,yBAA0B,UAC1B,4BAA6B,c","sources":["webpack://ol-mapbox-style/./examples/terrarium-hillshading.js"],"sourcesContent":["import 'ol/ol.css';\nimport olms from 'ol-mapbox-style';\n\nconst style = {\n version: 8,\n name: 'Terrarium',\n center: [13.783578, 47.609499],\n zoom: 11,\n sources: {\n osm: {\n type: 'raster',\n attribution:\n '© OpenStreetMap contributors.',\n tileSize: 256,\n tiles: ['https://tile.openstreetmap.org/{z}/{x}/{y}.png'],\n maxzoom: 19,\n },\n terrarium: {\n type: 'raster-dem',\n attribution:\n 'Data sources and attribution',\n tileSize: 256,\n tiles: [\n 'https://s3.amazonaws.com/elevation-tiles-prod/terrarium/{z}/{x}/{y}.png',\n ],\n maxzoom: 15,\n encoding: 'terrarium',\n },\n },\n layers: [\n {\n id: 'osm',\n type: 'raster',\n source: 'osm',\n },\n {\n id: 'hillshade',\n type: 'hillshade',\n source: 'terrarium',\n paint: {\n 'hillshade-accent-color': '#D8E8CF',\n 'hillshade-exaggeration': {\n stops: [\n [6, 0.4],\n [14, 0.35],\n [18, 0.25],\n ],\n },\n 'hillshade-shadow-color': '#6C6665',\n 'hillshade-highlight-color': '#B8AAA3',\n },\n },\n ],\n};\n\nolms('map', style);\n"],"names":["version","name","center","zoom","sources","osm","type","attribution","tileSize","tiles","maxzoom","terrarium","encoding","layers","id","source","paint","stops"],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/tilejson-vectortile.css b/dist/examples/tilejson-vectortile.css new file mode 100644 index 00000000..d7704658 --- /dev/null +++ b/dist/examples/tilejson-vectortile.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=tilejson-vectortile.css.map*/ \ No newline at end of file diff --git a/dist/examples/tilejson-vectortile.css.map b/dist/examples/tilejson-vectortile.css.map new file mode 100644 index 00000000..d24d0640 --- /dev/null +++ b/dist/examples/tilejson-vectortile.css.map @@ -0,0 +1 @@ +{"version":3,"file":"tilejson-vectortile.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/tilejson-vectortile.html b/dist/examples/tilejson-vectortile.html new file mode 100644 index 00000000..9c4559c1 --- /dev/null +++ b/dist/examples/tilejson-vectortile.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/tilejson-vectortile.js b/dist/examples/tilejson-vectortile.js new file mode 100644 index 00000000..7b51777d --- /dev/null +++ b/dist/examples/tilejson-vectortile.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[843],{3324:(s,e,o)=>{o(8508),(0,o(316).Bb)("map"," https://demo.tegola.io/styles/hot-osm.json")}},s=>{s(s.s=3324)}]); +//# sourceMappingURL=tilejson-vectortile.js.map \ No newline at end of file diff --git a/dist/examples/tilejson-vectortile.js.map b/dist/examples/tilejson-vectortile.js.map new file mode 100644 index 00000000..450a92b5 --- /dev/null +++ b/dist/examples/tilejson-vectortile.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tilejson-vectortile.js","mappings":"0HAGA,E,OAAA,IAAM,MAAO,8C","sources":["webpack://ol-mapbox-style/./examples/tilejson-vectortile.js"],"sourcesContent":["import 'ol/ol.css';\nimport {apply} from 'ol-mapbox-style';\n\napply('map', ' https://demo.tegola.io/styles/hot-osm.json');\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/tilejson.css b/dist/examples/tilejson.css new file mode 100644 index 00000000..e18e8573 --- /dev/null +++ b/dist/examples/tilejson.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=tilejson.css.map*/ \ No newline at end of file diff --git a/dist/examples/tilejson.css.map b/dist/examples/tilejson.css.map new file mode 100644 index 00000000..6a4740ed --- /dev/null +++ b/dist/examples/tilejson.css.map @@ -0,0 +1 @@ +{"version":3,"file":"tilejson.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/tilejson.html b/dist/examples/tilejson.html new file mode 100644 index 00000000..a2535844 --- /dev/null +++ b/dist/examples/tilejson.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/tilejson.js b/dist/examples/tilejson.js new file mode 100644 index 00000000..dc72872f --- /dev/null +++ b/dist/examples/tilejson.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[829],{6506:(s,e,a)=>{a(8508),(0,a(316).Bb)("map","data/tilejson.json")}},s=>{s(s.s=6506)}]); +//# sourceMappingURL=tilejson.js.map \ No newline at end of file diff --git a/dist/examples/tilejson.js.map b/dist/examples/tilejson.js.map new file mode 100644 index 00000000..aad830e6 --- /dev/null +++ b/dist/examples/tilejson.js.map @@ -0,0 +1 @@ +{"version":3,"file":"tilejson.js","mappings":"0HAGA,E,OAAA,IAAM,MAAO,qB","sources":["webpack://ol-mapbox-style/./examples/tilejson.js"],"sourcesContent":["import 'ol/ol.css';\nimport {apply} from 'ol-mapbox-style';\n\napply('map', 'data/tilejson.json');\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/wms.css b/dist/examples/wms.css new file mode 100644 index 00000000..83857b69 --- /dev/null +++ b/dist/examples/wms.css @@ -0,0 +1,357 @@ +:root, +:host { + --ol-background-color: white; + --ol-accent-background-color: #F5F5F5; + --ol-subtle-background-color: rgba(128, 128, 128, 0.25); + --ol-partial-background-color: rgba(255, 255, 255, 0.75); + --ol-foreground-color: #333333; + --ol-subtle-foreground-color: #666666; + --ol-brand-color: #00AAFF; +} + +.ol-box { + box-sizing: border-box; + border-radius: 2px; + border: 1.5px solid var(--ol-background-color); + background-color: var(--ol-partial-background-color); +} + +.ol-mouse-position { + top: 8px; + right: 8px; + position: absolute; +} + +.ol-scale-line { + background: var(--ol-partial-background-color); + border-radius: 4px; + bottom: 8px; + left: 8px; + padding: 2px; + position: absolute; +} + +.ol-scale-line-inner { + border: 1px solid var(--ol-subtle-foreground-color); + border-top: none; + color: var(--ol-foreground-color); + font-size: 10px; + text-align: center; + margin: 1px; + will-change: contents, width; + transition: all 0.25s; +} + +.ol-scale-bar { + position: absolute; + bottom: 8px; + left: 8px; +} + +.ol-scale-bar-inner { + display: flex; +} + +.ol-scale-step-marker { + width: 1px; + height: 15px; + background-color: var(--ol-foreground-color); + float: right; + z-index: 10; +} + +.ol-scale-step-text { + position: absolute; + bottom: -5px; + font-size: 10px; + z-index: 11; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-text { + position: absolute; + font-size: 12px; + text-align: center; + bottom: 25px; + color: var(--ol-foreground-color); + text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color); +} + +.ol-scale-singlebar { + position: relative; + height: 10px; + z-index: 9; + box-sizing: border-box; + border: 1px solid var(--ol-foreground-color); +} + +.ol-scale-singlebar-even { + background-color: var(--ol-subtle-foreground-color); +} + +.ol-scale-singlebar-odd { + background-color: var(--ol-background-color); +} + +.ol-unsupported { + display: none; +} + +.ol-viewport, +.ol-unselectable { + -webkit-touch-callout: none; + -webkit-user-select: none; + -moz-user-select: none; + user-select: none; + -webkit-tap-highlight-color: transparent; +} + +.ol-viewport canvas { + all: unset; + overflow: hidden; +} + +.ol-viewport { + touch-action: pan-x pan-y; +} + +.ol-selectable { + -webkit-touch-callout: default; + -webkit-user-select: text; + -moz-user-select: text; + user-select: text; +} + +.ol-grabbing { + cursor: -webkit-grabbing; + cursor: -moz-grabbing; + cursor: grabbing; +} + +.ol-grab { + cursor: move; + cursor: -webkit-grab; + cursor: -moz-grab; + cursor: grab; +} + +.ol-control { + position: absolute; + background-color: var(--ol-subtle-background-color); + border-radius: 4px; +} + +.ol-zoom { + top: .5em; + left: .5em; +} + +.ol-rotate { + top: .5em; + right: .5em; + transition: opacity .25s linear, visibility 0s linear; +} + +.ol-rotate.ol-hidden { + opacity: 0; + visibility: hidden; + transition: opacity .25s linear, visibility 0s linear .25s; +} + +.ol-zoom-extent { + top: 4.643em; + left: .5em; +} + +.ol-full-screen { + right: .5em; + top: .5em; +} + +.ol-control button { + display: block; + margin: 1px; + padding: 0; + color: var(--ol-subtle-foreground-color); + font-weight: bold; + text-decoration: none; + font-size: inherit; + text-align: center; + height: 1.375em; + width: 1.375em; + line-height: .4em; + background-color: var(--ol-background-color); + border: none; + border-radius: 2px; +} + +.ol-control button::-moz-focus-inner { + border: none; + padding: 0; +} + +.ol-zoom-extent button { + line-height: 1.4em; +} + +.ol-compass { + display: block; + font-weight: normal; + will-change: transform; +} + +.ol-touch .ol-control button { + font-size: 1.5em; +} + +.ol-touch .ol-zoom-extent { + top: 5.5em; +} + +.ol-control button:hover, +.ol-control button:focus { + text-decoration: none; + outline: 1px solid var(--ol-subtle-foreground-color); + color: var(--ol-foreground-color); +} + +.ol-zoom .ol-zoom-in { + border-radius: 2px 2px 0 0; +} + +.ol-zoom .ol-zoom-out { + border-radius: 0 0 2px 2px; +} + +.ol-attribution { + text-align: right; + bottom: .5em; + right: .5em; + max-width: calc(100% - 1.3em); + display: flex; + flex-flow: row-reverse; + align-items: center; +} + +.ol-attribution a { + color: var(--ol-subtle-foreground-color); + text-decoration: none; +} + +.ol-attribution ul { + margin: 0; + padding: 1px .5em; + color: var(--ol-foreground-color); + text-shadow: 0 0 2px var(--ol-background-color); + font-size: 12px; +} + +.ol-attribution li { + display: inline; + list-style: none; +} + +.ol-attribution li:not(:last-child):after { + content: " "; +} + +.ol-attribution img { + max-height: 2em; + max-width: inherit; + vertical-align: middle; +} + +.ol-attribution button { + flex-shrink: 0; +} + +.ol-attribution.ol-collapsed ul { + display: none; +} + +.ol-attribution:not(.ol-collapsed) { + background: var(--ol-partial-background-color); +} + +.ol-attribution.ol-uncollapsible { + bottom: 0; + right: 0; + border-radius: 4px 0 0; +} + +.ol-attribution.ol-uncollapsible img { + margin-top: -.2em; + max-height: 1.6em; +} + +.ol-attribution.ol-uncollapsible button { + display: none; +} + +.ol-zoomslider { + top: 4.5em; + left: .5em; + height: 200px; +} + +.ol-zoomslider button { + position: relative; + height: 10px; +} + +.ol-touch .ol-zoomslider { + top: 5.5em; +} + +.ol-overviewmap { + left: 0.5em; + bottom: 0.5em; +} + +.ol-overviewmap.ol-uncollapsible { + bottom: 0; + left: 0; + border-radius: 0 4px 0 0; +} + +.ol-overviewmap .ol-overviewmap-map, +.ol-overviewmap button { + display: block; +} + +.ol-overviewmap .ol-overviewmap-map { + border: 1px solid var(--ol-subtle-foreground-color); + height: 150px; + width: 150px; +} + +.ol-overviewmap:not(.ol-collapsed) button { + bottom: 0; + left: 0; + position: absolute; +} + +.ol-overviewmap.ol-collapsed .ol-overviewmap-map, +.ol-overviewmap.ol-uncollapsible button { + display: none; +} + +.ol-overviewmap:not(.ol-collapsed) { + background: var(--ol-subtle-background-color); +} + +.ol-overviewmap-box { + border: 1.5px dotted var(--ol-subtle-foreground-color); +} + +.ol-overviewmap .ol-overviewmap-box:hover { + cursor: move; +} + +.ol-overviewmap .ol-viewport:hover { + cursor: pointer; +} + + +/*# sourceMappingURL=wms.css.map*/ \ No newline at end of file diff --git a/dist/examples/wms.css.map b/dist/examples/wms.css.map new file mode 100644 index 00000000..15c95a2d --- /dev/null +++ b/dist/examples/wms.css.map @@ -0,0 +1 @@ +{"version":3,"file":"wms.css","mappings":"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","sources":["webpack://ol-mapbox-style/./node_modules/ol/ol.css"],"sourcesContent":[":root,\n:host {\n --ol-background-color: white;\n --ol-accent-background-color: #F5F5F5;\n --ol-subtle-background-color: rgba(128, 128, 128, 0.25);\n --ol-partial-background-color: rgba(255, 255, 255, 0.75);\n --ol-foreground-color: #333333;\n --ol-subtle-foreground-color: #666666;\n --ol-brand-color: #00AAFF;\n}\n\n.ol-box {\n box-sizing: border-box;\n border-radius: 2px;\n border: 1.5px solid var(--ol-background-color);\n background-color: var(--ol-partial-background-color);\n}\n\n.ol-mouse-position {\n top: 8px;\n right: 8px;\n position: absolute;\n}\n\n.ol-scale-line {\n background: var(--ol-partial-background-color);\n border-radius: 4px;\n bottom: 8px;\n left: 8px;\n padding: 2px;\n position: absolute;\n}\n\n.ol-scale-line-inner {\n border: 1px solid var(--ol-subtle-foreground-color);\n border-top: none;\n color: var(--ol-foreground-color);\n font-size: 10px;\n text-align: center;\n margin: 1px;\n will-change: contents, width;\n transition: all 0.25s;\n}\n\n.ol-scale-bar {\n position: absolute;\n bottom: 8px;\n left: 8px;\n}\n\n.ol-scale-bar-inner {\n display: flex;\n}\n\n.ol-scale-step-marker {\n width: 1px;\n height: 15px;\n background-color: var(--ol-foreground-color);\n float: right;\n z-index: 10;\n}\n\n.ol-scale-step-text {\n position: absolute;\n bottom: -5px;\n font-size: 10px;\n z-index: 11;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-text {\n position: absolute;\n font-size: 12px;\n text-align: center;\n bottom: 25px;\n color: var(--ol-foreground-color);\n text-shadow: -1.5px 0 var(--ol-partial-background-color), 0 1.5px var(--ol-partial-background-color), 1.5px 0 var(--ol-partial-background-color), 0 -1.5px var(--ol-partial-background-color);\n}\n\n.ol-scale-singlebar {\n position: relative;\n height: 10px;\n z-index: 9;\n box-sizing: border-box;\n border: 1px solid var(--ol-foreground-color);\n}\n\n.ol-scale-singlebar-even {\n background-color: var(--ol-subtle-foreground-color);\n}\n\n.ol-scale-singlebar-odd {\n background-color: var(--ol-background-color);\n}\n\n.ol-unsupported {\n display: none;\n}\n\n.ol-viewport,\n.ol-unselectable {\n -webkit-touch-callout: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n\n.ol-viewport canvas {\n all: unset;\n overflow: hidden;\n}\n\n.ol-viewport {\n touch-action: pan-x pan-y;\n}\n\n.ol-selectable {\n -webkit-touch-callout: default;\n -webkit-user-select: text;\n -moz-user-select: text;\n user-select: text;\n}\n\n.ol-grabbing {\n cursor: -webkit-grabbing;\n cursor: -moz-grabbing;\n cursor: grabbing;\n}\n\n.ol-grab {\n cursor: move;\n cursor: -webkit-grab;\n cursor: -moz-grab;\n cursor: grab;\n}\n\n.ol-control {\n position: absolute;\n background-color: var(--ol-subtle-background-color);\n border-radius: 4px;\n}\n\n.ol-zoom {\n top: .5em;\n left: .5em;\n}\n\n.ol-rotate {\n top: .5em;\n right: .5em;\n transition: opacity .25s linear, visibility 0s linear;\n}\n\n.ol-rotate.ol-hidden {\n opacity: 0;\n visibility: hidden;\n transition: opacity .25s linear, visibility 0s linear .25s;\n}\n\n.ol-zoom-extent {\n top: 4.643em;\n left: .5em;\n}\n\n.ol-full-screen {\n right: .5em;\n top: .5em;\n}\n\n.ol-control button {\n display: block;\n margin: 1px;\n padding: 0;\n color: var(--ol-subtle-foreground-color);\n font-weight: bold;\n text-decoration: none;\n font-size: inherit;\n text-align: center;\n height: 1.375em;\n width: 1.375em;\n line-height: .4em;\n background-color: var(--ol-background-color);\n border: none;\n border-radius: 2px;\n}\n\n.ol-control button::-moz-focus-inner {\n border: none;\n padding: 0;\n}\n\n.ol-zoom-extent button {\n line-height: 1.4em;\n}\n\n.ol-compass {\n display: block;\n font-weight: normal;\n will-change: transform;\n}\n\n.ol-touch .ol-control button {\n font-size: 1.5em;\n}\n\n.ol-touch .ol-zoom-extent {\n top: 5.5em;\n}\n\n.ol-control button:hover,\n.ol-control button:focus {\n text-decoration: none;\n outline: 1px solid var(--ol-subtle-foreground-color);\n color: var(--ol-foreground-color);\n}\n\n.ol-zoom .ol-zoom-in {\n border-radius: 2px 2px 0 0;\n}\n\n.ol-zoom .ol-zoom-out {\n border-radius: 0 0 2px 2px;\n}\n\n.ol-attribution {\n text-align: right;\n bottom: .5em;\n right: .5em;\n max-width: calc(100% - 1.3em);\n display: flex;\n flex-flow: row-reverse;\n align-items: center;\n}\n\n.ol-attribution a {\n color: var(--ol-subtle-foreground-color);\n text-decoration: none;\n}\n\n.ol-attribution ul {\n margin: 0;\n padding: 1px .5em;\n color: var(--ol-foreground-color);\n text-shadow: 0 0 2px var(--ol-background-color);\n font-size: 12px;\n}\n\n.ol-attribution li {\n display: inline;\n list-style: none;\n}\n\n.ol-attribution li:not(:last-child):after {\n content: \" \";\n}\n\n.ol-attribution img {\n max-height: 2em;\n max-width: inherit;\n vertical-align: middle;\n}\n\n.ol-attribution button {\n flex-shrink: 0;\n}\n\n.ol-attribution.ol-collapsed ul {\n display: none;\n}\n\n.ol-attribution:not(.ol-collapsed) {\n background: var(--ol-partial-background-color);\n}\n\n.ol-attribution.ol-uncollapsible {\n bottom: 0;\n right: 0;\n border-radius: 4px 0 0;\n}\n\n.ol-attribution.ol-uncollapsible img {\n margin-top: -.2em;\n max-height: 1.6em;\n}\n\n.ol-attribution.ol-uncollapsible button {\n display: none;\n}\n\n.ol-zoomslider {\n top: 4.5em;\n left: .5em;\n height: 200px;\n}\n\n.ol-zoomslider button {\n position: relative;\n height: 10px;\n}\n\n.ol-touch .ol-zoomslider {\n top: 5.5em;\n}\n\n.ol-overviewmap {\n left: 0.5em;\n bottom: 0.5em;\n}\n\n.ol-overviewmap.ol-uncollapsible {\n bottom: 0;\n left: 0;\n border-radius: 0 4px 0 0;\n}\n\n.ol-overviewmap .ol-overviewmap-map,\n.ol-overviewmap button {\n display: block;\n}\n\n.ol-overviewmap .ol-overviewmap-map {\n border: 1px solid var(--ol-subtle-foreground-color);\n height: 150px;\n width: 150px;\n}\n\n.ol-overviewmap:not(.ol-collapsed) button {\n bottom: 0;\n left: 0;\n position: absolute;\n}\n\n.ol-overviewmap.ol-collapsed .ol-overviewmap-map,\n.ol-overviewmap.ol-uncollapsible button {\n display: none;\n}\n\n.ol-overviewmap:not(.ol-collapsed) {\n background: var(--ol-subtle-background-color);\n}\n\n.ol-overviewmap-box {\n border: 1.5px dotted var(--ol-subtle-foreground-color);\n}\n\n.ol-overviewmap .ol-overviewmap-box:hover {\n cursor: move;\n}\n\n.ol-overviewmap .ol-viewport:hover {\n cursor: pointer;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/examples/wms.html b/dist/examples/wms.html new file mode 100644 index 00000000..71ceb6de --- /dev/null +++ b/dist/examples/wms.html @@ -0,0 +1,8 @@ +ol-mapbox-style example
\ No newline at end of file diff --git a/dist/examples/wms.js b/dist/examples/wms.js new file mode 100644 index 00000000..40675c06 --- /dev/null +++ b/dist/examples/wms.js @@ -0,0 +1,2 @@ +"use strict";(self.webpackChunkol_mapbox_style=self.webpackChunkol_mapbox_style||[]).push([[498],{8323:(s,a,e)=>{e(8508),(0,e(316).Ay)("map","data/wms.json")}},s=>{s(s.s=8323)}]); +//# sourceMappingURL=wms.js.map \ No newline at end of file diff --git a/dist/examples/wms.js.map b/dist/examples/wms.js.map new file mode 100644 index 00000000..dbbb0c64 --- /dev/null +++ b/dist/examples/wms.js.map @@ -0,0 +1 @@ +{"version":3,"file":"wms.js","mappings":"0HAGA,E,OAAA,IAAK,MAAO,gB","sources":["webpack://ol-mapbox-style/./examples/wms.js"],"sourcesContent":["import 'ol/ol.css';\nimport olms from 'ol-mapbox-style';\n\nolms('map', 'data/wms.json');\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/dist/index.d.ts b/dist/index.d.ts new file mode 100644 index 00000000..bd8a72ab --- /dev/null +++ b/dist/index.d.ts @@ -0,0 +1,3 @@ +export { default as MapboxVectorLayer } from "./MapboxVectorLayer.js"; +export { stylefunction, recordStyleLayer, renderTransparent, getStyleForLayer } from "./stylefunction.js"; +export { apply as default, apply, applyBackground, applyStyle, getLayer, getLayers, getSource, getMapboxLayer, updateMapboxSource, updateMapboxLayer, addMapboxLayer, removeMapboxLayer, getFeatureState, setFeatureState } from "./apply.js"; diff --git a/dist/index.js b/dist/index.js new file mode 100644 index 00000000..455cec6c --- /dev/null +++ b/dist/index.js @@ -0,0 +1,8816 @@ +import Circle from 'ol/style/Circle.js'; +import Fill from 'ol/style/Fill.js'; +import Icon from 'ol/style/Icon.js'; +import RenderFeature from 'ol/render/Feature.js'; +import Stroke from 'ol/style/Stroke.js'; +import Style from 'ol/style/Style.js'; +import Text from 'ol/style/Text.js'; +import { toPromise } from 'ol/functions.js'; +import { registerFont, checkedFonts } from 'ol/render/canvas.js'; +import TileState from 'ol/TileState.js'; +import { VectorTile } from 'ol'; +import { getUid } from 'ol/util.js'; +import GeoJSON from 'ol/format/GeoJSON.js'; +import ImageLayer from 'ol/layer/Image.js'; +import Layer from 'ol/layer/Layer.js'; +import LayerGroup from 'ol/layer/Group.js'; +import MVT from 'ol/format/MVT.js'; +import Map from 'ol/Map.js'; +import Raster from 'ol/source/Raster.js'; +import Source from 'ol/source/Source.js'; +import TileGrid from 'ol/tilegrid/TileGrid.js'; +import TileJSON from 'ol/source/TileJSON.js'; +import TileLayer from 'ol/layer/Tile.js'; +import VectorLayer from 'ol/layer/Vector.js'; +import VectorSource from 'ol/source/Vector.js'; +import VectorTileLayer from 'ol/layer/VectorTile.js'; +import VectorTileSource, { defaultLoadFunction } from 'ol/source/VectorTile.js'; +import View from 'ol/View.js'; +import { METERS_PER_UNIT } from 'ol/proj/Units.js'; +import { bbox } from 'ol/loadingstrategy.js'; +import { createXYZ } from 'ol/tilegrid.js'; +import { get as get$1, getUserProjection, getPointResolution, fromLonLat, equivalent } from 'ol/proj.js'; +import { getCenter, getTopLeft } from 'ol/extent.js'; +import BaseEvent from 'ol/events/Event.js'; +import EventType from 'ol/events/EventType.js'; + +function getDefaultExportFromCjs (x) { + return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x['default'] : x; +} + +var csscolorparser = {}; + +var parseCSSColor_1; +// (c) Dean McNamee , 2012. +// +// https://github.com/deanm/css-color-parser-js +// +// Permission is hereby granted, free of charge, to any person obtaining a copy +// of this software and associated documentation files (the "Software"), to +// deal in the Software without restriction, including without limitation the +// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or +// sell copies of the Software, and to permit persons to whom the Software is +// furnished to do so, subject to the following conditions: +// +// The above copyright notice and this permission notice shall be included in +// all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS +// IN THE SOFTWARE. +// http://www.w3.org/TR/css3-color/ +var kCSSColorTable = { + 'transparent': [ + 0, + 0, + 0, + 0 + ], + 'aliceblue': [ + 240, + 248, + 255, + 1 + ], + 'antiquewhite': [ + 250, + 235, + 215, + 1 + ], + 'aqua': [ + 0, + 255, + 255, + 1 + ], + 'aquamarine': [ + 127, + 255, + 212, + 1 + ], + 'azure': [ + 240, + 255, + 255, + 1 + ], + 'beige': [ + 245, + 245, + 220, + 1 + ], + 'bisque': [ + 255, + 228, + 196, + 1 + ], + 'black': [ + 0, + 0, + 0, + 1 + ], + 'blanchedalmond': [ + 255, + 235, + 205, + 1 + ], + 'blue': [ + 0, + 0, + 255, + 1 + ], + 'blueviolet': [ + 138, + 43, + 226, + 1 + ], + 'brown': [ + 165, + 42, + 42, + 1 + ], + 'burlywood': [ + 222, + 184, + 135, + 1 + ], + 'cadetblue': [ + 95, + 158, + 160, + 1 + ], + 'chartreuse': [ + 127, + 255, + 0, + 1 + ], + 'chocolate': [ + 210, + 105, + 30, + 1 + ], + 'coral': [ + 255, + 127, + 80, + 1 + ], + 'cornflowerblue': [ + 100, + 149, + 237, + 1 + ], + 'cornsilk': [ + 255, + 248, + 220, + 1 + ], + 'crimson': [ + 220, + 20, + 60, + 1 + ], + 'cyan': [ + 0, + 255, + 255, + 1 + ], + 'darkblue': [ + 0, + 0, + 139, + 1 + ], + 'darkcyan': [ + 0, + 139, + 139, + 1 + ], + 'darkgoldenrod': [ + 184, + 134, + 11, + 1 + ], + 'darkgray': [ + 169, + 169, + 169, + 1 + ], + 'darkgreen': [ + 0, + 100, + 0, + 1 + ], + 'darkgrey': [ + 169, + 169, + 169, + 1 + ], + 'darkkhaki': [ + 189, + 183, + 107, + 1 + ], + 'darkmagenta': [ + 139, + 0, + 139, + 1 + ], + 'darkolivegreen': [ + 85, + 107, + 47, + 1 + ], + 'darkorange': [ + 255, + 140, + 0, + 1 + ], + 'darkorchid': [ + 153, + 50, + 204, + 1 + ], + 'darkred': [ + 139, + 0, + 0, + 1 + ], + 'darksalmon': [ + 233, + 150, + 122, + 1 + ], + 'darkseagreen': [ + 143, + 188, + 143, + 1 + ], + 'darkslateblue': [ + 72, + 61, + 139, + 1 + ], + 'darkslategray': [ + 47, + 79, + 79, + 1 + ], + 'darkslategrey': [ + 47, + 79, + 79, + 1 + ], + 'darkturquoise': [ + 0, + 206, + 209, + 1 + ], + 'darkviolet': [ + 148, + 0, + 211, + 1 + ], + 'deeppink': [ + 255, + 20, + 147, + 1 + ], + 'deepskyblue': [ + 0, + 191, + 255, + 1 + ], + 'dimgray': [ + 105, + 105, + 105, + 1 + ], + 'dimgrey': [ + 105, + 105, + 105, + 1 + ], + 'dodgerblue': [ + 30, + 144, + 255, + 1 + ], + 'firebrick': [ + 178, + 34, + 34, + 1 + ], + 'floralwhite': [ + 255, + 250, + 240, + 1 + ], + 'forestgreen': [ + 34, + 139, + 34, + 1 + ], + 'fuchsia': [ + 255, + 0, + 255, + 1 + ], + 'gainsboro': [ + 220, + 220, + 220, + 1 + ], + 'ghostwhite': [ + 248, + 248, + 255, + 1 + ], + 'gold': [ + 255, + 215, + 0, + 1 + ], + 'goldenrod': [ + 218, + 165, + 32, + 1 + ], + 'gray': [ + 128, + 128, + 128, + 1 + ], + 'green': [ + 0, + 128, + 0, + 1 + ], + 'greenyellow': [ + 173, + 255, + 47, + 1 + ], + 'grey': [ + 128, + 128, + 128, + 1 + ], + 'honeydew': [ + 240, + 255, + 240, + 1 + ], + 'hotpink': [ + 255, + 105, + 180, + 1 + ], + 'indianred': [ + 205, + 92, + 92, + 1 + ], + 'indigo': [ + 75, + 0, + 130, + 1 + ], + 'ivory': [ + 255, + 255, + 240, + 1 + ], + 'khaki': [ + 240, + 230, + 140, + 1 + ], + 'lavender': [ + 230, + 230, + 250, + 1 + ], + 'lavenderblush': [ + 255, + 240, + 245, + 1 + ], + 'lawngreen': [ + 124, + 252, + 0, + 1 + ], + 'lemonchiffon': [ + 255, + 250, + 205, + 1 + ], + 'lightblue': [ + 173, + 216, + 230, + 1 + ], + 'lightcoral': [ + 240, + 128, + 128, + 1 + ], + 'lightcyan': [ + 224, + 255, + 255, + 1 + ], + 'lightgoldenrodyellow': [ + 250, + 250, + 210, + 1 + ], + 'lightgray': [ + 211, + 211, + 211, + 1 + ], + 'lightgreen': [ + 144, + 238, + 144, + 1 + ], + 'lightgrey': [ + 211, + 211, + 211, + 1 + ], + 'lightpink': [ + 255, + 182, + 193, + 1 + ], + 'lightsalmon': [ + 255, + 160, + 122, + 1 + ], + 'lightseagreen': [ + 32, + 178, + 170, + 1 + ], + 'lightskyblue': [ + 135, + 206, + 250, + 1 + ], + 'lightslategray': [ + 119, + 136, + 153, + 1 + ], + 'lightslategrey': [ + 119, + 136, + 153, + 1 + ], + 'lightsteelblue': [ + 176, + 196, + 222, + 1 + ], + 'lightyellow': [ + 255, + 255, + 224, + 1 + ], + 'lime': [ + 0, + 255, + 0, + 1 + ], + 'limegreen': [ + 50, + 205, + 50, + 1 + ], + 'linen': [ + 250, + 240, + 230, + 1 + ], + 'magenta': [ + 255, + 0, + 255, + 1 + ], + 'maroon': [ + 128, + 0, + 0, + 1 + ], + 'mediumaquamarine': [ + 102, + 205, + 170, + 1 + ], + 'mediumblue': [ + 0, + 0, + 205, + 1 + ], + 'mediumorchid': [ + 186, + 85, + 211, + 1 + ], + 'mediumpurple': [ + 147, + 112, + 219, + 1 + ], + 'mediumseagreen': [ + 60, + 179, + 113, + 1 + ], + 'mediumslateblue': [ + 123, + 104, + 238, + 1 + ], + 'mediumspringgreen': [ + 0, + 250, + 154, + 1 + ], + 'mediumturquoise': [ + 72, + 209, + 204, + 1 + ], + 'mediumvioletred': [ + 199, + 21, + 133, + 1 + ], + 'midnightblue': [ + 25, + 25, + 112, + 1 + ], + 'mintcream': [ + 245, + 255, + 250, + 1 + ], + 'mistyrose': [ + 255, + 228, + 225, + 1 + ], + 'moccasin': [ + 255, + 228, + 181, + 1 + ], + 'navajowhite': [ + 255, + 222, + 173, + 1 + ], + 'navy': [ + 0, + 0, + 128, + 1 + ], + 'oldlace': [ + 253, + 245, + 230, + 1 + ], + 'olive': [ + 128, + 128, + 0, + 1 + ], + 'olivedrab': [ + 107, + 142, + 35, + 1 + ], + 'orange': [ + 255, + 165, + 0, + 1 + ], + 'orangered': [ + 255, + 69, + 0, + 1 + ], + 'orchid': [ + 218, + 112, + 214, + 1 + ], + 'palegoldenrod': [ + 238, + 232, + 170, + 1 + ], + 'palegreen': [ + 152, + 251, + 152, + 1 + ], + 'paleturquoise': [ + 175, + 238, + 238, + 1 + ], + 'palevioletred': [ + 219, + 112, + 147, + 1 + ], + 'papayawhip': [ + 255, + 239, + 213, + 1 + ], + 'peachpuff': [ + 255, + 218, + 185, + 1 + ], + 'peru': [ + 205, + 133, + 63, + 1 + ], + 'pink': [ + 255, + 192, + 203, + 1 + ], + 'plum': [ + 221, + 160, + 221, + 1 + ], + 'powderblue': [ + 176, + 224, + 230, + 1 + ], + 'purple': [ + 128, + 0, + 128, + 1 + ], + 'rebeccapurple': [ + 102, + 51, + 153, + 1 + ], + 'red': [ + 255, + 0, + 0, + 1 + ], + 'rosybrown': [ + 188, + 143, + 143, + 1 + ], + 'royalblue': [ + 65, + 105, + 225, + 1 + ], + 'saddlebrown': [ + 139, + 69, + 19, + 1 + ], + 'salmon': [ + 250, + 128, + 114, + 1 + ], + 'sandybrown': [ + 244, + 164, + 96, + 1 + ], + 'seagreen': [ + 46, + 139, + 87, + 1 + ], + 'seashell': [ + 255, + 245, + 238, + 1 + ], + 'sienna': [ + 160, + 82, + 45, + 1 + ], + 'silver': [ + 192, + 192, + 192, + 1 + ], + 'skyblue': [ + 135, + 206, + 235, + 1 + ], + 'slateblue': [ + 106, + 90, + 205, + 1 + ], + 'slategray': [ + 112, + 128, + 144, + 1 + ], + 'slategrey': [ + 112, + 128, + 144, + 1 + ], + 'snow': [ + 255, + 250, + 250, + 1 + ], + 'springgreen': [ + 0, + 255, + 127, + 1 + ], + 'steelblue': [ + 70, + 130, + 180, + 1 + ], + 'tan': [ + 210, + 180, + 140, + 1 + ], + 'teal': [ + 0, + 128, + 128, + 1 + ], + 'thistle': [ + 216, + 191, + 216, + 1 + ], + 'tomato': [ + 255, + 99, + 71, + 1 + ], + 'turquoise': [ + 64, + 224, + 208, + 1 + ], + 'violet': [ + 238, + 130, + 238, + 1 + ], + 'wheat': [ + 245, + 222, + 179, + 1 + ], + 'white': [ + 255, + 255, + 255, + 1 + ], + 'whitesmoke': [ + 245, + 245, + 245, + 1 + ], + 'yellow': [ + 255, + 255, + 0, + 1 + ], + 'yellowgreen': [ + 154, + 205, + 50, + 1 + ] +}; +function clamp_css_byte(i) { + // Clamp to integer 0 .. 255. + i = Math.round(i); + // Seems to be what Chrome does (vs truncation). + return i < 0 ? 0 : i > 255 ? 255 : i; +} +function clamp_css_float(f) { + // Clamp to float 0.0 .. 1.0. + return f < 0 ? 0 : f > 1 ? 1 : f; +} +function parse_css_int(str) { + // int or percentage. + if (str[str.length - 1] === '%') + return clamp_css_byte(parseFloat(str) / 100 * 255); + return clamp_css_byte(parseInt(str)); +} +function parse_css_float(str) { + // float or percentage. + if (str[str.length - 1] === '%') + return clamp_css_float(parseFloat(str) / 100); + return clamp_css_float(parseFloat(str)); +} +function css_hue_to_rgb(m1, m2, h) { + if (h < 0) + h += 1; + else if (h > 1) + h -= 1; + if (h * 6 < 1) + return m1 + (m2 - m1) * h * 6; + if (h * 2 < 1) + return m2; + if (h * 3 < 2) + return m1 + (m2 - m1) * (2 / 3 - h) * 6; + return m1; +} +function parseCSSColor(css_str) { + // Remove all whitespace, not compliant, but should just be more accepting. + var str = css_str.replace(/ /g, '').toLowerCase(); + // Color keywords (and transparent) lookup. + if (str in kCSSColorTable) + return kCSSColorTable[str].slice(); + // dup. + // #abc and #abc123 syntax. + if (str[0] === '#') { + if (str.length === 4) { + var iv = parseInt(str.substr(1), 16); + // TODO(deanm): Stricter parsing. + if (!(iv >= 0 && iv <= 4095)) + return null; + // Covers NaN. + return [ + (iv & 3840) >> 4 | (iv & 3840) >> 8, + iv & 240 | (iv & 240) >> 4, + iv & 15 | (iv & 15) << 4, + 1 + ]; + } else if (str.length === 7) { + var iv = parseInt(str.substr(1), 16); + // TODO(deanm): Stricter parsing. + if (!(iv >= 0 && iv <= 16777215)) + return null; + // Covers NaN. + return [ + (iv & 16711680) >> 16, + (iv & 65280) >> 8, + iv & 255, + 1 + ]; + } + return null; + } + var op = str.indexOf('('), ep = str.indexOf(')'); + if (op !== -1 && ep + 1 === str.length) { + var fname = str.substr(0, op); + var params = str.substr(op + 1, ep - (op + 1)).split(','); + var alpha = 1; + // To allow case fallthrough. + switch (fname) { + case 'rgba': + if (params.length !== 4) + return null; + alpha = parse_css_float(params.pop()); + // Fall through. + case 'rgb': + if (params.length !== 3) + return null; + return [ + parse_css_int(params[0]), + parse_css_int(params[1]), + parse_css_int(params[2]), + alpha + ]; + case 'hsla': + if (params.length !== 4) + return null; + alpha = parse_css_float(params.pop()); + // Fall through. + case 'hsl': + if (params.length !== 3) + return null; + var h = (parseFloat(params[0]) % 360 + 360) % 360 / 360; + // 0 .. 1 + // NOTE(deanm): According to the CSS spec s/l should only be + // percentages, but we don't bother and let float or percentage. + var s = parse_css_float(params[1]); + var l = parse_css_float(params[2]); + var m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s; + var m1 = l * 2 - m2; + return [ + clamp_css_byte(css_hue_to_rgb(m1, m2, h + 1 / 3) * 255), + clamp_css_byte(css_hue_to_rgb(m1, m2, h) * 255), + clamp_css_byte(css_hue_to_rgb(m1, m2, h - 1 / 3) * 255), + alpha + ]; + default: + return null; + } + } + return null; +} +try { + parseCSSColor_1 = csscolorparser.parseCSSColor = parseCSSColor; +} catch (e) { +} + +// +/** + * An RGBA color value. Create instances from color strings using the static + * method `Color.parse`. The constructor accepts RGB channel values in the range + * `[0, 1]`, premultiplied by A. + * + * @param {number} r The red channel. + * @param {number} g The green channel. + * @param {number} b The blue channel. + * @param {number} a The alpha channel. + * @private + */ +class Color { + constructor(r, g, b, a = 1) { + this.r = r; + this.g = g; + this.b = b; + this.a = a; + } + /** + * Parses valid CSS color strings and returns a `Color` instance. + * @returns A `Color` instance, or `undefined` if the input is not a valid color string. + */ + static parse(input) { + if (!input) { + return undefined; + } + if (input instanceof Color) { + return input; + } + if (typeof input !== 'string') { + return undefined; + } + const rgba = parseCSSColor_1(input); + if (!rgba) { + return undefined; + } + return new Color(rgba[0] / 255 * rgba[3], rgba[1] / 255 * rgba[3], rgba[2] / 255 * rgba[3], rgba[3]); + } + /** + * Returns an RGBA string representing the color value. + * + * @returns An RGBA string. + * @example + * var purple = new Color.parse('purple'); + * purple.toString; // = "rgba(128,0,128,1)" + * var translucentGreen = new Color.parse('rgba(26, 207, 26, .73)'); + * translucentGreen.toString(); // = "rgba(26,207,26,0.73)" + */ + toString() { + const [r, g, b, a] = this.toArray(); + return `rgba(${ Math.round(r) },${ Math.round(g) },${ Math.round(b) },${ a })`; + } + /** + * Returns an RGBA array of values representing the color, unpremultiplied by A. + * + * @returns An array of RGBA color values in the range [0, 255]. + */ + toArray() { + const {r, g, b, a} = this; + return a === 0 ? [ + 0, + 0, + 0, + 0 + ] : [ + r * 255 / a, + g * 255 / a, + b * 255 / a, + a + ]; + } + /** + * Returns a RGBA array of float values representing the color, unpremultiplied by A. + * + * @returns An array of RGBA color values in the range [0, 1]. + */ + toArray01() { + const {r, g, b, a} = this; + return a === 0 ? [ + 0, + 0, + 0, + 0 + ] : [ + r / a, + g / a, + b / a, + a + ]; + } + /** + * Returns an RGBA array of values representing the color, premultiplied by A. + * + * @returns An array of RGBA color values in the range [0, 1]. + */ + toArray01PremultipliedAlpha() { + const {r, g, b, a} = this; + return [ + r, + g, + b, + a + ]; + } +} +Color.black = new Color(0, 0, 0, 1); +Color.white = new Color(1, 1, 1, 1); +Color.transparent = new Color(0, 0, 0, 0); +Color.red = new Color(1, 0, 0, 1); +Color.blue = new Color(0, 0, 1, 1); +var Color$1 = Color; + +function convertLiteral(value) { + return typeof value === 'object' ? [ + 'literal', + value + ] : value; +} +function convertFunction(parameters, propertySpec) { + let stops = parameters.stops; + if (!stops) { + // identity function + return convertIdentityFunction(parameters, propertySpec); + } + const zoomAndFeatureDependent = stops && typeof stops[0][0] === 'object'; + const featureDependent = zoomAndFeatureDependent || parameters.property !== undefined; + const zoomDependent = zoomAndFeatureDependent || !featureDependent; + stops = stops.map(stop => { + if (!featureDependent && propertySpec.tokens && typeof stop[1] === 'string') { + return [ + stop[0], + convertTokenString(stop[1]) + ]; + } + return [ + stop[0], + convertLiteral(stop[1]) + ]; + }); + if (zoomAndFeatureDependent) { + return convertZoomAndPropertyFunction(parameters, propertySpec, stops); + } else if (zoomDependent) { + return convertZoomFunction(parameters, propertySpec, stops); + } else { + return convertPropertyFunction(parameters, propertySpec, stops); + } +} +function convertIdentityFunction(parameters, propertySpec) { + const get = [ + 'get', + parameters.property + ]; + if (parameters.default === undefined) { + // By default, expressions for string-valued properties get coerced. To preserve + // legacy function semantics, insert an explicit assertion instead. + return propertySpec.type === 'string' ? [ + 'string', + get + ] : get; + } else if (propertySpec.type === 'enum') { + return [ + 'match', + get, + Object.keys(propertySpec.values), + get, + parameters.default + ]; + } else { + const expression = [ + propertySpec.type === 'color' ? 'to-color' : propertySpec.type, + get, + convertLiteral(parameters.default) + ]; + if (propertySpec.type === 'array') { + expression.splice(1, 0, propertySpec.value, propertySpec.length || null); + } + return expression; + } +} +function getInterpolateOperator(parameters) { + switch (parameters.colorSpace) { + case 'hcl': + return 'interpolate-hcl'; + case 'lab': + return 'interpolate-lab'; + default: + return 'interpolate'; + } +} +function convertZoomAndPropertyFunction(parameters, propertySpec, stops) { + const featureFunctionParameters = {}; + const featureFunctionStops = {}; + const zoomStops = []; + for (let s = 0; s < stops.length; s++) { + const stop = stops[s]; + const zoom = stop[0].zoom; + if (featureFunctionParameters[zoom] === undefined) { + featureFunctionParameters[zoom] = { + zoom, + type: parameters.type, + property: parameters.property, + default: parameters.default + }; + featureFunctionStops[zoom] = []; + zoomStops.push(zoom); + } + featureFunctionStops[zoom].push([ + stop[0].value, + stop[1] + ]); + } + // the interpolation type for the zoom dimension of a zoom-and-property + // function is determined directly from the style property specification + // for which it's being used: linear for interpolatable properties, step + // otherwise. + const functionType = getFunctionType({}, propertySpec); + if (functionType === 'exponential') { + const expression = [ + getInterpolateOperator(parameters), + ['linear'], + ['zoom'] + ]; + for (const z of zoomStops) { + const output = convertPropertyFunction(featureFunctionParameters[z], propertySpec, featureFunctionStops[z]); + appendStopPair(expression, z, output, false); + } + return expression; + } else { + const expression = [ + 'step', + ['zoom'] + ]; + for (const z of zoomStops) { + const output = convertPropertyFunction(featureFunctionParameters[z], propertySpec, featureFunctionStops[z]); + appendStopPair(expression, z, output, true); + } + fixupDegenerateStepCurve(expression); + return expression; + } +} +function coalesce(a, b) { + if (a !== undefined) + return a; + if (b !== undefined) + return b; +} +function getFallback(parameters, propertySpec) { + const defaultValue = convertLiteral(coalesce(parameters.default, propertySpec.default)); + /* + * Some fields with type: resolvedImage have an undefined default. + * Because undefined is an invalid value for resolvedImage, set fallback to + * an empty string instead of undefined to ensure output + * passes validation. + */ + if (defaultValue === undefined && propertySpec.type === 'resolvedImage') { + return ''; + } + return defaultValue; +} +function convertPropertyFunction(parameters, propertySpec, stops) { + const type = getFunctionType(parameters, propertySpec); + const get = [ + 'get', + parameters.property + ]; + if (type === 'categorical' && typeof stops[0][0] === 'boolean') { + const expression = ['case']; + for (const stop of stops) { + expression.push([ + '==', + get, + stop[0] + ], stop[1]); + } + expression.push(getFallback(parameters, propertySpec)); + return expression; + } else if (type === 'categorical') { + const expression = [ + 'match', + get + ]; + for (const stop of stops) { + appendStopPair(expression, stop[0], stop[1], false); + } + expression.push(getFallback(parameters, propertySpec)); + return expression; + } else if (type === 'interval') { + const expression = [ + 'step', + [ + 'number', + get + ] + ]; + for (const stop of stops) { + appendStopPair(expression, stop[0], stop[1], true); + } + fixupDegenerateStepCurve(expression); + return parameters.default === undefined ? expression : [ + 'case', + [ + '==', + [ + 'typeof', + get + ], + 'number' + ], + expression, + convertLiteral(parameters.default) + ]; + } else if (type === 'exponential') { + const base = parameters.base !== undefined ? parameters.base : 1; + const expression = [ + getInterpolateOperator(parameters), + base === 1 ? ['linear'] : [ + 'exponential', + base + ], + [ + 'number', + get + ] + ]; + for (const stop of stops) { + appendStopPair(expression, stop[0], stop[1], false); + } + return parameters.default === undefined ? expression : [ + 'case', + [ + '==', + [ + 'typeof', + get + ], + 'number' + ], + expression, + convertLiteral(parameters.default) + ]; + } else { + throw new Error(`Unknown property function type ${ type }`); + } +} +function convertZoomFunction(parameters, propertySpec, stops, input = ['zoom']) { + const type = getFunctionType(parameters, propertySpec); + let expression; + let isStep = false; + if (type === 'interval') { + expression = [ + 'step', + input + ]; + isStep = true; + } else if (type === 'exponential') { + const base = parameters.base !== undefined ? parameters.base : 1; + expression = [ + getInterpolateOperator(parameters), + base === 1 ? ['linear'] : [ + 'exponential', + base + ], + input + ]; + } else { + throw new Error(`Unknown zoom function type "${ type }"`); + } + for (const stop of stops) { + appendStopPair(expression, stop[0], stop[1], isStep); + } + fixupDegenerateStepCurve(expression); + return expression; +} +function fixupDegenerateStepCurve(expression) { + // degenerate step curve (i.e. a constant function): add a noop stop + if (expression[0] === 'step' && expression.length === 3) { + expression.push(0); + expression.push(expression[3]); + } +} +function appendStopPair(curve, input, output, isStep) { + // Skip duplicate stop values. They were not validated for functions, but they are for expressions. + // https://github.com/mapbox/mapbox-gl-js/issues/4107 + if (curve.length > 3 && input === curve[curve.length - 2]) { + return; + } + // step curves don't get the first input value, as it is redundant. + if (!(isStep && curve.length === 2)) { + curve.push(input); + } + curve.push(output); +} +function getFunctionType(parameters, propertySpec) { + if (parameters.type) { + return parameters.type; + } else { + return propertySpec.expression.interpolated ? 'exponential' : 'interval'; + } +} +// "String with {name} token" => ["concat", "String with ", ["get", "name"], " token"] +function convertTokenString(s) { + const result = ['concat']; + const re = /{([^{}]+)}/g; + let pos = 0; + for (let match = re.exec(s); match !== null; match = re.exec(s)) { + const literal = s.slice(pos, re.lastIndex - match[0].length); + pos = re.lastIndex; + if (literal.length > 0) + result.push(literal); + result.push([ + 'get', + match[1] + ]); + } + if (result.length === 1) { + return s; + } + if (pos < s.length) { + result.push(s.slice(pos)); + } else if (result.length === 2) { + return [ + 'to-string', + result[1] + ]; + } + return result; +} + +// +class ParsingError extends Error { + constructor(key, message) { + super(message); + this.message = message; + this.key = key; + } +} +var ParsingError$1 = ParsingError; + +// +/** + * Tracks `let` bindings during expression parsing. + * @private + */ +class Scope { + constructor(parent, bindings = []) { + this.parent = parent; + this.bindings = {}; + for (const [name, expression] of bindings) { + this.bindings[name] = expression; + } + } + concat(bindings) { + return new Scope(this, bindings); + } + get(name) { + if (this.bindings[name]) { + return this.bindings[name]; + } + if (this.parent) { + return this.parent.get(name); + } + throw new Error(`${ name } not found in scope.`); + } + has(name) { + if (this.bindings[name]) + return true; + return this.parent ? this.parent.has(name) : false; + } +} +var Scope$1 = Scope; + +// +const NullType = { kind: 'null' }; +const NumberType = { kind: 'number' }; +const StringType = { kind: 'string' }; +const BooleanType = { kind: 'boolean' }; +const ColorType = { kind: 'color' }; +const ObjectType = { kind: 'object' }; +const ValueType = { kind: 'value' }; +const ErrorType = { kind: 'error' }; +const CollatorType = { kind: 'collator' }; +const FormattedType = { kind: 'formatted' }; +const ResolvedImageType = { kind: 'resolvedImage' }; +function array$1(itemType, N) { + return { + kind: 'array', + itemType, + N + }; +} +function toString$1(type) { + if (type.kind === 'array') { + const itemType = toString$1(type.itemType); + return typeof type.N === 'number' ? `array<${ itemType }, ${ type.N }>` : type.itemType.kind === 'value' ? 'array' : `array<${ itemType }>`; + } else { + return type.kind; + } +} +const valueMemberTypes = [ + NullType, + NumberType, + StringType, + BooleanType, + ColorType, + FormattedType, + ObjectType, + array$1(ValueType), + ResolvedImageType +]; +/** + * Returns null if `t` is a subtype of `expected`; otherwise returns an + * error message. + * @private + */ +function checkSubtype(expected, t) { + if (t.kind === 'error') { + // Error is a subtype of every type + return null; + } else if (expected.kind === 'array') { + if (t.kind === 'array' && (t.N === 0 && t.itemType.kind === 'value' || !checkSubtype(expected.itemType, t.itemType)) && (typeof expected.N !== 'number' || expected.N === t.N)) { + return null; + } + } else if (expected.kind === t.kind) { + return null; + } else if (expected.kind === 'value') { + for (const memberType of valueMemberTypes) { + if (!checkSubtype(memberType, t)) { + return null; + } + } + } + return `Expected ${ toString$1(expected) } but found ${ toString$1(t) } instead.`; +} +function isValidType(provided, allowedTypes) { + return allowedTypes.some(t => t.kind === provided.kind); +} +function isValidNativeType(provided, allowedTypes) { + return allowedTypes.some(t => { + if (t === 'null') { + return provided === null; + } else if (t === 'array') { + return Array.isArray(provided); + } else if (t === 'object') { + return provided && !Array.isArray(provided) && typeof provided === 'object'; + } else { + return t === typeof provided; + } + }); +} + +// +// Flow type declarations for Intl cribbed from +// https://github.com/facebook/flow/issues/1270 +class Collator { + constructor(caseSensitive, diacriticSensitive, locale) { + if (caseSensitive) + this.sensitivity = diacriticSensitive ? 'variant' : 'case'; + else + this.sensitivity = diacriticSensitive ? 'accent' : 'base'; + this.locale = locale; + this.collator = new Intl.Collator(this.locale ? this.locale : [], { + sensitivity: this.sensitivity, + usage: 'search' + }); + } + compare(lhs, rhs) { + return this.collator.compare(lhs, rhs); + } + resolvedLocale() { + // We create a Collator without "usage: search" because we don't want + // the search options encoded in our result (e.g. "en-u-co-search") + return new Intl.Collator(this.locale ? this.locale : []).resolvedOptions().locale; + } +} + +// +class FormattedSection { + constructor(text, image, scale, fontStack, textColor) { + // combine characters so that diacritic marks are not separate code points + this.text = text.normalize ? text.normalize() : text; + this.image = image; + this.scale = scale; + this.fontStack = fontStack; + this.textColor = textColor; + } +} +class Formatted { + constructor(sections) { + this.sections = sections; + } + static fromString(unformatted) { + return new Formatted([new FormattedSection(unformatted, null, null, null, null)]); + } + isEmpty() { + if (this.sections.length === 0) + return true; + return !this.sections.some(section => section.text.length !== 0 || section.image && section.image.name.length !== 0); + } + static factory(text) { + if (text instanceof Formatted) { + return text; + } else { + return Formatted.fromString(text); + } + } + toString() { + if (this.sections.length === 0) + return ''; + return this.sections.map(section => section.text).join(''); + } + serialize() { + const serialized = ['format']; + for (const section of this.sections) { + if (section.image) { + serialized.push([ + 'image', + section.image.name + ]); + continue; + } + serialized.push(section.text); + const options = {}; + if (section.fontStack) { + options['text-font'] = [ + 'literal', + section.fontStack.split(',') + ]; + } + if (section.scale) { + options['font-scale'] = section.scale; + } + if (section.textColor) { + options['text-color'] = ['rgba'].concat(section.textColor.toArray()); + } + serialized.push(options); + } + return serialized; + } +} + +// +class ResolvedImage { + constructor(options) { + this.name = options.name; + this.available = options.available; + } + toString() { + return this.name; + } + static fromString(name) { + if (!name) + return null; + // treat empty values as no image + return new ResolvedImage({ + name, + available: false + }); + } + serialize() { + return [ + 'image', + this.name + ]; + } +} + +function validateRGBA(r, g, b, a) { + if (!(typeof r === 'number' && r >= 0 && r <= 255 && typeof g === 'number' && g >= 0 && g <= 255 && typeof b === 'number' && b >= 0 && b <= 255)) { + const value = typeof a === 'number' ? [ + r, + g, + b, + a + ] : [ + r, + g, + b + ]; + return `Invalid rgba value [${ value.join(', ') }]: 'r', 'g', and 'b' must be between 0 and 255.`; + } + if (!(typeof a === 'undefined' || typeof a === 'number' && a >= 0 && a <= 1)) { + return `Invalid rgba value [${ [ + r, + g, + b, + a + ].join(', ') }]: 'a' must be between 0 and 1.`; + } + return null; +} +function isValue(mixed) { + if (mixed === null) { + return true; + } else if (typeof mixed === 'string') { + return true; + } else if (typeof mixed === 'boolean') { + return true; + } else if (typeof mixed === 'number') { + return true; + } else if (mixed instanceof Color$1) { + return true; + } else if (mixed instanceof Collator) { + return true; + } else if (mixed instanceof Formatted) { + return true; + } else if (mixed instanceof ResolvedImage) { + return true; + } else if (Array.isArray(mixed)) { + for (const item of mixed) { + if (!isValue(item)) { + return false; + } + } + return true; + } else if (typeof mixed === 'object') { + for (const key in mixed) { + if (!isValue(mixed[key])) { + return false; + } + } + return true; + } else { + return false; + } +} +function typeOf(value) { + if (value === null) { + return NullType; + } else if (typeof value === 'string') { + return StringType; + } else if (typeof value === 'boolean') { + return BooleanType; + } else if (typeof value === 'number') { + return NumberType; + } else if (value instanceof Color$1) { + return ColorType; + } else if (value instanceof Collator) { + return CollatorType; + } else if (value instanceof Formatted) { + return FormattedType; + } else if (value instanceof ResolvedImage) { + return ResolvedImageType; + } else if (Array.isArray(value)) { + const length = value.length; + let itemType; + for (const item of value) { + const t = typeOf(item); + if (!itemType) { + itemType = t; + } else if (itemType === t) { + continue; + } else { + itemType = ValueType; + break; + } + } + return array$1(itemType || ValueType, length); + } else { + return ObjectType; + } +} +function toString(value) { + const type = typeof value; + if (value === null) { + return ''; + } else if (type === 'string' || type === 'number' || type === 'boolean') { + return String(value); + } else if (value instanceof Color$1 || value instanceof Formatted || value instanceof ResolvedImage) { + return value.toString(); + } else { + return JSON.stringify(value); + } +} + +class Literal { + constructor(type, value) { + this.type = type; + this.value = value; + } + static parse(args, context) { + if (args.length !== 2) + return context.error(`'literal' expression requires exactly one argument, but found ${ args.length - 1 } instead.`); + if (!isValue(args[1])) + return context.error(`invalid value`); + const value = args[1]; + let type = typeOf(value); + // special case: infer the item type if possible for zero-length arrays + const expected = context.expectedType; + if (type.kind === 'array' && type.N === 0 && expected && expected.kind === 'array' && (typeof expected.N !== 'number' || expected.N === 0)) { + type = expected; + } + return new Literal(type, value); + } + evaluate() { + return this.value; + } + eachChild() { + } + outputDefined() { + return true; + } + serialize() { + if (this.type.kind === 'array' || this.type.kind === 'object') { + return [ + 'literal', + this.value + ]; + } else if (this.value instanceof Color$1) { + // Constant-folding can generate Literal expressions that you + // couldn't actually generate with a "literal" expression, + // so we have to implement an equivalent serialization here + return ['rgba'].concat(this.value.toArray()); + } else if (this.value instanceof Formatted) { + // Same as Color + return this.value.serialize(); + } else { + return this.value; + } + } +} +var Literal$1 = Literal; + +// +class RuntimeError { + constructor(message) { + this.name = 'ExpressionEvaluationError'; + this.message = message; + } + toJSON() { + return this.message; + } +} +var RuntimeError$1 = RuntimeError; + +const types$2 = { + string: StringType, + number: NumberType, + boolean: BooleanType, + object: ObjectType +}; +class Assertion { + constructor(type, args) { + this.type = type; + this.args = args; + } + static parse(args, context) { + if (args.length < 2) + return context.error(`Expected at least one argument.`); + let i = 1; + let type; + const name = args[0]; + if (name === 'array') { + let itemType; + if (args.length > 2) { + const type = args[1]; + if (typeof type !== 'string' || !(type in types$2) || type === 'object') + return context.error('The item type argument of "array" must be one of string, number, boolean', 1); + itemType = types$2[type]; + i++; + } else { + itemType = ValueType; + } + let N; + if (args.length > 3) { + if (args[2] !== null && (typeof args[2] !== 'number' || args[2] < 0 || args[2] !== Math.floor(args[2]))) { + return context.error('The length argument to "array" must be a positive integer literal', 2); + } + N = args[2]; + i++; + } + type = array$1(itemType, N); + } else { + type = types$2[name]; + } + const parsed = []; + for (; i < args.length; i++) { + const input = context.parse(args[i], i, ValueType); + if (!input) + return null; + parsed.push(input); + } + return new Assertion(type, parsed); + } + evaluate(ctx) { + for (let i = 0; i < this.args.length; i++) { + const value = this.args[i].evaluate(ctx); + const error = checkSubtype(this.type, typeOf(value)); + if (!error) { + return value; + } else if (i === this.args.length - 1) { + throw new RuntimeError$1(`Expected value to be of type ${ toString$1(this.type) }, but found ${ toString$1(typeOf(value)) } instead.`); + } + } + return null; + } + eachChild(fn) { + this.args.forEach(fn); + } + outputDefined() { + return this.args.every(arg => arg.outputDefined()); + } + serialize() { + const type = this.type; + const serialized = [type.kind]; + if (type.kind === 'array') { + const itemType = type.itemType; + if (itemType.kind === 'string' || itemType.kind === 'number' || itemType.kind === 'boolean') { + serialized.push(itemType.kind); + const N = type.N; + if (typeof N === 'number' || this.args.length > 1) { + serialized.push(N); + } + } + } + return serialized.concat(this.args.map(arg => arg.serialize())); + } +} +var Assertion$1 = Assertion; + +// +class FormatExpression { + constructor(sections) { + this.type = FormattedType; + this.sections = sections; + } + static parse(args, context) { + if (args.length < 2) { + return context.error(`Expected at least one argument.`); + } + const firstArg = args[1]; + if (!Array.isArray(firstArg) && typeof firstArg === 'object') { + return context.error(`First argument must be an image or text section.`); + } + const sections = []; + let nextTokenMayBeObject = false; + for (let i = 1; i <= args.length - 1; ++i) { + const arg = args[i]; + if (nextTokenMayBeObject && typeof arg === 'object' && !Array.isArray(arg)) { + nextTokenMayBeObject = false; + let scale = null; + if (arg['font-scale']) { + scale = context.parse(arg['font-scale'], 1, NumberType); + if (!scale) + return null; + } + let font = null; + if (arg['text-font']) { + font = context.parse(arg['text-font'], 1, array$1(StringType)); + if (!font) + return null; + } + let textColor = null; + if (arg['text-color']) { + textColor = context.parse(arg['text-color'], 1, ColorType); + if (!textColor) + return null; + } + const lastExpression = sections[sections.length - 1]; + lastExpression.scale = scale; + lastExpression.font = font; + lastExpression.textColor = textColor; + } else { + const content = context.parse(args[i], 1, ValueType); + if (!content) + return null; + const kind = content.type.kind; + if (kind !== 'string' && kind !== 'value' && kind !== 'null' && kind !== 'resolvedImage') + return context.error(`Formatted text type must be 'string', 'value', 'image' or 'null'.`); + nextTokenMayBeObject = true; + sections.push({ + content, + scale: null, + font: null, + textColor: null + }); + } + } + return new FormatExpression(sections); + } + evaluate(ctx) { + const evaluateSection = section => { + const evaluatedContent = section.content.evaluate(ctx); + if (typeOf(evaluatedContent) === ResolvedImageType) { + return new FormattedSection('', evaluatedContent, null, null, null); + } + return new FormattedSection(toString(evaluatedContent), null, section.scale ? section.scale.evaluate(ctx) : null, section.font ? section.font.evaluate(ctx).join(',') : null, section.textColor ? section.textColor.evaluate(ctx) : null); + }; + return new Formatted(this.sections.map(evaluateSection)); + } + eachChild(fn) { + for (const section of this.sections) { + fn(section.content); + if (section.scale) { + fn(section.scale); + } + if (section.font) { + fn(section.font); + } + if (section.textColor) { + fn(section.textColor); + } + } + } + outputDefined() { + // Technically the combinatoric set of all children + // Usually, this.text will be undefined anyway + return false; + } + serialize() { + const serialized = ['format']; + for (const section of this.sections) { + serialized.push(section.content.serialize()); + const options = {}; + if (section.scale) { + options['font-scale'] = section.scale.serialize(); + } + if (section.font) { + options['text-font'] = section.font.serialize(); + } + if (section.textColor) { + options['text-color'] = section.textColor.serialize(); + } + serialized.push(options); + } + return serialized; + } +} + +// +class ImageExpression { + constructor(input) { + this.type = ResolvedImageType; + this.input = input; + } + static parse(args, context) { + if (args.length !== 2) { + return context.error(`Expected two arguments.`); + } + const name = context.parse(args[1], 1, StringType); + if (!name) + return context.error(`No image name provided.`); + return new ImageExpression(name); + } + evaluate(ctx) { + const evaluatedImageName = this.input.evaluate(ctx); + const value = ResolvedImage.fromString(evaluatedImageName); + if (value && ctx.availableImages) + value.available = ctx.availableImages.indexOf(evaluatedImageName) > -1; + return value; + } + eachChild(fn) { + fn(this.input); + } + outputDefined() { + // The output of image is determined by the list of available images in the evaluation context + return false; + } + serialize() { + return [ + 'image', + this.input.serialize() + ]; + } +} + +const types$1 = { + 'to-boolean': BooleanType, + 'to-color': ColorType, + 'to-number': NumberType, + 'to-string': StringType +}; +/** + * Special form for error-coalescing coercion expressions "to-number", + * "to-color". Since these coercions can fail at runtime, they accept multiple + * arguments, only evaluating one at a time until one succeeds. + * + * @private + */ +class Coercion { + constructor(type, args) { + this.type = type; + this.args = args; + } + static parse(args, context) { + if (args.length < 2) + return context.error(`Expected at least one argument.`); + const name = args[0]; + if ((name === 'to-boolean' || name === 'to-string') && args.length !== 2) + return context.error(`Expected one argument.`); + const type = types$1[name]; + const parsed = []; + for (let i = 1; i < args.length; i++) { + const input = context.parse(args[i], i, ValueType); + if (!input) + return null; + parsed.push(input); + } + return new Coercion(type, parsed); + } + evaluate(ctx) { + if (this.type.kind === 'boolean') { + return Boolean(this.args[0].evaluate(ctx)); + } else if (this.type.kind === 'color') { + let input; + let error; + for (const arg of this.args) { + input = arg.evaluate(ctx); + error = null; + if (input instanceof Color$1) { + return input; + } else if (typeof input === 'string') { + const c = ctx.parseColor(input); + if (c) + return c; + } else if (Array.isArray(input)) { + if (input.length < 3 || input.length > 4) { + error = `Invalid rbga value ${ JSON.stringify(input) }: expected an array containing either three or four numeric values.`; + } else { + error = validateRGBA(input[0], input[1], input[2], input[3]); + } + if (!error) { + return new Color$1(input[0] / 255, input[1] / 255, input[2] / 255, input[3]); + } + } + } + throw new RuntimeError$1(error || `Could not parse color from value '${ typeof input === 'string' ? input : String(JSON.stringify(input)) }'`); + } else if (this.type.kind === 'number') { + let value = null; + for (const arg of this.args) { + value = arg.evaluate(ctx); + if (value === null) + return 0; + const num = Number(value); + if (isNaN(num)) + continue; + return num; + } + throw new RuntimeError$1(`Could not convert ${ JSON.stringify(value) } to number.`); + } else if (this.type.kind === 'formatted') { + // There is no explicit 'to-formatted' but this coercion can be implicitly + // created by properties that expect the 'formatted' type. + return Formatted.fromString(toString(this.args[0].evaluate(ctx))); + } else if (this.type.kind === 'resolvedImage') { + return ResolvedImage.fromString(toString(this.args[0].evaluate(ctx))); + } else { + return toString(this.args[0].evaluate(ctx)); + } + } + eachChild(fn) { + this.args.forEach(fn); + } + outputDefined() { + return this.args.every(arg => arg.outputDefined()); + } + serialize() { + if (this.type.kind === 'formatted') { + return new FormatExpression([{ + content: this.args[0], + scale: null, + font: null, + textColor: null + }]).serialize(); + } + if (this.type.kind === 'resolvedImage') { + return new ImageExpression(this.args[0]).serialize(); + } + const serialized = [`to-${ this.type.kind }`]; + this.eachChild(child => { + serialized.push(child.serialize()); + }); + return serialized; + } +} +var Coercion$1 = Coercion; + +// +const geometryTypes = [ + 'Unknown', + 'Point', + 'LineString', + 'Polygon' +]; +class EvaluationContext { + constructor() { + this.globals = null; + this.feature = null; + this.featureState = null; + this.formattedSection = null; + this._parseColorCache = {}; + this.availableImages = null; + this.canonical = null; + this.featureTileCoord = null; + this.featureDistanceData = null; + } + id() { + return this.feature && this.feature.id !== undefined ? this.feature.id : null; + } + geometryType() { + return this.feature ? typeof this.feature.type === 'number' ? geometryTypes[this.feature.type] : this.feature.type : null; + } + geometry() { + return this.feature && 'geometry' in this.feature ? this.feature.geometry : null; + } + canonicalID() { + return this.canonical; + } + properties() { + return this.feature && this.feature.properties || {}; + } + distanceFromCenter() { + if (this.featureTileCoord && this.featureDistanceData) { + const c = this.featureDistanceData.center; + const scale = this.featureDistanceData.scale; + const {x, y} = this.featureTileCoord; + // Calculate the distance vector `d` (left handed) + const dX = x * scale - c[0]; + const dY = y * scale - c[1]; + // The bearing vector `b` (left handed) + const bX = this.featureDistanceData.bearing[0]; + const bY = this.featureDistanceData.bearing[1]; + // Distance is calculated as `dot(d, v)` + const dist = bX * dX + bY * dY; + return dist; + } + return 0; + } + parseColor(input) { + let cached = this._parseColorCache[input]; + if (!cached) { + cached = this._parseColorCache[input] = Color$1.parse(input); + } + return cached; + } +} +var EvaluationContext$1 = EvaluationContext; + +// +class CompoundExpression { + constructor(name, type, evaluate, args) { + this.name = name; + this.type = type; + this._evaluate = evaluate; + this.args = args; + } + evaluate(ctx) { + return this._evaluate(ctx, this.args); + } + eachChild(fn) { + this.args.forEach(fn); + } + outputDefined() { + return false; + } + serialize() { + return [this.name].concat(this.args.map(arg => arg.serialize())); + } + static parse(args, context) { + const op = args[0]; + const definition = CompoundExpression.definitions[op]; + if (!definition) { + return context.error(`Unknown expression "${ op }". If you wanted a literal array, use ["literal", [...]].`, 0); + } + // Now check argument types against each signature + const type = Array.isArray(definition) ? definition[0] : definition.type; + const availableOverloads = Array.isArray(definition) ? [[ + definition[1], + definition[2] + ]] : definition.overloads; + const overloads = availableOverloads.filter(([signature]) => !Array.isArray(signature) || // varags + signature.length === args.length - 1 // correct param count +); + let signatureContext = null; + for (const [params, evaluate] of overloads) { + // Use a fresh context for each attempted signature so that, if + // we eventually succeed, we haven't polluted `context.errors`. + signatureContext = new ParsingContext$1(context.registry, context.path, null, context.scope); + // First parse all the args, potentially coercing to the + // types expected by this overload. + const parsedArgs = []; + let argParseFailed = false; + for (let i = 1; i < args.length; i++) { + const arg = args[i]; + const expectedType = Array.isArray(params) ? params[i - 1] : params.type; + const parsed = signatureContext.parse(arg, 1 + parsedArgs.length, expectedType); + if (!parsed) { + argParseFailed = true; + break; + } + parsedArgs.push(parsed); + } + if (argParseFailed) { + // Couldn't coerce args of this overload to expected type, move + // on to next one. + continue; + } + if (Array.isArray(params)) { + if (params.length !== parsedArgs.length) { + signatureContext.error(`Expected ${ params.length } arguments, but found ${ parsedArgs.length } instead.`); + continue; + } + } + for (let i = 0; i < parsedArgs.length; i++) { + const expected = Array.isArray(params) ? params[i] : params.type; + const arg = parsedArgs[i]; + signatureContext.concat(i + 1).checkSubtype(expected, arg.type); + } + if (signatureContext.errors.length === 0) { + return new CompoundExpression(op, type, evaluate, parsedArgs); + } + } + if (overloads.length === 1) { + context.errors.push(...signatureContext.errors); + } else { + const expected = overloads.length ? overloads : availableOverloads; + const signatures = expected.map(([params]) => stringifySignature(params)).join(' | '); + const actualTypes = []; + // For error message, re-parse arguments without trying to + // apply any coercions + for (let i = 1; i < args.length; i++) { + const parsed = context.parse(args[i], 1 + actualTypes.length); + if (!parsed) + return null; + actualTypes.push(toString$1(parsed.type)); + } + context.error(`Expected arguments of type ${ signatures }, but found (${ actualTypes.join(', ') }) instead.`); + } + return null; + } + static register(registry, definitions) { + CompoundExpression.definitions = definitions; + for (const name in definitions) { + registry[name] = CompoundExpression; + } + } +} +function stringifySignature(signature) { + if (Array.isArray(signature)) { + return `(${ signature.map(toString$1).join(', ') })`; + } else { + return `(${ toString$1(signature.type) }...)`; + } +} +var CompoundExpression$1 = CompoundExpression; + +// +class CollatorExpression { + constructor(caseSensitive, diacriticSensitive, locale) { + this.type = CollatorType; + this.locale = locale; + this.caseSensitive = caseSensitive; + this.diacriticSensitive = diacriticSensitive; + } + static parse(args, context) { + if (args.length !== 2) + return context.error(`Expected one argument.`); + const options = args[1]; + if (typeof options !== 'object' || Array.isArray(options)) + return context.error(`Collator options argument must be an object.`); + const caseSensitive = context.parse(options['case-sensitive'] === undefined ? false : options['case-sensitive'], 1, BooleanType); + if (!caseSensitive) + return null; + const diacriticSensitive = context.parse(options['diacritic-sensitive'] === undefined ? false : options['diacritic-sensitive'], 1, BooleanType); + if (!diacriticSensitive) + return null; + let locale = null; + if (options['locale']) { + locale = context.parse(options['locale'], 1, StringType); + if (!locale) + return null; + } + return new CollatorExpression(caseSensitive, diacriticSensitive, locale); + } + evaluate(ctx) { + return new Collator(this.caseSensitive.evaluate(ctx), this.diacriticSensitive.evaluate(ctx), this.locale ? this.locale.evaluate(ctx) : null); + } + eachChild(fn) { + fn(this.caseSensitive); + fn(this.diacriticSensitive); + if (this.locale) { + fn(this.locale); + } + } + outputDefined() { + // Technically the set of possible outputs is the combinatoric set of Collators produced + // by all possible outputs of locale/caseSensitive/diacriticSensitive + // But for the primary use of Collators in comparison operators, we ignore the Collator's + // possible outputs anyway, so we can get away with leaving this false for now. + return false; + } + serialize() { + const options = {}; + options['case-sensitive'] = this.caseSensitive.serialize(); + options['diacritic-sensitive'] = this.diacriticSensitive.serialize(); + if (this.locale) { + options['locale'] = this.locale.serialize(); + } + return [ + 'collator', + options + ]; + } +} + +// +// minX, minY, maxX, maxY +const EXTENT = 8192; +function updateBBox(bbox, coord) { + bbox[0] = Math.min(bbox[0], coord[0]); + bbox[1] = Math.min(bbox[1], coord[1]); + bbox[2] = Math.max(bbox[2], coord[0]); + bbox[3] = Math.max(bbox[3], coord[1]); +} +function mercatorXfromLng(lng) { + return (180 + lng) / 360; +} +function mercatorYfromLat(lat) { + return (180 - 180 / Math.PI * Math.log(Math.tan(Math.PI / 4 + lat * Math.PI / 360))) / 360; +} +function boxWithinBox(bbox1, bbox2) { + if (bbox1[0] <= bbox2[0]) + return false; + if (bbox1[2] >= bbox2[2]) + return false; + if (bbox1[1] <= bbox2[1]) + return false; + if (bbox1[3] >= bbox2[3]) + return false; + return true; +} +function getTileCoordinates(p, canonical) { + const x = mercatorXfromLng(p[0]); + const y = mercatorYfromLat(p[1]); + const tilesAtZoom = Math.pow(2, canonical.z); + return [ + Math.round(x * tilesAtZoom * EXTENT), + Math.round(y * tilesAtZoom * EXTENT) + ]; +} +function onBoundary(p, p1, p2) { + const x1 = p[0] - p1[0]; + const y1 = p[1] - p1[1]; + const x2 = p[0] - p2[0]; + const y2 = p[1] - p2[1]; + return x1 * y2 - x2 * y1 === 0 && x1 * x2 <= 0 && y1 * y2 <= 0; +} +function rayIntersect(p, p1, p2) { + return p1[1] > p[1] !== p2[1] > p[1] && p[0] < (p2[0] - p1[0]) * (p[1] - p1[1]) / (p2[1] - p1[1]) + p1[0]; +} +// ray casting algorithm for detecting if point is in polygon +function pointWithinPolygon(point, rings) { + let inside = false; + for (let i = 0, len = rings.length; i < len; i++) { + const ring = rings[i]; + for (let j = 0, len2 = ring.length; j < len2 - 1; j++) { + if (onBoundary(point, ring[j], ring[j + 1])) + return false; + if (rayIntersect(point, ring[j], ring[j + 1])) + inside = !inside; + } + } + return inside; +} +function pointWithinPolygons(point, polygons) { + for (let i = 0; i < polygons.length; i++) { + if (pointWithinPolygon(point, polygons[i])) + return true; + } + return false; +} +function perp(v1, v2) { + return v1[0] * v2[1] - v1[1] * v2[0]; +} +// check if p1 and p2 are in different sides of line segment q1->q2 +function twoSided(p1, p2, q1, q2) { + // q1->p1 (x1, y1), q1->p2 (x2, y2), q1->q2 (x3, y3) + const x1 = p1[0] - q1[0]; + const y1 = p1[1] - q1[1]; + const x2 = p2[0] - q1[0]; + const y2 = p2[1] - q1[1]; + const x3 = q2[0] - q1[0]; + const y3 = q2[1] - q1[1]; + const det1 = x1 * y3 - x3 * y1; + const det2 = x2 * y3 - x3 * y2; + if (det1 > 0 && det2 < 0 || det1 < 0 && det2 > 0) + return true; + return false; +} +// a, b are end points for line segment1, c and d are end points for line segment2 +function lineIntersectLine(a, b, c, d) { + // check if two segments are parallel or not + // precondition is end point a, b is inside polygon, if line a->b is + // parallel to polygon edge c->d, then a->b won't intersect with c->d + const vectorP = [ + b[0] - a[0], + b[1] - a[1] + ]; + const vectorQ = [ + d[0] - c[0], + d[1] - c[1] + ]; + if (perp(vectorQ, vectorP) === 0) + return false; + // If lines are intersecting with each other, the relative location should be: + // a and b lie in different sides of segment c->d + // c and d lie in different sides of segment a->b + if (twoSided(a, b, c, d) && twoSided(c, d, a, b)) + return true; + return false; +} +function lineIntersectPolygon(p1, p2, polygon) { + for (const ring of polygon) { + // loop through every edge of the ring + for (let j = 0; j < ring.length - 1; ++j) { + if (lineIntersectLine(p1, p2, ring[j], ring[j + 1])) { + return true; + } + } + } + return false; +} +function lineStringWithinPolygon(line, polygon) { + // First, check if geometry points of line segments are all inside polygon + for (let i = 0; i < line.length; ++i) { + if (!pointWithinPolygon(line[i], polygon)) { + return false; + } + } + // Second, check if there is line segment intersecting polygon edge + for (let i = 0; i < line.length - 1; ++i) { + if (lineIntersectPolygon(line[i], line[i + 1], polygon)) { + return false; + } + } + return true; +} +function lineStringWithinPolygons(line, polygons) { + for (let i = 0; i < polygons.length; i++) { + if (lineStringWithinPolygon(line, polygons[i])) + return true; + } + return false; +} +function getTilePolygon(coordinates, bbox, canonical) { + const polygon = []; + for (let i = 0; i < coordinates.length; i++) { + const ring = []; + for (let j = 0; j < coordinates[i].length; j++) { + const coord = getTileCoordinates(coordinates[i][j], canonical); + updateBBox(bbox, coord); + ring.push(coord); + } + polygon.push(ring); + } + return polygon; +} +function getTilePolygons(coordinates, bbox, canonical) { + const polygons = []; + for (let i = 0; i < coordinates.length; i++) { + const polygon = getTilePolygon(coordinates[i], bbox, canonical); + polygons.push(polygon); + } + return polygons; +} +function updatePoint(p, bbox, polyBBox, worldSize) { + if (p[0] < polyBBox[0] || p[0] > polyBBox[2]) { + const halfWorldSize = worldSize * 0.5; + let shift = p[0] - polyBBox[0] > halfWorldSize ? -worldSize : polyBBox[0] - p[0] > halfWorldSize ? worldSize : 0; + if (shift === 0) { + shift = p[0] - polyBBox[2] > halfWorldSize ? -worldSize : polyBBox[2] - p[0] > halfWorldSize ? worldSize : 0; + } + p[0] += shift; + } + updateBBox(bbox, p); +} +function resetBBox(bbox) { + bbox[0] = bbox[1] = Infinity; + bbox[2] = bbox[3] = -Infinity; +} +function getTilePoints(geometry, pointBBox, polyBBox, canonical) { + const worldSize = Math.pow(2, canonical.z) * EXTENT; + const shifts = [ + canonical.x * EXTENT, + canonical.y * EXTENT + ]; + const tilePoints = []; + if (!geometry) + return tilePoints; + for (const points of geometry) { + for (const point of points) { + const p = [ + point.x + shifts[0], + point.y + shifts[1] + ]; + updatePoint(p, pointBBox, polyBBox, worldSize); + tilePoints.push(p); + } + } + return tilePoints; +} +function getTileLines(geometry, lineBBox, polyBBox, canonical) { + const worldSize = Math.pow(2, canonical.z) * EXTENT; + const shifts = [ + canonical.x * EXTENT, + canonical.y * EXTENT + ]; + const tileLines = []; + if (!geometry) + return tileLines; + for (const line of geometry) { + const tileLine = []; + for (const point of line) { + const p = [ + point.x + shifts[0], + point.y + shifts[1] + ]; + updateBBox(lineBBox, p); + tileLine.push(p); + } + tileLines.push(tileLine); + } + if (lineBBox[2] - lineBBox[0] <= worldSize / 2) { + resetBBox(lineBBox); + for (const line of tileLines) { + for (const p of line) { + updatePoint(p, lineBBox, polyBBox, worldSize); + } + } + } + return tileLines; +} +function pointsWithinPolygons(ctx, polygonGeometry) { + const pointBBox = [ + Infinity, + Infinity, + -Infinity, + -Infinity + ]; + const polyBBox = [ + Infinity, + Infinity, + -Infinity, + -Infinity + ]; + const canonical = ctx.canonicalID(); + if (!canonical) { + return false; + } + if (polygonGeometry.type === 'Polygon') { + const tilePolygon = getTilePolygon(polygonGeometry.coordinates, polyBBox, canonical); + const tilePoints = getTilePoints(ctx.geometry(), pointBBox, polyBBox, canonical); + if (!boxWithinBox(pointBBox, polyBBox)) + return false; + for (const point of tilePoints) { + if (!pointWithinPolygon(point, tilePolygon)) + return false; + } + } + if (polygonGeometry.type === 'MultiPolygon') { + const tilePolygons = getTilePolygons(polygonGeometry.coordinates, polyBBox, canonical); + const tilePoints = getTilePoints(ctx.geometry(), pointBBox, polyBBox, canonical); + if (!boxWithinBox(pointBBox, polyBBox)) + return false; + for (const point of tilePoints) { + if (!pointWithinPolygons(point, tilePolygons)) + return false; + } + } + return true; +} +function linesWithinPolygons(ctx, polygonGeometry) { + const lineBBox = [ + Infinity, + Infinity, + -Infinity, + -Infinity + ]; + const polyBBox = [ + Infinity, + Infinity, + -Infinity, + -Infinity + ]; + const canonical = ctx.canonicalID(); + if (!canonical) { + return false; + } + if (polygonGeometry.type === 'Polygon') { + const tilePolygon = getTilePolygon(polygonGeometry.coordinates, polyBBox, canonical); + const tileLines = getTileLines(ctx.geometry(), lineBBox, polyBBox, canonical); + if (!boxWithinBox(lineBBox, polyBBox)) + return false; + for (const line of tileLines) { + if (!lineStringWithinPolygon(line, tilePolygon)) + return false; + } + } + if (polygonGeometry.type === 'MultiPolygon') { + const tilePolygons = getTilePolygons(polygonGeometry.coordinates, polyBBox, canonical); + const tileLines = getTileLines(ctx.geometry(), lineBBox, polyBBox, canonical); + if (!boxWithinBox(lineBBox, polyBBox)) + return false; + for (const line of tileLines) { + if (!lineStringWithinPolygons(line, tilePolygons)) + return false; + } + } + return true; +} +class Within { + constructor(geojson, geometries) { + this.type = BooleanType; + this.geojson = geojson; + this.geometries = geometries; + } + static parse(args, context) { + if (args.length !== 2) + return context.error(`'within' expression requires exactly one argument, but found ${ args.length - 1 } instead.`); + if (isValue(args[1])) { + const geojson = args[1]; + if (geojson.type === 'FeatureCollection') { + for (let i = 0; i < geojson.features.length; ++i) { + const type = geojson.features[i].geometry.type; + if (type === 'Polygon' || type === 'MultiPolygon') { + return new Within(geojson, geojson.features[i].geometry); + } + } + } else if (geojson.type === 'Feature') { + const type = geojson.geometry.type; + if (type === 'Polygon' || type === 'MultiPolygon') { + return new Within(geojson, geojson.geometry); + } + } else if (geojson.type === 'Polygon' || geojson.type === 'MultiPolygon') { + return new Within(geojson, geojson); + } + } + return context.error(`'within' expression requires valid geojson object that contains polygon geometry type.`); + } + evaluate(ctx) { + if (ctx.geometry() != null && ctx.canonicalID() != null) { + if (ctx.geometryType() === 'Point') { + return pointsWithinPolygons(ctx, this.geometries); + } else if (ctx.geometryType() === 'LineString') { + return linesWithinPolygons(ctx, this.geometries); + } + } + return false; + } + eachChild() { + } + outputDefined() { + return true; + } + serialize() { + return [ + 'within', + this.geojson + ]; + } +} +var Within$1 = Within; + +// +function isFeatureConstant(e) { + if (e instanceof CompoundExpression$1) { + if (e.name === 'get' && e.args.length === 1) { + return false; + } else if (e.name === 'feature-state') { + return false; + } else if (e.name === 'has' && e.args.length === 1) { + return false; + } else if (e.name === 'properties' || e.name === 'geometry-type' || e.name === 'id') { + return false; + } else if (/^filter-/.test(e.name)) { + return false; + } + } + if (e instanceof Within$1) { + return false; + } + let result = true; + e.eachChild(arg => { + if (result && !isFeatureConstant(arg)) { + result = false; + } + }); + return result; +} +function isStateConstant(e) { + if (e instanceof CompoundExpression$1) { + if (e.name === 'feature-state') { + return false; + } + } + let result = true; + e.eachChild(arg => { + if (result && !isStateConstant(arg)) { + result = false; + } + }); + return result; +} +function isGlobalPropertyConstant(e, properties) { + if (e instanceof CompoundExpression$1 && properties.indexOf(e.name) >= 0) { + return false; + } + let result = true; + e.eachChild(arg => { + if (result && !isGlobalPropertyConstant(arg, properties)) { + result = false; + } + }); + return result; +} + +// +class Var { + constructor(name, boundExpression) { + this.type = boundExpression.type; + this.name = name; + this.boundExpression = boundExpression; + } + static parse(args, context) { + if (args.length !== 2 || typeof args[1] !== 'string') + return context.error(`'var' expression requires exactly one string literal argument.`); + const name = args[1]; + if (!context.scope.has(name)) { + return context.error(`Unknown variable "${ name }". Make sure "${ name }" has been bound in an enclosing "let" expression before using it.`, 1); + } + return new Var(name, context.scope.get(name)); + } + evaluate(ctx) { + return this.boundExpression.evaluate(ctx); + } + eachChild() { + } + outputDefined() { + return false; + } + serialize() { + return [ + 'var', + this.name + ]; + } +} +var Var$1 = Var; + +// +/** + * State associated parsing at a given point in an expression tree. + * @private + */ +class ParsingContext { + // The expected type of this expression. Provided only to allow Expression + // implementations to infer argument types: Expression#parse() need not + // check that the output type of the parsed expression matches + // `expectedType`. + constructor(registry, path = [], expectedType, scope = new Scope$1(), errors = []) { + this.registry = registry; + this.path = path; + this.key = path.map(part => `[${ part }]`).join(''); + this.scope = scope; + this.errors = errors; + this.expectedType = expectedType; + } + /** + * @param expr the JSON expression to parse + * @param index the optional argument index if this expression is an argument of a parent expression that's being parsed + * @param options + * @param options.omitTypeAnnotations set true to omit inferred type annotations. Caller beware: with this option set, the parsed expression's type will NOT satisfy `expectedType` if it would normally be wrapped in an inferred annotation. + * @private + */ + parse(expr, index, expectedType, bindings, options = {}) { + if (index) { + return this.concat(index, expectedType, bindings)._parse(expr, options); + } + return this._parse(expr, options); + } + _parse(expr, options) { + if (expr === null || typeof expr === 'string' || typeof expr === 'boolean' || typeof expr === 'number') { + expr = [ + 'literal', + expr + ]; + } + function annotate(parsed, type, typeAnnotation) { + if (typeAnnotation === 'assert') { + return new Assertion$1(type, [parsed]); + } else if (typeAnnotation === 'coerce') { + return new Coercion$1(type, [parsed]); + } else { + return parsed; + } + } + if (Array.isArray(expr)) { + if (expr.length === 0) { + return this.error(`Expected an array with at least one element. If you wanted a literal array, use ["literal", []].`); + } + const op = expr[0]; + if (typeof op !== 'string') { + this.error(`Expression name must be a string, but found ${ typeof op } instead. If you wanted a literal array, use ["literal", [...]].`, 0); + return null; + } + const Expr = this.registry[op]; + if (Expr) { + let parsed = Expr.parse(expr, this); + if (!parsed) + return null; + if (this.expectedType) { + const expected = this.expectedType; + const actual = parsed.type; + // When we expect a number, string, boolean, or array but have a value, wrap it in an assertion. + // When we expect a color or formatted string, but have a string or value, wrap it in a coercion. + // Otherwise, we do static type-checking. + // + // These behaviors are overridable for: + // * The "coalesce" operator, which needs to omit type annotations. + // * String-valued properties (e.g. `text-field`), where coercion is more convenient than assertion. + // + if ((expected.kind === 'string' || expected.kind === 'number' || expected.kind === 'boolean' || expected.kind === 'object' || expected.kind === 'array') && actual.kind === 'value') { + parsed = annotate(parsed, expected, options.typeAnnotation || 'assert'); + } else if ((expected.kind === 'color' || expected.kind === 'formatted' || expected.kind === 'resolvedImage') && (actual.kind === 'value' || actual.kind === 'string')) { + parsed = annotate(parsed, expected, options.typeAnnotation || 'coerce'); + } else if (this.checkSubtype(expected, actual)) { + return null; + } + } + // If an expression's arguments are all literals, we can evaluate + // it immediately and replace it with a literal value in the + // parsed/compiled result. Expressions that expect an image should + // not be resolved here so we can later get the available images. + if (!(parsed instanceof Literal$1) && parsed.type.kind !== 'resolvedImage' && isConstant(parsed)) { + const ec = new EvaluationContext$1(); + try { + parsed = new Literal$1(parsed.type, parsed.evaluate(ec)); + } catch (e) { + this.error(e.message); + return null; + } + } + return parsed; + } + return this.error(`Unknown expression "${ op }". If you wanted a literal array, use ["literal", [...]].`, 0); + } else if (typeof expr === 'undefined') { + return this.error(`'undefined' value invalid. Use null instead.`); + } else if (typeof expr === 'object') { + return this.error(`Bare objects invalid. Use ["literal", {...}] instead.`); + } else { + return this.error(`Expected an array, but found ${ typeof expr } instead.`); + } + } + /** + * Returns a copy of this context suitable for parsing the subexpression at + * index `index`, optionally appending to 'let' binding map. + * + * Note that `errors` property, intended for collecting errors while + * parsing, is copied by reference rather than cloned. + * @private + */ + concat(index, expectedType, bindings) { + const path = typeof index === 'number' ? this.path.concat(index) : this.path; + const scope = bindings ? this.scope.concat(bindings) : this.scope; + return new ParsingContext(this.registry, path, expectedType || null, scope, this.errors); + } + /** + * Push a parsing (or type checking) error into the `this.errors` + * @param error The message + * @param keys Optionally specify the source of the error at a child + * of the current expression at `this.key`. + * @private + */ + error(error, ...keys) { + const key = `${ this.key }${ keys.map(k => `[${ k }]`).join('') }`; + this.errors.push(new ParsingError$1(key, error)); + } + /** + * Returns null if `t` is a subtype of `expected`; otherwise returns an + * error message and also pushes it to `this.errors`. + */ + checkSubtype(expected, t) { + const error = checkSubtype(expected, t); + if (error) + this.error(error); + return error; + } +} +var ParsingContext$1 = ParsingContext; +function isConstant(expression) { + if (expression instanceof Var$1) { + return isConstant(expression.boundExpression); + } else if (expression instanceof CompoundExpression$1 && expression.name === 'error') { + return false; + } else if (expression instanceof CollatorExpression) { + // Although the results of a Collator expression with fixed arguments + // generally shouldn't change between executions, we can't serialize them + // as constant expressions because results change based on environment. + return false; + } else if (expression instanceof Within$1) { + return false; + } + const isTypeAnnotation = expression instanceof Coercion$1 || expression instanceof Assertion$1; + let childrenConstant = true; + expression.eachChild(child => { + // We can _almost_ assume that if `expressions` children are constant, + // they would already have been evaluated to Literal values when they + // were parsed. Type annotations are the exception, because they might + // have been inferred and added after a child was parsed. + // So we recurse into isConstant() for the children of type annotations, + // but otherwise simply check whether they are Literals. + if (isTypeAnnotation) { + childrenConstant = childrenConstant && isConstant(child); + } else { + childrenConstant = childrenConstant && child instanceof Literal$1; + } + }); + if (!childrenConstant) { + return false; + } + return isFeatureConstant(expression) && isGlobalPropertyConstant(expression, [ + 'zoom', + 'heatmap-density', + 'line-progress', + 'sky-radial-progress', + 'accumulated', + 'is-supported-script', + 'pitch', + 'distance-from-center' + ]); +} + +// +/** + * Returns the index of the last stop <= input, or 0 if it doesn't exist. + * @private + */ +function findStopLessThanOrEqualTo(stops, input) { + const lastIndex = stops.length - 1; + let lowerIndex = 0; + let upperIndex = lastIndex; + let currentIndex = 0; + let currentValue, nextValue; + while (lowerIndex <= upperIndex) { + currentIndex = Math.floor((lowerIndex + upperIndex) / 2); + currentValue = stops[currentIndex]; + nextValue = stops[currentIndex + 1]; + if (currentValue <= input) { + if (currentIndex === lastIndex || input < nextValue) { + // Search complete + return currentIndex; + } + lowerIndex = currentIndex + 1; + } else if (currentValue > input) { + upperIndex = currentIndex - 1; + } else { + throw new RuntimeError$1('Input is not a number.'); + } + } + return 0; +} + +// +class Step { + constructor(type, input, stops) { + this.type = type; + this.input = input; + this.labels = []; + this.outputs = []; + for (const [label, expression] of stops) { + this.labels.push(label); + this.outputs.push(expression); + } + } + static parse(args, context) { + if (args.length - 1 < 4) { + return context.error(`Expected at least 4 arguments, but found only ${ args.length - 1 }.`); + } + if ((args.length - 1) % 2 !== 0) { + return context.error(`Expected an even number of arguments.`); + } + const input = context.parse(args[1], 1, NumberType); + if (!input) + return null; + const stops = []; + let outputType = null; + if (context.expectedType && context.expectedType.kind !== 'value') { + outputType = context.expectedType; + } + for (let i = 1; i < args.length; i += 2) { + const label = i === 1 ? -Infinity : args[i]; + const value = args[i + 1]; + const labelKey = i; + const valueKey = i + 1; + if (typeof label !== 'number') { + return context.error('Input/output pairs for "step" expressions must be defined using literal numeric values (not computed expressions) for the input values.', labelKey); + } + if (stops.length && stops[stops.length - 1][0] >= label) { + return context.error('Input/output pairs for "step" expressions must be arranged with input values in strictly ascending order.', labelKey); + } + const parsed = context.parse(value, valueKey, outputType); + if (!parsed) + return null; + outputType = outputType || parsed.type; + stops.push([ + label, + parsed + ]); + } + return new Step(outputType, input, stops); + } + evaluate(ctx) { + const labels = this.labels; + const outputs = this.outputs; + if (labels.length === 1) { + return outputs[0].evaluate(ctx); + } + const value = this.input.evaluate(ctx); + if (value <= labels[0]) { + return outputs[0].evaluate(ctx); + } + const stopCount = labels.length; + if (value >= labels[stopCount - 1]) { + return outputs[stopCount - 1].evaluate(ctx); + } + const index = findStopLessThanOrEqualTo(labels, value); + return outputs[index].evaluate(ctx); + } + eachChild(fn) { + fn(this.input); + for (const expression of this.outputs) { + fn(expression); + } + } + outputDefined() { + return this.outputs.every(out => out.outputDefined()); + } + serialize() { + const serialized = [ + 'step', + this.input.serialize() + ]; + for (let i = 0; i < this.labels.length; i++) { + if (i > 0) { + serialized.push(this.labels[i]); + } + serialized.push(this.outputs[i].serialize()); + } + return serialized; + } +} +var Step$1 = Step; + +/* + * Copyright (C) 2008 Apple Inc. All Rights Reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY + * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR + * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY + * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + * + * Ported from Webkit + * http://svn.webkit.org/repository/webkit/trunk/Source/WebCore/platform/graphics/UnitBezier.h + */ + +var unitbezier = UnitBezier; +function UnitBezier(p1x, p1y, p2x, p2y) { + // Calculate the polynomial coefficients, implicit first and last control points are (0,0) and (1,1). + this.cx = 3 * p1x; + this.bx = 3 * (p2x - p1x) - this.cx; + this.ax = 1 - this.cx - this.bx; + this.cy = 3 * p1y; + this.by = 3 * (p2y - p1y) - this.cy; + this.ay = 1 - this.cy - this.by; + this.p1x = p1x; + this.p1y = p2y; + this.p2x = p2x; + this.p2y = p2y; +} +UnitBezier.prototype.sampleCurveX = function (t) { + // `ax t^3 + bx t^2 + cx t' expanded using Horner's rule. + return ((this.ax * t + this.bx) * t + this.cx) * t; +}; +UnitBezier.prototype.sampleCurveY = function (t) { + return ((this.ay * t + this.by) * t + this.cy) * t; +}; +UnitBezier.prototype.sampleCurveDerivativeX = function (t) { + return (3 * this.ax * t + 2 * this.bx) * t + this.cx; +}; +UnitBezier.prototype.solveCurveX = function (x, epsilon) { + if (typeof epsilon === 'undefined') + epsilon = 0.000001; + var t0, t1, t2, x2, i; + // First try a few iterations of Newton's method -- normally very fast. + for (t2 = x, i = 0; i < 8; i++) { + x2 = this.sampleCurveX(t2) - x; + if (Math.abs(x2) < epsilon) + return t2; + var d2 = this.sampleCurveDerivativeX(t2); + if (Math.abs(d2) < 0.000001) + break; + t2 = t2 - x2 / d2; + } + // Fall back to the bisection method for reliability. + t0 = 0; + t1 = 1; + t2 = x; + if (t2 < t0) + return t0; + if (t2 > t1) + return t1; + while (t0 < t1) { + x2 = this.sampleCurveX(t2); + if (Math.abs(x2 - x) < epsilon) + return t2; + if (x > x2) { + t0 = t2; + } else { + t1 = t2; + } + t2 = (t1 - t0) * 0.5 + t0; + } + // Failure. + return t2; +}; +UnitBezier.prototype.solve = function (x, epsilon) { + return this.sampleCurveY(this.solveCurveX(x, epsilon)); +}; + +var UnitBezier$1 = /*@__PURE__*/getDefaultExportFromCjs(unitbezier); + +// +function number(a, b, t) { + return a * (1 - t) + b * t; +} +function color(from, to, t) { + return new Color$1(number(from.r, to.r, t), number(from.g, to.g, t), number(from.b, to.b, t), number(from.a, to.a, t)); +} +function array(from, to, t) { + return from.map((d, i) => { + return number(d, to[i], t); + }); +} + +var interpolate = /*#__PURE__*/Object.freeze({ + __proto__: null, + number: number, + color: color, + array: array +}); + +// +// Constants +const Xn = 0.95047, + // D65 standard referent + Yn = 1, Zn = 1.08883, t0 = 4 / 29, t1 = 6 / 29, t2 = 3 * t1 * t1, t3 = t1 * t1 * t1, deg2rad$1 = Math.PI / 180, rad2deg = 180 / Math.PI; +// Utilities +function xyz2lab(t) { + return t > t3 ? Math.pow(t, 1 / 3) : t / t2 + t0; +} +function lab2xyz(t) { + return t > t1 ? t * t * t : t2 * (t - t0); +} +function xyz2rgb(x) { + return 255 * (x <= 0.0031308 ? 12.92 * x : 1.055 * Math.pow(x, 1 / 2.4) - 0.055); +} +function rgb2xyz(x) { + x /= 255; + return x <= 0.04045 ? x / 12.92 : Math.pow((x + 0.055) / 1.055, 2.4); +} +// LAB +function rgbToLab(rgbColor) { + const b = rgb2xyz(rgbColor.r), a = rgb2xyz(rgbColor.g), l = rgb2xyz(rgbColor.b), x = xyz2lab((0.4124564 * b + 0.3575761 * a + 0.1804375 * l) / Xn), y = xyz2lab((0.2126729 * b + 0.7151522 * a + 0.072175 * l) / Yn), z = xyz2lab((0.0193339 * b + 0.119192 * a + 0.9503041 * l) / Zn); + return { + l: 116 * y - 16, + a: 500 * (x - y), + b: 200 * (y - z), + alpha: rgbColor.a + }; +} +function labToRgb(labColor) { + let y = (labColor.l + 16) / 116, x = isNaN(labColor.a) ? y : y + labColor.a / 500, z = isNaN(labColor.b) ? y : y - labColor.b / 200; + y = Yn * lab2xyz(y); + x = Xn * lab2xyz(x); + z = Zn * lab2xyz(z); + return new Color$1(xyz2rgb(3.2404542 * x - 1.5371385 * y - 0.4985314 * z), // D65 -> sRGB + xyz2rgb(-0.969266 * x + 1.8760108 * y + 0.041556 * z), xyz2rgb(0.0556434 * x - 0.2040259 * y + 1.0572252 * z), labColor.alpha); +} +function interpolateLab(from, to, t) { + return { + l: number(from.l, to.l, t), + a: number(from.a, to.a, t), + b: number(from.b, to.b, t), + alpha: number(from.alpha, to.alpha, t) + }; +} +// HCL +function rgbToHcl(rgbColor) { + const {l, a, b} = rgbToLab(rgbColor); + const h = Math.atan2(b, a) * rad2deg; + return { + h: h < 0 ? h + 360 : h, + c: Math.sqrt(a * a + b * b), + l, + alpha: rgbColor.a + }; +} +function hclToRgb(hclColor) { + const h = hclColor.h * deg2rad$1, c = hclColor.c, l = hclColor.l; + return labToRgb({ + l, + a: Math.cos(h) * c, + b: Math.sin(h) * c, + alpha: hclColor.alpha + }); +} +function interpolateHue(a, b, t) { + const d = b - a; + return a + t * (d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d); +} +function interpolateHcl(from, to, t) { + return { + h: interpolateHue(from.h, to.h, t), + c: number(from.c, to.c, t), + l: number(from.l, to.l, t), + alpha: number(from.alpha, to.alpha, t) + }; +} +const lab = { + forward: rgbToLab, + reverse: labToRgb, + interpolate: interpolateLab +}; +const hcl = { + forward: rgbToHcl, + reverse: hclToRgb, + interpolate: interpolateHcl +}; + +// +class Interpolate { + constructor(type, operator, interpolation, input, stops) { + this.type = type; + this.operator = operator; + this.interpolation = interpolation; + this.input = input; + this.labels = []; + this.outputs = []; + for (const [label, expression] of stops) { + this.labels.push(label); + this.outputs.push(expression); + } + } + static interpolationFactor(interpolation, input, lower, upper) { + let t = 0; + if (interpolation.name === 'exponential') { + t = exponentialInterpolation(input, interpolation.base, lower, upper); + } else if (interpolation.name === 'linear') { + t = exponentialInterpolation(input, 1, lower, upper); + } else if (interpolation.name === 'cubic-bezier') { + const c = interpolation.controlPoints; + const ub = new UnitBezier$1(c[0], c[1], c[2], c[3]); + t = ub.solve(exponentialInterpolation(input, 1, lower, upper)); + } + return t; + } + static parse(args, context) { + let [operator, interpolation, input, ...rest] = args; + if (!Array.isArray(interpolation) || interpolation.length === 0) { + return context.error(`Expected an interpolation type expression.`, 1); + } + if (interpolation[0] === 'linear') { + interpolation = { name: 'linear' }; + } else if (interpolation[0] === 'exponential') { + const base = interpolation[1]; + if (typeof base !== 'number') + return context.error(`Exponential interpolation requires a numeric base.`, 1, 1); + interpolation = { + name: 'exponential', + base + }; + } else if (interpolation[0] === 'cubic-bezier') { + const controlPoints = interpolation.slice(1); + if (controlPoints.length !== 4 || controlPoints.some(t => typeof t !== 'number' || t < 0 || t > 1)) { + return context.error('Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.', 1); + } + interpolation = { + name: 'cubic-bezier', + controlPoints: controlPoints + }; + } else { + return context.error(`Unknown interpolation type ${ String(interpolation[0]) }`, 1, 0); + } + if (args.length - 1 < 4) { + return context.error(`Expected at least 4 arguments, but found only ${ args.length - 1 }.`); + } + if ((args.length - 1) % 2 !== 0) { + return context.error(`Expected an even number of arguments.`); + } + input = context.parse(input, 2, NumberType); + if (!input) + return null; + const stops = []; + let outputType = null; + if (operator === 'interpolate-hcl' || operator === 'interpolate-lab') { + outputType = ColorType; + } else if (context.expectedType && context.expectedType.kind !== 'value') { + outputType = context.expectedType; + } + for (let i = 0; i < rest.length; i += 2) { + const label = rest[i]; + const value = rest[i + 1]; + const labelKey = i + 3; + const valueKey = i + 4; + if (typeof label !== 'number') { + return context.error('Input/output pairs for "interpolate" expressions must be defined using literal numeric values (not computed expressions) for the input values.', labelKey); + } + if (stops.length && stops[stops.length - 1][0] >= label) { + return context.error('Input/output pairs for "interpolate" expressions must be arranged with input values in strictly ascending order.', labelKey); + } + const parsed = context.parse(value, valueKey, outputType); + if (!parsed) + return null; + outputType = outputType || parsed.type; + stops.push([ + label, + parsed + ]); + } + if (outputType.kind !== 'number' && outputType.kind !== 'color' && !(outputType.kind === 'array' && outputType.itemType.kind === 'number' && typeof outputType.N === 'number')) { + return context.error(`Type ${ toString$1(outputType) } is not interpolatable.`); + } + return new Interpolate(outputType, operator, interpolation, input, stops); + } + evaluate(ctx) { + const labels = this.labels; + const outputs = this.outputs; + if (labels.length === 1) { + return outputs[0].evaluate(ctx); + } + const value = this.input.evaluate(ctx); + if (value <= labels[0]) { + return outputs[0].evaluate(ctx); + } + const stopCount = labels.length; + if (value >= labels[stopCount - 1]) { + return outputs[stopCount - 1].evaluate(ctx); + } + const index = findStopLessThanOrEqualTo(labels, value); + const lower = labels[index]; + const upper = labels[index + 1]; + const t = Interpolate.interpolationFactor(this.interpolation, value, lower, upper); + const outputLower = outputs[index].evaluate(ctx); + const outputUpper = outputs[index + 1].evaluate(ctx); + if (this.operator === 'interpolate') { + return interpolate[this.type.kind.toLowerCase()](outputLower, outputUpper, t); // eslint-disable-line import/namespace + } else if (this.operator === 'interpolate-hcl') { + return hcl.reverse(hcl.interpolate(hcl.forward(outputLower), hcl.forward(outputUpper), t)); + } else { + return lab.reverse(lab.interpolate(lab.forward(outputLower), lab.forward(outputUpper), t)); + } + } + eachChild(fn) { + fn(this.input); + for (const expression of this.outputs) { + fn(expression); + } + } + outputDefined() { + return this.outputs.every(out => out.outputDefined()); + } + serialize() { + let interpolation; + if (this.interpolation.name === 'linear') { + interpolation = ['linear']; + } else if (this.interpolation.name === 'exponential') { + if (this.interpolation.base === 1) { + interpolation = ['linear']; + } else { + interpolation = [ + 'exponential', + this.interpolation.base + ]; + } + } else { + interpolation = ['cubic-bezier'].concat(this.interpolation.controlPoints); + } + const serialized = [ + this.operator, + interpolation, + this.input.serialize() + ]; + for (let i = 0; i < this.labels.length; i++) { + serialized.push(this.labels[i], this.outputs[i].serialize()); + } + return serialized; + } +} +/** + * Returns a ratio that can be used to interpolate between exponential function + * stops. + * How it works: Two consecutive stop values define a (scaled and shifted) exponential function `f(x) = a * base^x + b`, where `base` is the user-specified base, + * and `a` and `b` are constants affording sufficient degrees of freedom to fit + * the function to the given stops. + * + * Here's a bit of algebra that lets us compute `f(x)` directly from the stop + * values without explicitly solving for `a` and `b`: + * + * First stop value: `f(x0) = y0 = a * base^x0 + b` + * Second stop value: `f(x1) = y1 = a * base^x1 + b` + * => `y1 - y0 = a(base^x1 - base^x0)` + * => `a = (y1 - y0)/(base^x1 - base^x0)` + * + * Desired value: `f(x) = y = a * base^x + b` + * => `f(x) = y0 + a * (base^x - base^x0)` + * + * From the above, we can replace the `a` in `a * (base^x - base^x0)` and do a + * little algebra: + * ``` + * a * (base^x - base^x0) = (y1 - y0)/(base^x1 - base^x0) * (base^x - base^x0) + * = (y1 - y0) * (base^x - base^x0) / (base^x1 - base^x0) + * ``` + * + * If we let `(base^x - base^x0) / (base^x1 base^x0)`, then we have + * `f(x) = y0 + (y1 - y0) * ratio`. In other words, `ratio` may be treated as + * an interpolation factor between the two stops' output values. + * + * (Note: a slightly different form for `ratio`, + * `(base^(x-x0) - 1) / (base^(x1-x0) - 1) `, is equivalent, but requires fewer + * expensive `Math.pow()` operations.) + * + * @private +*/ +function exponentialInterpolation(input, base, lowerValue, upperValue) { + const difference = upperValue - lowerValue; + const progress = input - lowerValue; + if (difference === 0) { + return 0; + } else if (base === 1) { + return progress / difference; + } else { + return (Math.pow(base, progress) - 1) / (Math.pow(base, difference) - 1); + } +} +var Interpolate$1 = Interpolate; + +class Coalesce { + constructor(type, args) { + this.type = type; + this.args = args; + } + static parse(args, context) { + if (args.length < 2) { + return context.error('Expectected at least one argument.'); + } + let outputType = null; + const expectedType = context.expectedType; + if (expectedType && expectedType.kind !== 'value') { + outputType = expectedType; + } + const parsedArgs = []; + for (const arg of args.slice(1)) { + const parsed = context.parse(arg, 1 + parsedArgs.length, outputType, undefined, { typeAnnotation: 'omit' }); + if (!parsed) + return null; + outputType = outputType || parsed.type; + parsedArgs.push(parsed); + } + // Above, we parse arguments without inferred type annotation so that + // they don't produce a runtime error for `null` input, which would + // preempt the desired null-coalescing behavior. + // Thus, if any of our arguments would have needed an annotation, we + // need to wrap the enclosing coalesce expression with it instead. + const needsAnnotation = expectedType && parsedArgs.some(arg => checkSubtype(expectedType, arg.type)); + return needsAnnotation ? new Coalesce(ValueType, parsedArgs) : new Coalesce(outputType, parsedArgs); + } + evaluate(ctx) { + let result = null; + let argCount = 0; + let firstImage; + for (const arg of this.args) { + argCount++; + result = arg.evaluate(ctx); + // we need to keep track of the first requested image in a coalesce statement + // if coalesce can't find a valid image, we return the first image so styleimagemissing can fire + if (result && result instanceof ResolvedImage && !result.available) { + // set to first image + if (!firstImage) { + firstImage = result; + } + result = null; + // if we reach the end, return the first image + if (argCount === this.args.length) { + return firstImage; + } + } + if (result !== null) + break; + } + return result; + } + eachChild(fn) { + this.args.forEach(fn); + } + outputDefined() { + return this.args.every(arg => arg.outputDefined()); + } + serialize() { + const serialized = ['coalesce']; + this.eachChild(child => { + serialized.push(child.serialize()); + }); + return serialized; + } +} +var Coalesce$1 = Coalesce; + +// +class Let { + constructor(bindings, result) { + this.type = result.type; + this.bindings = [].concat(bindings); + this.result = result; + } + evaluate(ctx) { + return this.result.evaluate(ctx); + } + eachChild(fn) { + for (const binding of this.bindings) { + fn(binding[1]); + } + fn(this.result); + } + static parse(args, context) { + if (args.length < 4) + return context.error(`Expected at least 3 arguments, but found ${ args.length - 1 } instead.`); + const bindings = []; + for (let i = 1; i < args.length - 1; i += 2) { + const name = args[i]; + if (typeof name !== 'string') { + return context.error(`Expected string, but found ${ typeof name } instead.`, i); + } + if (/[^a-zA-Z0-9_]/.test(name)) { + return context.error(`Variable names must contain only alphanumeric characters or '_'.`, i); + } + const value = context.parse(args[i + 1], i + 1); + if (!value) + return null; + bindings.push([ + name, + value + ]); + } + const result = context.parse(args[args.length - 1], args.length - 1, context.expectedType, bindings); + if (!result) + return null; + return new Let(bindings, result); + } + outputDefined() { + return this.result.outputDefined(); + } + serialize() { + const serialized = ['let']; + for (const [name, expr] of this.bindings) { + serialized.push(name, expr.serialize()); + } + serialized.push(this.result.serialize()); + return serialized; + } +} +var Let$1 = Let; + +// +class At { + constructor(type, index, input) { + this.type = type; + this.index = index; + this.input = input; + } + static parse(args, context) { + if (args.length !== 3) + return context.error(`Expected 2 arguments, but found ${ args.length - 1 } instead.`); + const index = context.parse(args[1], 1, NumberType); + const input = context.parse(args[2], 2, array$1(context.expectedType || ValueType)); + if (!index || !input) + return null; + const t = input.type; + return new At(t.itemType, index, input); + } + evaluate(ctx) { + const index = this.index.evaluate(ctx); + const array = this.input.evaluate(ctx); + if (index < 0) { + throw new RuntimeError$1(`Array index out of bounds: ${ index } < 0.`); + } + if (index >= array.length) { + throw new RuntimeError$1(`Array index out of bounds: ${ index } > ${ array.length - 1 }.`); + } + if (index !== Math.floor(index)) { + throw new RuntimeError$1(`Array index must be an integer, but found ${ index } instead.`); + } + return array[index]; + } + eachChild(fn) { + fn(this.index); + fn(this.input); + } + outputDefined() { + return false; + } + serialize() { + return [ + 'at', + this.index.serialize(), + this.input.serialize() + ]; + } +} +var At$1 = At; + +// +class In { + constructor(needle, haystack) { + this.type = BooleanType; + this.needle = needle; + this.haystack = haystack; + } + static parse(args, context) { + if (args.length !== 3) { + return context.error(`Expected 2 arguments, but found ${ args.length - 1 } instead.`); + } + const needle = context.parse(args[1], 1, ValueType); + const haystack = context.parse(args[2], 2, ValueType); + if (!needle || !haystack) + return null; + if (!isValidType(needle.type, [ + BooleanType, + StringType, + NumberType, + NullType, + ValueType + ])) { + return context.error(`Expected first argument to be of type boolean, string, number or null, but found ${ toString$1(needle.type) } instead`); + } + return new In(needle, haystack); + } + evaluate(ctx) { + const needle = this.needle.evaluate(ctx); + const haystack = this.haystack.evaluate(ctx); + if (haystack == null) + return false; + if (!isValidNativeType(needle, [ + 'boolean', + 'string', + 'number', + 'null' + ])) { + throw new RuntimeError$1(`Expected first argument to be of type boolean, string, number or null, but found ${ toString$1(typeOf(needle)) } instead.`); + } + if (!isValidNativeType(haystack, [ + 'string', + 'array' + ])) { + throw new RuntimeError$1(`Expected second argument to be of type array or string, but found ${ toString$1(typeOf(haystack)) } instead.`); + } + return haystack.indexOf(needle) >= 0; + } + eachChild(fn) { + fn(this.needle); + fn(this.haystack); + } + outputDefined() { + return true; + } + serialize() { + return [ + 'in', + this.needle.serialize(), + this.haystack.serialize() + ]; + } +} +var In$1 = In; + +// +class IndexOf { + constructor(needle, haystack, fromIndex) { + this.type = NumberType; + this.needle = needle; + this.haystack = haystack; + this.fromIndex = fromIndex; + } + static parse(args, context) { + if (args.length <= 2 || args.length >= 5) { + return context.error(`Expected 3 or 4 arguments, but found ${ args.length - 1 } instead.`); + } + const needle = context.parse(args[1], 1, ValueType); + const haystack = context.parse(args[2], 2, ValueType); + if (!needle || !haystack) + return null; + if (!isValidType(needle.type, [ + BooleanType, + StringType, + NumberType, + NullType, + ValueType + ])) { + return context.error(`Expected first argument to be of type boolean, string, number or null, but found ${ toString$1(needle.type) } instead`); + } + if (args.length === 4) { + const fromIndex = context.parse(args[3], 3, NumberType); + if (!fromIndex) + return null; + return new IndexOf(needle, haystack, fromIndex); + } else { + return new IndexOf(needle, haystack); + } + } + evaluate(ctx) { + const needle = this.needle.evaluate(ctx); + const haystack = this.haystack.evaluate(ctx); + if (!isValidNativeType(needle, [ + 'boolean', + 'string', + 'number', + 'null' + ])) { + throw new RuntimeError$1(`Expected first argument to be of type boolean, string, number or null, but found ${ toString$1(typeOf(needle)) } instead.`); + } + if (!isValidNativeType(haystack, [ + 'string', + 'array' + ])) { + throw new RuntimeError$1(`Expected second argument to be of type array or string, but found ${ toString$1(typeOf(haystack)) } instead.`); + } + if (this.fromIndex) { + const fromIndex = this.fromIndex.evaluate(ctx); + return haystack.indexOf(needle, fromIndex); + } + return haystack.indexOf(needle); + } + eachChild(fn) { + fn(this.needle); + fn(this.haystack); + if (this.fromIndex) { + fn(this.fromIndex); + } + } + outputDefined() { + return false; + } + serialize() { + if (this.fromIndex != null && this.fromIndex !== undefined) { + const fromIndex = this.fromIndex.serialize(); + return [ + 'index-of', + this.needle.serialize(), + this.haystack.serialize(), + fromIndex + ]; + } + return [ + 'index-of', + this.needle.serialize(), + this.haystack.serialize() + ]; + } +} +var IndexOf$1 = IndexOf; + +// Map input label values to output expression index +class Match { + constructor(inputType, outputType, input, cases, outputs, otherwise) { + this.inputType = inputType; + this.type = outputType; + this.input = input; + this.cases = cases; + this.outputs = outputs; + this.otherwise = otherwise; + } + static parse(args, context) { + if (args.length < 5) + return context.error(`Expected at least 4 arguments, but found only ${ args.length - 1 }.`); + if (args.length % 2 !== 1) + return context.error(`Expected an even number of arguments.`); + let inputType; + let outputType; + if (context.expectedType && context.expectedType.kind !== 'value') { + outputType = context.expectedType; + } + const cases = {}; + const outputs = []; + for (let i = 2; i < args.length - 1; i += 2) { + let labels = args[i]; + const value = args[i + 1]; + if (!Array.isArray(labels)) { + labels = [labels]; + } + const labelContext = context.concat(i); + if (labels.length === 0) { + return labelContext.error('Expected at least one branch label.'); + } + for (const label of labels) { + if (typeof label !== 'number' && typeof label !== 'string') { + return labelContext.error(`Branch labels must be numbers or strings.`); + } else if (typeof label === 'number' && Math.abs(label) > Number.MAX_SAFE_INTEGER) { + return labelContext.error(`Branch labels must be integers no larger than ${ Number.MAX_SAFE_INTEGER }.`); + } else if (typeof label === 'number' && Math.floor(label) !== label) { + return labelContext.error(`Numeric branch labels must be integer values.`); + } else if (!inputType) { + inputType = typeOf(label); + } else if (labelContext.checkSubtype(inputType, typeOf(label))) { + return null; + } + if (typeof cases[String(label)] !== 'undefined') { + return labelContext.error('Branch labels must be unique.'); + } + cases[String(label)] = outputs.length; + } + const result = context.parse(value, i, outputType); + if (!result) + return null; + outputType = outputType || result.type; + outputs.push(result); + } + const input = context.parse(args[1], 1, ValueType); + if (!input) + return null; + const otherwise = context.parse(args[args.length - 1], args.length - 1, outputType); + if (!otherwise) + return null; + if (input.type.kind !== 'value' && context.concat(1).checkSubtype(inputType, input.type)) { + return null; + } + return new Match(inputType, outputType, input, cases, outputs, otherwise); + } + evaluate(ctx) { + const input = this.input.evaluate(ctx); + const output = typeOf(input) === this.inputType && this.outputs[this.cases[input]] || this.otherwise; + return output.evaluate(ctx); + } + eachChild(fn) { + fn(this.input); + this.outputs.forEach(fn); + fn(this.otherwise); + } + outputDefined() { + return this.outputs.every(out => out.outputDefined()) && this.otherwise.outputDefined(); + } + serialize() { + const serialized = [ + 'match', + this.input.serialize() + ]; + // Sort so serialization has an arbitrary defined order, even though + // branch order doesn't affect evaluation + const sortedLabels = Object.keys(this.cases).sort(); + // Group branches by unique match expression to support condensed + // serializations of the form [case1, case2, ...] -> matchExpression + const groupedByOutput = []; + const outputLookup = {}; + // lookup index into groupedByOutput for a given output expression + for (const label of sortedLabels) { + const outputIndex = outputLookup[this.cases[label]]; + if (outputIndex === undefined) { + // First time seeing this output, add it to the end of the grouped list + outputLookup[this.cases[label]] = groupedByOutput.length; + groupedByOutput.push([ + this.cases[label], + [label] + ]); + } else { + // We've seen this expression before, add the label to that output's group + groupedByOutput[outputIndex][1].push(label); + } + } + const coerceLabel = label => this.inputType.kind === 'number' ? Number(label) : label; + for (const [outputIndex, labels] of groupedByOutput) { + if (labels.length === 1) { + // Only a single label matches this output expression + serialized.push(coerceLabel(labels[0])); + } else { + // Array of literal labels pointing to this output expression + serialized.push(labels.map(coerceLabel)); + } + serialized.push(this.outputs[outputIndex].serialize()); + } + serialized.push(this.otherwise.serialize()); + return serialized; + } +} +var Match$1 = Match; + +class Case { + constructor(type, branches, otherwise) { + this.type = type; + this.branches = branches; + this.otherwise = otherwise; + } + static parse(args, context) { + if (args.length < 4) + return context.error(`Expected at least 3 arguments, but found only ${ args.length - 1 }.`); + if (args.length % 2 !== 0) + return context.error(`Expected an odd number of arguments.`); + let outputType; + if (context.expectedType && context.expectedType.kind !== 'value') { + outputType = context.expectedType; + } + const branches = []; + for (let i = 1; i < args.length - 1; i += 2) { + const test = context.parse(args[i], i, BooleanType); + if (!test) + return null; + const result = context.parse(args[i + 1], i + 1, outputType); + if (!result) + return null; + branches.push([ + test, + result + ]); + outputType = outputType || result.type; + } + const otherwise = context.parse(args[args.length - 1], args.length - 1, outputType); + if (!otherwise) + return null; + return new Case(outputType, branches, otherwise); + } + evaluate(ctx) { + for (const [test, expression] of this.branches) { + if (test.evaluate(ctx)) { + return expression.evaluate(ctx); + } + } + return this.otherwise.evaluate(ctx); + } + eachChild(fn) { + for (const [test, expression] of this.branches) { + fn(test); + fn(expression); + } + fn(this.otherwise); + } + outputDefined() { + return this.branches.every(([_, out]) => out.outputDefined()) && this.otherwise.outputDefined(); + } + serialize() { + const serialized = ['case']; + this.eachChild(child => { + serialized.push(child.serialize()); + }); + return serialized; + } +} +var Case$1 = Case; + +// +class Slice { + constructor(type, input, beginIndex, endIndex) { + this.type = type; + this.input = input; + this.beginIndex = beginIndex; + this.endIndex = endIndex; + } + static parse(args, context) { + if (args.length <= 2 || args.length >= 5) { + return context.error(`Expected 3 or 4 arguments, but found ${ args.length - 1 } instead.`); + } + const input = context.parse(args[1], 1, ValueType); + const beginIndex = context.parse(args[2], 2, NumberType); + if (!input || !beginIndex) + return null; + if (!isValidType(input.type, [ + array$1(ValueType), + StringType, + ValueType + ])) { + return context.error(`Expected first argument to be of type array or string, but found ${ toString$1(input.type) } instead`); + } + if (args.length === 4) { + const endIndex = context.parse(args[3], 3, NumberType); + if (!endIndex) + return null; + return new Slice(input.type, input, beginIndex, endIndex); + } else { + return new Slice(input.type, input, beginIndex); + } + } + evaluate(ctx) { + const input = this.input.evaluate(ctx); + const beginIndex = this.beginIndex.evaluate(ctx); + if (!isValidNativeType(input, [ + 'string', + 'array' + ])) { + throw new RuntimeError$1(`Expected first argument to be of type array or string, but found ${ toString$1(typeOf(input)) } instead.`); + } + if (this.endIndex) { + const endIndex = this.endIndex.evaluate(ctx); + return input.slice(beginIndex, endIndex); + } + return input.slice(beginIndex); + } + eachChild(fn) { + fn(this.input); + fn(this.beginIndex); + if (this.endIndex) { + fn(this.endIndex); + } + } + outputDefined() { + return false; + } + serialize() { + if (this.endIndex != null && this.endIndex !== undefined) { + const endIndex = this.endIndex.serialize(); + return [ + 'slice', + this.input.serialize(), + this.beginIndex.serialize(), + endIndex + ]; + } + return [ + 'slice', + this.input.serialize(), + this.beginIndex.serialize() + ]; + } +} +var Slice$1 = Slice; + +// +function isComparableType(op, type) { + if (op === '==' || op === '!=') { + // equality operator + return type.kind === 'boolean' || type.kind === 'string' || type.kind === 'number' || type.kind === 'null' || type.kind === 'value'; + } else { + // ordering operator + return type.kind === 'string' || type.kind === 'number' || type.kind === 'value'; + } +} +function eq(ctx, a, b) { + return a === b; +} +function neq(ctx, a, b) { + return a !== b; +} +function lt(ctx, a, b) { + return a < b; +} +function gt(ctx, a, b) { + return a > b; +} +function lteq(ctx, a, b) { + return a <= b; +} +function gteq(ctx, a, b) { + return a >= b; +} +function eqCollate(ctx, a, b, c) { + return c.compare(a, b) === 0; +} +function neqCollate(ctx, a, b, c) { + return !eqCollate(ctx, a, b, c); +} +function ltCollate(ctx, a, b, c) { + return c.compare(a, b) < 0; +} +function gtCollate(ctx, a, b, c) { + return c.compare(a, b) > 0; +} +function lteqCollate(ctx, a, b, c) { + return c.compare(a, b) <= 0; +} +function gteqCollate(ctx, a, b, c) { + return c.compare(a, b) >= 0; +} +/** + * Special form for comparison operators, implementing the signatures: + * - (T, T, ?Collator) => boolean + * - (T, value, ?Collator) => boolean + * - (value, T, ?Collator) => boolean + * + * For inequalities, T must be either value, string, or number. For ==/!=, it + * can also be boolean or null. + * + * Equality semantics are equivalent to Javascript's strict equality (===/!==) + * -- i.e., when the arguments' types don't match, == evaluates to false, != to + * true. + * + * When types don't match in an ordering comparison, a runtime error is thrown. + * + * @private + */ +function makeComparison(op, compareBasic, compareWithCollator) { + const isOrderComparison = op !== '==' && op !== '!='; + return class Comparison { + constructor(lhs, rhs, collator) { + this.type = BooleanType; + this.lhs = lhs; + this.rhs = rhs; + this.collator = collator; + this.hasUntypedArgument = lhs.type.kind === 'value' || rhs.type.kind === 'value'; + } + static parse(args, context) { + if (args.length !== 3 && args.length !== 4) + return context.error(`Expected two or three arguments.`); + const op = args[0]; + let lhs = context.parse(args[1], 1, ValueType); + if (!lhs) + return null; + if (!isComparableType(op, lhs.type)) { + return context.concat(1).error(`"${ op }" comparisons are not supported for type '${ toString$1(lhs.type) }'.`); + } + let rhs = context.parse(args[2], 2, ValueType); + if (!rhs) + return null; + if (!isComparableType(op, rhs.type)) { + return context.concat(2).error(`"${ op }" comparisons are not supported for type '${ toString$1(rhs.type) }'.`); + } + if (lhs.type.kind !== rhs.type.kind && lhs.type.kind !== 'value' && rhs.type.kind !== 'value') { + return context.error(`Cannot compare types '${ toString$1(lhs.type) }' and '${ toString$1(rhs.type) }'.`); + } + if (isOrderComparison) { + // typing rules specific to less/greater than operators + if (lhs.type.kind === 'value' && rhs.type.kind !== 'value') { + // (value, T) + lhs = new Assertion$1(rhs.type, [lhs]); + } else if (lhs.type.kind !== 'value' && rhs.type.kind === 'value') { + // (T, value) + rhs = new Assertion$1(lhs.type, [rhs]); + } + } + let collator = null; + if (args.length === 4) { + if (lhs.type.kind !== 'string' && rhs.type.kind !== 'string' && lhs.type.kind !== 'value' && rhs.type.kind !== 'value') { + return context.error(`Cannot use collator to compare non-string types.`); + } + collator = context.parse(args[3], 3, CollatorType); + if (!collator) + return null; + } + return new Comparison(lhs, rhs, collator); + } + evaluate(ctx) { + const lhs = this.lhs.evaluate(ctx); + const rhs = this.rhs.evaluate(ctx); + if (isOrderComparison && this.hasUntypedArgument) { + const lt = typeOf(lhs); + const rt = typeOf(rhs); + // check that type is string or number, and equal + if (lt.kind !== rt.kind || !(lt.kind === 'string' || lt.kind === 'number')) { + throw new RuntimeError$1(`Expected arguments for "${ op }" to be (string, string) or (number, number), but found (${ lt.kind }, ${ rt.kind }) instead.`); + } + } + if (this.collator && !isOrderComparison && this.hasUntypedArgument) { + const lt = typeOf(lhs); + const rt = typeOf(rhs); + if (lt.kind !== 'string' || rt.kind !== 'string') { + return compareBasic(ctx, lhs, rhs); + } + } + return this.collator ? compareWithCollator(ctx, lhs, rhs, this.collator.evaluate(ctx)) : compareBasic(ctx, lhs, rhs); + } + eachChild(fn) { + fn(this.lhs); + fn(this.rhs); + if (this.collator) { + fn(this.collator); + } + } + outputDefined() { + return true; + } + serialize() { + const serialized = [op]; + this.eachChild(child => { + serialized.push(child.serialize()); + }); + return serialized; + } + }; +} +const Equals = makeComparison('==', eq, eqCollate); +const NotEquals = makeComparison('!=', neq, neqCollate); +const LessThan = makeComparison('<', lt, ltCollate); +const GreaterThan = makeComparison('>', gt, gtCollate); +const LessThanOrEqual = makeComparison('<=', lteq, lteqCollate); +const GreaterThanOrEqual = makeComparison('>=', gteq, gteqCollate); + +// +class NumberFormat { + // BCP 47 language tag + // ISO 4217 currency code, required if style=currency + // Simple units sanctioned for use in ECMAScript, required if style=unit. https://tc39.es/proposal-unified-intl-numberformat/section6/locales-currencies-tz_proposed_out.html#sec-issanctionedsimpleunitidentifier + // Default 0 + // Default 3 + constructor(number, locale, currency, unit, minFractionDigits, maxFractionDigits) { + this.type = StringType; + this.number = number; + this.locale = locale; + this.currency = currency; + this.unit = unit; + this.minFractionDigits = minFractionDigits; + this.maxFractionDigits = maxFractionDigits; + } + static parse(args, context) { + if (args.length !== 3) + return context.error(`Expected two arguments.`); + const number = context.parse(args[1], 1, NumberType); + if (!number) + return null; + const options = args[2]; + if (typeof options !== 'object' || Array.isArray(options)) + return context.error(`NumberFormat options argument must be an object.`); + let locale = null; + if (options['locale']) { + locale = context.parse(options['locale'], 1, StringType); + if (!locale) + return null; + } + let currency = null; + if (options['currency']) { + currency = context.parse(options['currency'], 1, StringType); + if (!currency) + return null; + } + let unit = null; + if (options['unit']) { + unit = context.parse(options['unit'], 1, StringType); + if (!unit) + return null; + } + let minFractionDigits = null; + if (options['min-fraction-digits']) { + minFractionDigits = context.parse(options['min-fraction-digits'], 1, NumberType); + if (!minFractionDigits) + return null; + } + let maxFractionDigits = null; + if (options['max-fraction-digits']) { + maxFractionDigits = context.parse(options['max-fraction-digits'], 1, NumberType); + if (!maxFractionDigits) + return null; + } + return new NumberFormat(number, locale, currency, unit, minFractionDigits, maxFractionDigits); + } + evaluate(ctx) { + return new Intl.NumberFormat(this.locale ? this.locale.evaluate(ctx) : [], { + style: this.currency && 'currency' || this.unit && 'unit' || 'decimal', + currency: this.currency ? this.currency.evaluate(ctx) : undefined, + unit: this.unit ? this.unit.evaluate(ctx) : undefined, + minimumFractionDigits: this.minFractionDigits ? this.minFractionDigits.evaluate(ctx) : undefined, + maximumFractionDigits: this.maxFractionDigits ? this.maxFractionDigits.evaluate(ctx) : undefined + }).format(this.number.evaluate(ctx)); + } + eachChild(fn) { + fn(this.number); + if (this.locale) { + fn(this.locale); + } + if (this.currency) { + fn(this.currency); + } + if (this.unit) { + fn(this.unit); + } + if (this.minFractionDigits) { + fn(this.minFractionDigits); + } + if (this.maxFractionDigits) { + fn(this.maxFractionDigits); + } + } + outputDefined() { + return false; + } + serialize() { + const options = {}; + if (this.locale) { + options['locale'] = this.locale.serialize(); + } + if (this.currency) { + options['currency'] = this.currency.serialize(); + } + if (this.unit) { + options['unit'] = this.unit.serialize(); + } + if (this.minFractionDigits) { + options['min-fraction-digits'] = this.minFractionDigits.serialize(); + } + if (this.maxFractionDigits) { + options['max-fraction-digits'] = this.maxFractionDigits.serialize(); + } + return [ + 'number-format', + this.number.serialize(), + options + ]; + } +} + +// +class Length { + constructor(input) { + this.type = NumberType; + this.input = input; + } + static parse(args, context) { + if (args.length !== 2) + return context.error(`Expected 1 argument, but found ${ args.length - 1 } instead.`); + const input = context.parse(args[1], 1); + if (!input) + return null; + if (input.type.kind !== 'array' && input.type.kind !== 'string' && input.type.kind !== 'value') + return context.error(`Expected argument of type string or array, but found ${ toString$1(input.type) } instead.`); + return new Length(input); + } + evaluate(ctx) { + const input = this.input.evaluate(ctx); + if (typeof input === 'string') { + return input.length; + } else if (Array.isArray(input)) { + return input.length; + } else { + throw new RuntimeError$1(`Expected value to be of type string or array, but found ${ toString$1(typeOf(input)) } instead.`); + } + } + eachChild(fn) { + fn(this.input); + } + outputDefined() { + return false; + } + serialize() { + const serialized = ['length']; + this.eachChild(child => { + serialized.push(child.serialize()); + }); + return serialized; + } +} +var Length$1 = Length; + +// +const expressions = { + // special forms + '==': Equals, + '!=': NotEquals, + '>': GreaterThan, + '<': LessThan, + '>=': GreaterThanOrEqual, + '<=': LessThanOrEqual, + 'array': Assertion$1, + 'at': At$1, + 'boolean': Assertion$1, + 'case': Case$1, + 'coalesce': Coalesce$1, + 'collator': CollatorExpression, + 'format': FormatExpression, + 'image': ImageExpression, + 'in': In$1, + 'index-of': IndexOf$1, + 'interpolate': Interpolate$1, + 'interpolate-hcl': Interpolate$1, + 'interpolate-lab': Interpolate$1, + 'length': Length$1, + 'let': Let$1, + 'literal': Literal$1, + 'match': Match$1, + 'number': Assertion$1, + 'number-format': NumberFormat, + 'object': Assertion$1, + 'slice': Slice$1, + 'step': Step$1, + 'string': Assertion$1, + 'to-boolean': Coercion$1, + 'to-color': Coercion$1, + 'to-number': Coercion$1, + 'to-string': Coercion$1, + 'var': Var$1, + 'within': Within$1 +}; +function rgba(ctx, [r, g, b, a]) { + r = r.evaluate(ctx); + g = g.evaluate(ctx); + b = b.evaluate(ctx); + const alpha = a ? a.evaluate(ctx) : 1; + const error = validateRGBA(r, g, b, alpha); + if (error) + throw new RuntimeError$1(error); + return new Color$1(r / 255 * alpha, g / 255 * alpha, b / 255 * alpha, alpha); +} +function has(key, obj) { + return key in obj; +} +function get(key, obj) { + const v = obj[key]; + return typeof v === 'undefined' ? null : v; +} +function binarySearch(v, a, i, j) { + while (i <= j) { + const m = i + j >> 1; + if (a[m] === v) + return true; + if (a[m] > v) + j = m - 1; + else + i = m + 1; + } + return false; +} +function varargs(type) { + return { type }; +} +CompoundExpression$1.register(expressions, { + 'error': [ + ErrorType, + [StringType], + (ctx, [v]) => { + throw new RuntimeError$1(v.evaluate(ctx)); + } + ], + 'typeof': [ + StringType, + [ValueType], + (ctx, [v]) => toString$1(typeOf(v.evaluate(ctx))) + ], + 'to-rgba': [ + array$1(NumberType, 4), + [ColorType], + (ctx, [v]) => { + return v.evaluate(ctx).toArray(); + } + ], + 'rgb': [ + ColorType, + [ + NumberType, + NumberType, + NumberType + ], + rgba + ], + 'rgba': [ + ColorType, + [ + NumberType, + NumberType, + NumberType, + NumberType + ], + rgba + ], + 'has': { + type: BooleanType, + overloads: [ + [ + [StringType], + (ctx, [key]) => has(key.evaluate(ctx), ctx.properties()) + ], + [ + [ + StringType, + ObjectType + ], + (ctx, [key, obj]) => has(key.evaluate(ctx), obj.evaluate(ctx)) + ] + ] + }, + 'get': { + type: ValueType, + overloads: [ + [ + [StringType], + (ctx, [key]) => get(key.evaluate(ctx), ctx.properties()) + ], + [ + [ + StringType, + ObjectType + ], + (ctx, [key, obj]) => get(key.evaluate(ctx), obj.evaluate(ctx)) + ] + ] + }, + 'feature-state': [ + ValueType, + [StringType], + (ctx, [key]) => get(key.evaluate(ctx), ctx.featureState || {}) + ], + 'properties': [ + ObjectType, + [], + ctx => ctx.properties() + ], + 'geometry-type': [ + StringType, + [], + ctx => ctx.geometryType() + ], + 'id': [ + ValueType, + [], + ctx => ctx.id() + ], + 'zoom': [ + NumberType, + [], + ctx => ctx.globals.zoom + ], + 'pitch': [ + NumberType, + [], + ctx => ctx.globals.pitch || 0 + ], + 'distance-from-center': [ + NumberType, + [], + ctx => ctx.distanceFromCenter() + ], + 'heatmap-density': [ + NumberType, + [], + ctx => ctx.globals.heatmapDensity || 0 + ], + 'line-progress': [ + NumberType, + [], + ctx => ctx.globals.lineProgress || 0 + ], + 'sky-radial-progress': [ + NumberType, + [], + ctx => ctx.globals.skyRadialProgress || 0 + ], + 'accumulated': [ + ValueType, + [], + ctx => ctx.globals.accumulated === undefined ? null : ctx.globals.accumulated + ], + '+': [ + NumberType, + varargs(NumberType), + (ctx, args) => { + let result = 0; + for (const arg of args) { + result += arg.evaluate(ctx); + } + return result; + } + ], + '*': [ + NumberType, + varargs(NumberType), + (ctx, args) => { + let result = 1; + for (const arg of args) { + result *= arg.evaluate(ctx); + } + return result; + } + ], + '-': { + type: NumberType, + overloads: [ + [ + [ + NumberType, + NumberType + ], + (ctx, [a, b]) => a.evaluate(ctx) - b.evaluate(ctx) + ], + [ + [NumberType], + (ctx, [a]) => -a.evaluate(ctx) + ] + ] + }, + '/': [ + NumberType, + [ + NumberType, + NumberType + ], + (ctx, [a, b]) => a.evaluate(ctx) / b.evaluate(ctx) + ], + '%': [ + NumberType, + [ + NumberType, + NumberType + ], + (ctx, [a, b]) => a.evaluate(ctx) % b.evaluate(ctx) + ], + 'ln2': [ + NumberType, + [], + () => Math.LN2 + ], + 'pi': [ + NumberType, + [], + () => Math.PI + ], + 'e': [ + NumberType, + [], + () => Math.E + ], + '^': [ + NumberType, + [ + NumberType, + NumberType + ], + (ctx, [b, e]) => Math.pow(b.evaluate(ctx), e.evaluate(ctx)) + ], + 'sqrt': [ + NumberType, + [NumberType], + (ctx, [x]) => Math.sqrt(x.evaluate(ctx)) + ], + 'log10': [ + NumberType, + [NumberType], + (ctx, [n]) => Math.log(n.evaluate(ctx)) / Math.LN10 + ], + 'ln': [ + NumberType, + [NumberType], + (ctx, [n]) => Math.log(n.evaluate(ctx)) + ], + 'log2': [ + NumberType, + [NumberType], + (ctx, [n]) => Math.log(n.evaluate(ctx)) / Math.LN2 + ], + 'sin': [ + NumberType, + [NumberType], + (ctx, [n]) => Math.sin(n.evaluate(ctx)) + ], + 'cos': [ + NumberType, + [NumberType], + (ctx, [n]) => Math.cos(n.evaluate(ctx)) + ], + 'tan': [ + NumberType, + [NumberType], + (ctx, [n]) => Math.tan(n.evaluate(ctx)) + ], + 'asin': [ + NumberType, + [NumberType], + (ctx, [n]) => Math.asin(n.evaluate(ctx)) + ], + 'acos': [ + NumberType, + [NumberType], + (ctx, [n]) => Math.acos(n.evaluate(ctx)) + ], + 'atan': [ + NumberType, + [NumberType], + (ctx, [n]) => Math.atan(n.evaluate(ctx)) + ], + 'min': [ + NumberType, + varargs(NumberType), + (ctx, args) => Math.min(...args.map(arg => arg.evaluate(ctx))) + ], + 'max': [ + NumberType, + varargs(NumberType), + (ctx, args) => Math.max(...args.map(arg => arg.evaluate(ctx))) + ], + 'abs': [ + NumberType, + [NumberType], + (ctx, [n]) => Math.abs(n.evaluate(ctx)) + ], + 'round': [ + NumberType, + [NumberType], + (ctx, [n]) => { + const v = n.evaluate(ctx); + // Javascript's Math.round() rounds towards +Infinity for halfway + // values, even when they're negative. It's more common to round + // away from 0 (e.g., this is what python and C++ do) + return v < 0 ? -Math.round(-v) : Math.round(v); + } + ], + 'floor': [ + NumberType, + [NumberType], + (ctx, [n]) => Math.floor(n.evaluate(ctx)) + ], + 'ceil': [ + NumberType, + [NumberType], + (ctx, [n]) => Math.ceil(n.evaluate(ctx)) + ], + 'filter-==': [ + BooleanType, + [ + StringType, + ValueType + ], + (ctx, [k, v]) => ctx.properties()[k.value] === v.value + ], + 'filter-id-==': [ + BooleanType, + [ValueType], + (ctx, [v]) => ctx.id() === v.value + ], + 'filter-type-==': [ + BooleanType, + [StringType], + (ctx, [v]) => ctx.geometryType() === v.value + ], + 'filter-<': [ + BooleanType, + [ + StringType, + ValueType + ], + (ctx, [k, v]) => { + const a = ctx.properties()[k.value]; + const b = v.value; + return typeof a === typeof b && a < b; + } + ], + 'filter-id-<': [ + BooleanType, + [ValueType], + (ctx, [v]) => { + const a = ctx.id(); + const b = v.value; + return typeof a === typeof b && a < b; + } + ], + 'filter->': [ + BooleanType, + [ + StringType, + ValueType + ], + (ctx, [k, v]) => { + const a = ctx.properties()[k.value]; + const b = v.value; + return typeof a === typeof b && a > b; + } + ], + 'filter-id->': [ + BooleanType, + [ValueType], + (ctx, [v]) => { + const a = ctx.id(); + const b = v.value; + return typeof a === typeof b && a > b; + } + ], + 'filter-<=': [ + BooleanType, + [ + StringType, + ValueType + ], + (ctx, [k, v]) => { + const a = ctx.properties()[k.value]; + const b = v.value; + return typeof a === typeof b && a <= b; + } + ], + 'filter-id-<=': [ + BooleanType, + [ValueType], + (ctx, [v]) => { + const a = ctx.id(); + const b = v.value; + return typeof a === typeof b && a <= b; + } + ], + 'filter->=': [ + BooleanType, + [ + StringType, + ValueType + ], + (ctx, [k, v]) => { + const a = ctx.properties()[k.value]; + const b = v.value; + return typeof a === typeof b && a >= b; + } + ], + 'filter-id->=': [ + BooleanType, + [ValueType], + (ctx, [v]) => { + const a = ctx.id(); + const b = v.value; + return typeof a === typeof b && a >= b; + } + ], + 'filter-has': [ + BooleanType, + [ValueType], + (ctx, [k]) => k.value in ctx.properties() + ], + 'filter-has-id': [ + BooleanType, + [], + ctx => ctx.id() !== null && ctx.id() !== undefined + ], + 'filter-type-in': [ + BooleanType, + [array$1(StringType)], + (ctx, [v]) => v.value.indexOf(ctx.geometryType()) >= 0 + ], + 'filter-id-in': [ + BooleanType, + [array$1(ValueType)], + (ctx, [v]) => v.value.indexOf(ctx.id()) >= 0 + ], + 'filter-in-small': [ + BooleanType, + [ + StringType, + array$1(ValueType) + ], + // assumes v is an array literal + (ctx, [k, v]) => v.value.indexOf(ctx.properties()[k.value]) >= 0 + ], + 'filter-in-large': [ + BooleanType, + [ + StringType, + array$1(ValueType) + ], + // assumes v is a array literal with values sorted in ascending order and of a single type + (ctx, [k, v]) => binarySearch(ctx.properties()[k.value], v.value, 0, v.value.length - 1) + ], + 'all': { + type: BooleanType, + overloads: [ + [ + [ + BooleanType, + BooleanType + ], + (ctx, [a, b]) => a.evaluate(ctx) && b.evaluate(ctx) + ], + [ + varargs(BooleanType), + (ctx, args) => { + for (const arg of args) { + if (!arg.evaluate(ctx)) + return false; + } + return true; + } + ] + ] + }, + 'any': { + type: BooleanType, + overloads: [ + [ + [ + BooleanType, + BooleanType + ], + (ctx, [a, b]) => a.evaluate(ctx) || b.evaluate(ctx) + ], + [ + varargs(BooleanType), + (ctx, args) => { + for (const arg of args) { + if (arg.evaluate(ctx)) + return true; + } + return false; + } + ] + ] + }, + '!': [ + BooleanType, + [BooleanType], + (ctx, [b]) => !b.evaluate(ctx) + ], + 'is-supported-script': [ + BooleanType, + [StringType], + // At parse time this will always return true, so we need to exclude this expression with isGlobalPropertyConstant + (ctx, [s]) => { + const isSupportedScript = ctx.globals && ctx.globals.isSupportedScript; + if (isSupportedScript) { + return isSupportedScript(s.evaluate(ctx)); + } + return true; + } + ], + 'upcase': [ + StringType, + [StringType], + (ctx, [s]) => s.evaluate(ctx).toUpperCase() + ], + 'downcase': [ + StringType, + [StringType], + (ctx, [s]) => s.evaluate(ctx).toLowerCase() + ], + 'concat': [ + StringType, + varargs(ValueType), + (ctx, args) => args.map(arg => toString(arg.evaluate(ctx))).join('') + ], + 'resolved-locale': [ + StringType, + [CollatorType], + (ctx, [collator]) => collator.evaluate(ctx).resolvedLocale() + ] +}); +var definitions = expressions; + +// +/** + * A type used for returning and propagating errors. The first element of the union + * represents success and contains a value, and the second represents an error and + * contains an error value. + * @private + */ +function success(value) { + return { + result: 'success', + value + }; +} +function error(value) { + return { + result: 'error', + value + }; +} + +// +function supportsPropertyExpression(spec) { + return spec['property-type'] === 'data-driven'; +} +function supportsZoomExpression(spec) { + return !!spec.expression && spec.expression.parameters.indexOf('zoom') > -1; +} +function supportsInterpolation(spec) { + return !!spec.expression && spec.expression.interpolated; +} + +function isFunction(value) { + return typeof value === 'object' && value !== null && !Array.isArray(value); +} + +class StyleExpression { + constructor(expression, propertySpec) { + this.expression = expression; + this._warningHistory = {}; + this._evaluator = new EvaluationContext$1(); + this._defaultValue = propertySpec ? getDefaultValue(propertySpec) : null; + this._enumValues = propertySpec && propertySpec.type === 'enum' ? propertySpec.values : null; + } + evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection, featureTileCoord, featureDistanceData) { + this._evaluator.globals = globals; + this._evaluator.feature = feature; + this._evaluator.featureState = featureState; + this._evaluator.canonical = canonical || null; + this._evaluator.availableImages = availableImages || null; + this._evaluator.formattedSection = formattedSection; + this._evaluator.featureTileCoord = featureTileCoord || null; + this._evaluator.featureDistanceData = featureDistanceData || null; + return this.expression.evaluate(this._evaluator); + } + evaluate(globals, feature, featureState, canonical, availableImages, formattedSection, featureTileCoord, featureDistanceData) { + this._evaluator.globals = globals; + this._evaluator.feature = feature || null; + this._evaluator.featureState = featureState || null; + this._evaluator.canonical = canonical || null; + this._evaluator.availableImages = availableImages || null; + this._evaluator.formattedSection = formattedSection || null; + this._evaluator.featureTileCoord = featureTileCoord || null; + this._evaluator.featureDistanceData = featureDistanceData || null; + try { + const val = this.expression.evaluate(this._evaluator); + // eslint-disable-next-line no-self-compare + if (val === null || val === undefined || typeof val === 'number' && val !== val) { + return this._defaultValue; + } + if (this._enumValues && !(val in this._enumValues)) { + throw new RuntimeError$1(`Expected value to be one of ${ Object.keys(this._enumValues).map(v => JSON.stringify(v)).join(', ') }, but found ${ JSON.stringify(val) } instead.`); + } + return val; + } catch (e) { + if (!this._warningHistory[e.message]) { + this._warningHistory[e.message] = true; + if (typeof console !== 'undefined') { + console.warn(e.message); + } + } + return this._defaultValue; + } + } +} +function isExpression(expression) { + return Array.isArray(expression) && expression.length > 0 && typeof expression[0] === 'string' && expression[0] in definitions; +} +/** + * Parse and typecheck the given style spec JSON expression. If + * options.defaultValue is provided, then the resulting StyleExpression's + * `evaluate()` method will handle errors by logging a warning (once per + * message) and returning the default value. Otherwise, it will throw + * evaluation errors. + * + * @private + */ +function createExpression(expression, propertySpec) { + const parser = new ParsingContext$1(definitions, [], propertySpec ? getExpectedType(propertySpec) : undefined); + // For string-valued properties, coerce to string at the top level rather than asserting. + const parsed = parser.parse(expression, undefined, undefined, undefined, propertySpec && propertySpec.type === 'string' ? { typeAnnotation: 'coerce' } : undefined); + if (!parsed) { + return error(parser.errors); + } + return success(new StyleExpression(parsed, propertySpec)); +} +class ZoomConstantExpression { + constructor(kind, expression) { + this.kind = kind; + this._styleExpression = expression; + this.isStateDependent = kind !== 'constant' && !isStateConstant(expression.expression); + } + evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection) { + return this._styleExpression.evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection); + } + evaluate(globals, feature, featureState, canonical, availableImages, formattedSection) { + return this._styleExpression.evaluate(globals, feature, featureState, canonical, availableImages, formattedSection); + } +} +class ZoomDependentExpression { + constructor(kind, expression, zoomStops, interpolationType) { + this.kind = kind; + this.zoomStops = zoomStops; + this._styleExpression = expression; + this.isStateDependent = kind !== 'camera' && !isStateConstant(expression.expression); + this.interpolationType = interpolationType; + } + evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection) { + return this._styleExpression.evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection); + } + evaluate(globals, feature, featureState, canonical, availableImages, formattedSection) { + return this._styleExpression.evaluate(globals, feature, featureState, canonical, availableImages, formattedSection); + } + interpolationFactor(input, lower, upper) { + if (this.interpolationType) { + return Interpolate$1.interpolationFactor(this.interpolationType, input, lower, upper); + } else { + return 0; + } + } +} +function createPropertyExpression(expression, propertySpec) { + expression = createExpression(expression, propertySpec); + if (expression.result === 'error') { + return expression; + } + const parsed = expression.value.expression; + const isFeatureConstant$1 = isFeatureConstant(parsed); + if (!isFeatureConstant$1 && !supportsPropertyExpression(propertySpec)) { + return error([new ParsingError$1('', 'data expressions not supported')]); + } + const isZoomConstant = isGlobalPropertyConstant(parsed, [ + 'zoom', + 'pitch', + 'distance-from-center' + ]); + if (!isZoomConstant && !supportsZoomExpression(propertySpec)) { + return error([new ParsingError$1('', 'zoom expressions not supported')]); + } + const zoomCurve = findZoomCurve(parsed); + if (!zoomCurve && !isZoomConstant) { + return error([new ParsingError$1('', '"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.')]); + } else if (zoomCurve instanceof ParsingError$1) { + return error([zoomCurve]); + } else if (zoomCurve instanceof Interpolate$1 && !supportsInterpolation(propertySpec)) { + return error([new ParsingError$1('', '"interpolate" expressions cannot be used with this property')]); + } + if (!zoomCurve) { + return success(isFeatureConstant$1 ? new ZoomConstantExpression('constant', expression.value) : new ZoomConstantExpression('source', expression.value)); + } + const interpolationType = zoomCurve instanceof Interpolate$1 ? zoomCurve.interpolation : undefined; + return success(isFeatureConstant$1 ? new ZoomDependentExpression('camera', expression.value, zoomCurve.labels, interpolationType) : new ZoomDependentExpression('composite', expression.value, zoomCurve.labels, interpolationType)); +} +// Zoom-dependent expressions may only use ["zoom"] as the input to a top-level "step" or "interpolate" +// expression (collectively referred to as a "curve"). The curve may be wrapped in one or more "let" or +// "coalesce" expressions. +function findZoomCurve(expression) { + let result = null; + if (expression instanceof Let$1) { + result = findZoomCurve(expression.result); + } else if (expression instanceof Coalesce$1) { + for (const arg of expression.args) { + result = findZoomCurve(arg); + if (result) { + break; + } + } + } else if ((expression instanceof Step$1 || expression instanceof Interpolate$1) && expression.input instanceof CompoundExpression$1 && expression.input.name === 'zoom') { + result = expression; + } + if (result instanceof ParsingError$1) { + return result; + } + expression.eachChild(child => { + const childResult = findZoomCurve(child); + if (childResult instanceof ParsingError$1) { + result = childResult; + } else if (!result && childResult) { + result = new ParsingError$1('', '"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.'); + } else if (result && childResult && result !== childResult) { + result = new ParsingError$1('', 'Only one zoom-based "step" or "interpolate" subexpression may be used in an expression.'); + } + }); + return result; +} +function getExpectedType(spec) { + const types = { + color: ColorType, + string: StringType, + number: NumberType, + enum: StringType, + boolean: BooleanType, + formatted: FormattedType, + resolvedImage: ResolvedImageType + }; + if (spec.type === 'array') { + return array$1(types[spec.value] || ValueType, spec.length); + } + return types[spec.type]; +} +function getDefaultValue(spec) { + if (spec.type === 'color' && (isFunction(spec.default) || Array.isArray(spec.default))) { + // Special case for heatmap-color: it uses the 'default:' to define a + // default color ramp, but createExpression expects a simple value to fall + // back to in case of runtime errors + return new Color$1(0, 0, 0, 0); + } else if (spec.type === 'color') { + return Color$1.parse(spec.default) || null; + } else if (spec.default === undefined) { + return null; + } else { + return spec.default; + } +} + +// +// Turn jsonlint-lines-primitives objects into primitive objects +function unbundle(value) { + if (value instanceof Number || value instanceof String || value instanceof Boolean) { + return value.valueOf(); + } else { + return value; + } +} +function deepUnbundle(value) { + if (Array.isArray(value)) { + return value.map(deepUnbundle); + } else if (value instanceof Object && !(value instanceof Number || value instanceof String || value instanceof Boolean)) { + const unbundledValue = {}; + for (const key in value) { + unbundledValue[key] = deepUnbundle(value[key]); + } + return unbundledValue; + } + return unbundle(value); +} + +var spec = {"$version":8,"$root":{"version":{"required":true,"type":"enum","values":[8]},"name":{"type":"string"},"metadata":{"type":"*"},"center":{"type":"array","value":"number"},"zoom":{"type":"number"},"bearing":{"type":"number","default":0,"period":360,"units":"degrees"},"pitch":{"type":"number","default":0,"units":"degrees"},"light":{"type":"light"},"terrain":{"type":"terrain"},"fog":{"type":"fog"},"sources":{"required":true,"type":"sources"},"sprite":{"type":"string"},"glyphs":{"type":"string"},"transition":{"type":"transition"},"projection":{"type":"projection"},"layers":{"required":true,"type":"array","value":"layer"}},"sources":{"*":{"type":"source"}},"source":["source_vector","source_raster","source_raster_dem","source_geojson","source_video","source_image"],"source_vector":{"type":{"required":true,"type":"enum","values":{"vector":{}}},"url":{"type":"string"},"tiles":{"type":"array","value":"string"},"bounds":{"type":"array","value":"number","length":4,"default":[-180,-85.051129,180,85.051129]},"scheme":{"type":"enum","values":{"xyz":{},"tms":{}},"default":"xyz"},"minzoom":{"type":"number","default":0},"maxzoom":{"type":"number","default":22},"attribution":{"type":"string"},"promoteId":{"type":"promoteId"},"volatile":{"type":"boolean","default":false},"*":{"type":"*"}},"source_raster":{"type":{"required":true,"type":"enum","values":{"raster":{}}},"url":{"type":"string"},"tiles":{"type":"array","value":"string"},"bounds":{"type":"array","value":"number","length":4,"default":[-180,-85.051129,180,85.051129]},"minzoom":{"type":"number","default":0},"maxzoom":{"type":"number","default":22},"tileSize":{"type":"number","default":512,"units":"pixels"},"scheme":{"type":"enum","values":{"xyz":{},"tms":{}},"default":"xyz"},"attribution":{"type":"string"},"volatile":{"type":"boolean","default":false},"*":{"type":"*"}},"source_raster_dem":{"type":{"required":true,"type":"enum","values":{"raster-dem":{}}},"url":{"type":"string"},"tiles":{"type":"array","value":"string"},"bounds":{"type":"array","value":"number","length":4,"default":[-180,-85.051129,180,85.051129]},"minzoom":{"type":"number","default":0},"maxzoom":{"type":"number","default":22},"tileSize":{"type":"number","default":512,"units":"pixels"},"attribution":{"type":"string"},"encoding":{"type":"enum","values":{"terrarium":{},"mapbox":{}},"default":"mapbox"},"volatile":{"type":"boolean","default":false},"*":{"type":"*"}},"source_geojson":{"type":{"required":true,"type":"enum","values":{"geojson":{}}},"data":{"type":"*"},"maxzoom":{"type":"number","default":18},"attribution":{"type":"string"},"buffer":{"type":"number","default":128,"maximum":512,"minimum":0},"filter":{"type":"*"},"tolerance":{"type":"number","default":0.375},"cluster":{"type":"boolean","default":false},"clusterRadius":{"type":"number","default":50,"minimum":0},"clusterMaxZoom":{"type":"number"},"clusterMinPoints":{"type":"number"},"clusterProperties":{"type":"*"},"lineMetrics":{"type":"boolean","default":false},"generateId":{"type":"boolean","default":false},"promoteId":{"type":"promoteId"}},"source_video":{"type":{"required":true,"type":"enum","values":{"video":{}}},"urls":{"required":true,"type":"array","value":"string"},"coordinates":{"required":true,"type":"array","length":4,"value":{"type":"array","length":2,"value":"number"}}},"source_image":{"type":{"required":true,"type":"enum","values":{"image":{}}},"url":{"required":true,"type":"string"},"coordinates":{"required":true,"type":"array","length":4,"value":{"type":"array","length":2,"value":"number"}}},"layer":{"id":{"type":"string","required":true},"type":{"type":"enum","values":{"fill":{},"line":{},"symbol":{},"circle":{},"heatmap":{},"fill-extrusion":{},"raster":{},"hillshade":{},"background":{},"sky":{}},"required":true},"metadata":{"type":"*"},"source":{"type":"string"},"source-layer":{"type":"string"},"minzoom":{"type":"number","minimum":0,"maximum":24},"maxzoom":{"type":"number","minimum":0,"maximum":24},"filter":{"type":"filter"},"layout":{"type":"layout"},"paint":{"type":"paint"}},"layout":["layout_fill","layout_line","layout_circle","layout_heatmap","layout_fill-extrusion","layout_symbol","layout_raster","layout_hillshade","layout_background","layout_sky"],"layout_background":{"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_sky":{"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_fill":{"fill-sort-key":{"type":"number","expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_circle":{"circle-sort-key":{"type":"number","expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_heatmap":{"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_fill-extrusion":{"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"},"fill-extrusion-edge-radius":{"type":"number","private":true,"default":0,"minimum":0,"maximum":1,"property-type":"constant"}},"layout_line":{"line-cap":{"type":"enum","values":{"butt":{},"round":{},"square":{}},"default":"butt","expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-join":{"type":"enum","values":{"bevel":{},"round":{},"miter":{}},"default":"miter","expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-miter-limit":{"type":"number","default":2,"requires":[{"line-join":"miter"}],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"line-round-limit":{"type":"number","default":1.05,"requires":[{"line-join":"round"}],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"line-sort-key":{"type":"number","expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_symbol":{"symbol-placement":{"type":"enum","values":{"point":{},"line":{},"line-center":{}},"default":"point","expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"symbol-spacing":{"type":"number","default":250,"minimum":1,"units":"pixels","requires":[{"symbol-placement":"line"}],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"symbol-avoid-edges":{"type":"boolean","default":false,"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"symbol-sort-key":{"type":"number","expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"symbol-z-order":{"type":"enum","values":{"auto":{},"viewport-y":{},"source":{}},"default":"auto","expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-allow-overlap":{"type":"boolean","default":false,"requires":["icon-image"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-ignore-placement":{"type":"boolean","default":false,"requires":["icon-image"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-optional":{"type":"boolean","default":false,"requires":["icon-image","text-field"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-rotation-alignment":{"type":"enum","values":{"map":{},"viewport":{},"auto":{}},"default":"auto","requires":["icon-image"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-size":{"type":"number","default":1,"minimum":0,"units":"factor of the original icon size","requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-text-fit":{"type":"enum","values":{"none":{},"width":{},"height":{},"both":{}},"default":"none","requires":["icon-image","text-field"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-text-fit-padding":{"type":"array","value":"number","length":4,"default":[0,0,0,0],"units":"pixels","requires":["icon-image","text-field",{"icon-text-fit":["both","width","height"]}],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"icon-image":{"type":"resolvedImage","tokens":true,"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-rotate":{"type":"number","default":0,"period":360,"units":"degrees","requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-padding":{"type":"number","default":2,"minimum":0,"units":"pixels","requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"icon-keep-upright":{"type":"boolean","default":false,"requires":["icon-image",{"icon-rotation-alignment":"map"},{"symbol-placement":["line","line-center"]}],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"icon-offset":{"type":"array","value":"number","length":2,"default":[0,0],"requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-anchor":{"type":"enum","values":{"center":{},"left":{},"right":{},"top":{},"bottom":{},"top-left":{},"top-right":{},"bottom-left":{},"bottom-right":{}},"default":"center","requires":["icon-image"],"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"icon-pitch-alignment":{"type":"enum","values":{"map":{},"viewport":{},"auto":{}},"default":"auto","requires":["icon-image"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-pitch-alignment":{"type":"enum","values":{"map":{},"viewport":{},"auto":{}},"default":"auto","requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-rotation-alignment":{"type":"enum","values":{"map":{},"viewport":{},"auto":{}},"default":"auto","requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-field":{"type":"formatted","default":"","tokens":true,"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-font":{"type":"array","value":"string","default":["Open Sans Regular","Arial Unicode MS Regular"],"requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-size":{"type":"number","default":16,"minimum":0,"units":"pixels","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-max-width":{"type":"number","default":10,"minimum":0,"units":"ems","requires":["text-field",{"symbol-placement":["point"]}],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-line-height":{"type":"number","default":1.2,"units":"ems","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-letter-spacing":{"type":"number","default":0,"units":"ems","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-justify":{"type":"enum","values":{"auto":{},"left":{},"center":{},"right":{}},"default":"center","requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-radial-offset":{"type":"number","units":"ems","default":0,"requires":["text-field"],"property-type":"data-driven","expression":{"interpolated":true,"parameters":["zoom","feature"]}},"text-variable-anchor":{"type":"array","value":"enum","values":{"center":{},"left":{},"right":{},"top":{},"bottom":{},"top-left":{},"top-right":{},"bottom-left":{},"bottom-right":{}},"requires":["text-field",{"symbol-placement":["point"]}],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-anchor":{"type":"enum","values":{"center":{},"left":{},"right":{},"top":{},"bottom":{},"top-left":{},"top-right":{},"bottom-left":{},"bottom-right":{}},"default":"center","requires":["text-field",{"!":"text-variable-anchor"}],"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-max-angle":{"type":"number","default":45,"units":"degrees","requires":["text-field",{"symbol-placement":["line","line-center"]}],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"text-writing-mode":{"type":"array","value":"enum","values":{"horizontal":{},"vertical":{}},"requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-rotate":{"type":"number","default":0,"period":360,"units":"degrees","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-padding":{"type":"number","default":2,"minimum":0,"units":"pixels","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"text-keep-upright":{"type":"boolean","default":true,"requires":["text-field",{"text-rotation-alignment":"map"},{"symbol-placement":["line","line-center"]}],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-transform":{"type":"enum","values":{"none":{},"uppercase":{},"lowercase":{}},"default":"none","requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-offset":{"type":"array","value":"number","units":"ems","length":2,"default":[0,0],"requires":["text-field",{"!":"text-radial-offset"}],"expression":{"interpolated":true,"parameters":["zoom","feature"]},"property-type":"data-driven"},"text-allow-overlap":{"type":"boolean","default":false,"requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-ignore-placement":{"type":"boolean","default":false,"requires":["text-field"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-optional":{"type":"boolean","default":false,"requires":["text-field","icon-image"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_raster":{"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"layout_hillshade":{"visibility":{"type":"enum","values":{"visible":{},"none":{}},"default":"visible","property-type":"constant"}},"filter":{"type":"array","value":"*"},"filter_symbol":{"type":"boolean","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature","pitch","distance-from-center"]}},"filter_fill":{"type":"boolean","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_line":{"type":"boolean","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_circle":{"type":"boolean","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_fill-extrusion":{"type":"boolean","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_heatmap":{"type":"boolean","default":false,"transition":false,"property-type":"data-driven","expression":{"interpolated":false,"parameters":["zoom","feature"]}},"filter_operator":{"type":"enum","values":{"==":{},"!=":{},">":{},">=":{},"<":{},"<=":{},"in":{},"!in":{},"all":{},"any":{},"none":{},"has":{},"!has":{},"within":{}}},"geometry_type":{"type":"enum","values":{"Point":{},"LineString":{},"Polygon":{}}},"function":{"expression":{"type":"expression"},"stops":{"type":"array","value":"function_stop"},"base":{"type":"number","default":1,"minimum":0},"property":{"type":"string","default":"$zoom"},"type":{"type":"enum","values":{"identity":{},"exponential":{},"interval":{},"categorical":{}},"default":"exponential"},"colorSpace":{"type":"enum","values":{"rgb":{},"lab":{},"hcl":{}},"default":"rgb"},"default":{"type":"*","required":false}},"function_stop":{"type":"array","minimum":0,"maximum":24,"value":["number","color"],"length":2},"expression":{"type":"array","value":"*","minimum":1},"expression_name":{"type":"enum","values":{"let":{"group":"Variable binding"},"var":{"group":"Variable binding"},"literal":{"group":"Types"},"array":{"group":"Types"},"at":{"group":"Lookup"},"in":{"group":"Lookup"},"index-of":{"group":"Lookup"},"slice":{"group":"Lookup"},"case":{"group":"Decision"},"match":{"group":"Decision"},"coalesce":{"group":"Decision"},"step":{"group":"Ramps, scales, curves"},"interpolate":{"group":"Ramps, scales, curves"},"interpolate-hcl":{"group":"Ramps, scales, curves"},"interpolate-lab":{"group":"Ramps, scales, curves"},"ln2":{"group":"Math"},"pi":{"group":"Math"},"e":{"group":"Math"},"typeof":{"group":"Types"},"string":{"group":"Types"},"number":{"group":"Types"},"boolean":{"group":"Types"},"object":{"group":"Types"},"collator":{"group":"Types"},"format":{"group":"Types"},"image":{"group":"Types"},"number-format":{"group":"Types"},"to-string":{"group":"Types"},"to-number":{"group":"Types"},"to-boolean":{"group":"Types"},"to-rgba":{"group":"Color"},"to-color":{"group":"Types"},"rgb":{"group":"Color"},"rgba":{"group":"Color"},"get":{"group":"Lookup"},"has":{"group":"Lookup"},"length":{"group":"Lookup"},"properties":{"group":"Feature data"},"feature-state":{"group":"Feature data"},"geometry-type":{"group":"Feature data"},"id":{"group":"Feature data"},"zoom":{"group":"Camera"},"pitch":{"group":"Camera"},"distance-from-center":{"group":"Camera"},"heatmap-density":{"group":"Heatmap"},"line-progress":{"group":"Feature data"},"sky-radial-progress":{"group":"sky"},"accumulated":{"group":"Feature data"},"+":{"group":"Math"},"*":{"group":"Math"},"-":{"group":"Math"},"/":{"group":"Math"},"%":{"group":"Math"},"^":{"group":"Math"},"sqrt":{"group":"Math"},"log10":{"group":"Math"},"ln":{"group":"Math"},"log2":{"group":"Math"},"sin":{"group":"Math"},"cos":{"group":"Math"},"tan":{"group":"Math"},"asin":{"group":"Math"},"acos":{"group":"Math"},"atan":{"group":"Math"},"min":{"group":"Math"},"max":{"group":"Math"},"round":{"group":"Math"},"abs":{"group":"Math"},"ceil":{"group":"Math"},"floor":{"group":"Math"},"distance":{"group":"Math"},"==":{"group":"Decision"},"!=":{"group":"Decision"},">":{"group":"Decision"},"<":{"group":"Decision"},">=":{"group":"Decision"},"<=":{"group":"Decision"},"all":{"group":"Decision"},"any":{"group":"Decision"},"!":{"group":"Decision"},"within":{"group":"Decision"},"is-supported-script":{"group":"String"},"upcase":{"group":"String"},"downcase":{"group":"String"},"concat":{"group":"String"},"resolved-locale":{"group":"String"}}},"fog":{"range":{"type":"array","default":[0.5,10],"minimum":-20,"maximum":20,"length":2,"value":"number","property-type":"data-constant","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"color":{"type":"color","property-type":"data-constant","default":"#ffffff","expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"high-color":{"type":"color","property-type":"data-constant","default":"#245cdf","expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"space-color":{"type":"color","property-type":"data-constant","default":["interpolate",["linear"],["zoom"],4,"#010b19",7,"#367ab9"],"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"horizon-blend":{"type":"number","property-type":"data-constant","default":["interpolate",["linear"],["zoom"],4,0.2,7,0.1],"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"star-intensity":{"type":"number","property-type":"data-constant","default":["interpolate",["linear"],["zoom"],5,0.35,6,0],"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true}},"light":{"anchor":{"type":"enum","default":"viewport","values":{"map":{},"viewport":{}},"property-type":"data-constant","transition":false,"expression":{"interpolated":false,"parameters":["zoom"]}},"position":{"type":"array","default":[1.15,210,30],"length":3,"value":"number","property-type":"data-constant","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]}},"color":{"type":"color","property-type":"data-constant","default":"#ffffff","expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"intensity":{"type":"number","property-type":"data-constant","default":0.5,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true}},"projection":{"name":{"type":"enum","values":{"albers":{},"equalEarth":{},"equirectangular":{},"lambertConformalConic":{},"mercator":{},"naturalEarth":{},"winkelTripel":{},"globe":{}},"default":"mercator","required":true},"center":{"type":"array","length":2,"value":"number","property-type":"data-constant","minimum":[-180,-90],"maximum":[180,90],"transition":false,"requires":[{"name":["albers","lambertConformalConic"]}]},"parallels":{"type":"array","length":2,"value":"number","property-type":"data-constant","minimum":[-90,-90],"maximum":[90,90],"transition":false,"requires":[{"name":["albers","lambertConformalConic"]}]}},"terrain":{"source":{"type":"string","required":true},"exaggeration":{"type":"number","property-type":"data-constant","default":1,"minimum":0,"maximum":1000,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"requires":["source"]}},"paint":["paint_fill","paint_line","paint_circle","paint_heatmap","paint_fill-extrusion","paint_symbol","paint_raster","paint_hillshade","paint_background","paint_sky"],"paint_fill":{"fill-antialias":{"type":"boolean","default":true,"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"fill-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-color":{"type":"color","default":"#000000","transition":true,"requires":[{"!":"fill-pattern"}],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-outline-color":{"type":"color","transition":true,"requires":[{"!":"fill-pattern"},{"fill-antialias":true}],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"fill-translate-anchor":{"type":"enum","values":{"map":{},"viewport":{}},"default":"map","requires":["fill-translate"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"fill-pattern":{"type":"resolvedImage","transition":false,"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"}},"paint_fill-extrusion":{"fill-extrusion-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-color":{"type":"color","default":"#000000","transition":true,"requires":[{"!":"fill-extrusion-pattern"}],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-translate-anchor":{"type":"enum","values":{"map":{},"viewport":{}},"default":"map","requires":["fill-extrusion-translate"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-pattern":{"type":"resolvedImage","transition":false,"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"fill-extrusion-height":{"type":"number","default":0,"minimum":0,"units":"meters","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-base":{"type":"number","default":0,"minimum":0,"units":"meters","transition":true,"requires":["fill-extrusion-height"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-vertical-gradient":{"type":"boolean","default":true,"transition":false,"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"fill-extrusion-ambient-occlusion-intensity":{"property-type":"data-constant","type":"number","private":true,"default":0,"minimum":0,"maximum":1,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true},"fill-extrusion-ambient-occlusion-radius":{"property-type":"data-constant","type":"number","private":true,"default":3,"minimum":0,"expression":{"interpolated":true,"parameters":["zoom"]},"transition":true,"requires":["fill-extrusion-edge-radius"]}},"paint_line":{"line-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-color":{"type":"color","default":"#000000","transition":true,"requires":[{"!":"line-pattern"}],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"line-translate-anchor":{"type":"enum","values":{"map":{},"viewport":{}},"default":"map","requires":["line-translate"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"line-width":{"type":"number","default":1,"minimum":0,"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-gap-width":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-offset":{"type":"number","default":0,"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-blur":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-dasharray":{"type":"array","value":"number","minimum":0,"transition":false,"units":"line widths","requires":[{"!":"line-pattern"}],"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-pattern":{"type":"resolvedImage","transition":false,"expression":{"interpolated":false,"parameters":["zoom","feature"]},"property-type":"data-driven"},"line-gradient":{"type":"color","transition":false,"requires":[{"!":"line-pattern"},{"source":"geojson","has":{"lineMetrics":true}}],"expression":{"interpolated":true,"parameters":["line-progress"]},"property-type":"color-ramp"},"line-trim-offset":{"type":"array","value":"number","length":2,"default":[0,0],"minimum":[0,0],"maximum":[1,1],"transition":false,"requires":[{"source":"geojson","has":{"lineMetrics":true}}],"property-type":"constant"}},"paint_circle":{"circle-radius":{"type":"number","default":5,"minimum":0,"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-blur":{"type":"number","default":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"circle-translate-anchor":{"type":"enum","values":{"map":{},"viewport":{}},"default":"map","requires":["circle-translate"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"circle-pitch-scale":{"type":"enum","values":{"map":{},"viewport":{}},"default":"map","expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"circle-pitch-alignment":{"type":"enum","values":{"map":{},"viewport":{}},"default":"viewport","expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"circle-stroke-width":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-stroke-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-stroke-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"}},"paint_heatmap":{"heatmap-radius":{"type":"number","default":30,"minimum":1,"transition":true,"units":"pixels","expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"heatmap-weight":{"type":"number","default":1,"minimum":0,"transition":false,"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"heatmap-intensity":{"type":"number","default":1,"minimum":0,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"heatmap-color":{"type":"color","default":["interpolate",["linear"],["heatmap-density"],0,"rgba(0, 0, 255, 0)",0.1,"royalblue",0.3,"cyan",0.5,"lime",0.7,"yellow",1,"red"],"transition":false,"expression":{"interpolated":true,"parameters":["heatmap-density"]},"property-type":"color-ramp"},"heatmap-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_symbol":{"icon-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-color":{"type":"color","default":"#000000","transition":true,"requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-color":{"type":"color","default":"rgba(0, 0, 0, 0)","transition":true,"requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-width":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-blur":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","requires":["icon-image"],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"icon-translate-anchor":{"type":"enum","values":{"map":{},"viewport":{}},"default":"map","requires":["icon-image","icon-translate"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"text-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-color":{"type":"color","default":"#000000","transition":true,"overridable":true,"requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-color":{"type":"color","default":"rgba(0, 0, 0, 0)","transition":true,"requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-width":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-blur":{"type":"number","default":0,"minimum":0,"transition":true,"units":"pixels","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-translate":{"type":"array","value":"number","length":2,"default":[0,0],"transition":true,"units":"pixels","requires":["text-field"],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"text-translate-anchor":{"type":"enum","values":{"map":{},"viewport":{}},"default":"map","requires":["text-field","text-translate"],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_raster":{"raster-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-hue-rotate":{"type":"number","default":0,"period":360,"transition":true,"units":"degrees","expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-brightness-min":{"type":"number","default":0,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-brightness-max":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-saturation":{"type":"number","default":0,"minimum":-1,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-contrast":{"type":"number","default":0,"minimum":-1,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"raster-resampling":{"type":"enum","values":{"linear":{},"nearest":{}},"default":"linear","expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"raster-fade-duration":{"type":"number","default":300,"minimum":0,"transition":false,"units":"milliseconds","expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_hillshade":{"hillshade-illumination-direction":{"type":"number","default":335,"minimum":0,"maximum":359,"transition":false,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-illumination-anchor":{"type":"enum","values":{"map":{},"viewport":{}},"default":"viewport","expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-exaggeration":{"type":"number","default":0.5,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-shadow-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-highlight-color":{"type":"color","default":"#FFFFFF","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"hillshade-accent-color":{"type":"color","default":"#000000","transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_background":{"background-color":{"type":"color","default":"#000000","transition":true,"requires":[{"!":"background-pattern"}],"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"},"background-pattern":{"type":"resolvedImage","transition":false,"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"background-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"paint_sky":{"sky-type":{"type":"enum","values":{"gradient":{},"atmosphere":{}},"default":"atmosphere","expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"sky-atmosphere-sun":{"type":"array","value":"number","length":2,"units":"degrees","minimum":[0,0],"maximum":[360,180],"transition":false,"requires":[{"sky-type":"atmosphere"}],"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"sky-atmosphere-sun-intensity":{"type":"number","requires":[{"sky-type":"atmosphere"}],"default":10,"minimum":0,"maximum":100,"transition":false,"property-type":"data-constant"},"sky-gradient-center":{"type":"array","requires":[{"sky-type":"gradient"}],"value":"number","default":[0,0],"length":2,"units":"degrees","minimum":[0,0],"maximum":[360,180],"transition":false,"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"sky-gradient-radius":{"type":"number","requires":[{"sky-type":"gradient"}],"default":90,"minimum":0,"maximum":180,"transition":false,"expression":{"interpolated":false,"parameters":["zoom"]},"property-type":"data-constant"},"sky-gradient":{"type":"color","default":["interpolate",["linear"],["sky-radial-progress"],0.8,"#87ceeb",1,"white"],"transition":false,"requires":[{"sky-type":"gradient"}],"expression":{"interpolated":true,"parameters":["sky-radial-progress"]},"property-type":"color-ramp"},"sky-atmosphere-halo-color":{"type":"color","default":"white","transition":false,"requires":[{"sky-type":"atmosphere"}],"property-type":"data-constant"},"sky-atmosphere-color":{"type":"color","default":"white","transition":false,"requires":[{"sky-type":"atmosphere"}],"property-type":"data-constant"},"sky-opacity":{"type":"number","default":1,"minimum":0,"maximum":1,"transition":true,"expression":{"interpolated":true,"parameters":["zoom"]},"property-type":"data-constant"}},"transition":{"duration":{"type":"number","default":300,"minimum":0,"units":"milliseconds"},"delay":{"type":"number","default":0,"minimum":0,"units":"milliseconds"}},"property-type":{"data-driven":{"type":"property-type"},"color-ramp":{"type":"property-type"},"data-constant":{"type":"property-type"},"constant":{"type":"property-type"}},"promoteId":{"*":{"type":"string"}}}; + +// +function isExpressionFilter(filter) { + if (filter === true || filter === false) { + return true; + } + if (!Array.isArray(filter) || filter.length === 0) { + return false; + } + switch (filter[0]) { + case 'has': + return filter.length >= 2 && filter[1] !== '$id' && filter[1] !== '$type'; + case 'in': + return filter.length >= 3 && (typeof filter[1] !== 'string' || Array.isArray(filter[2])); + case '!in': + case '!has': + case 'none': + return false; + case '==': + case '!=': + case '>': + case '>=': + case '<': + case '<=': + return filter.length !== 3 || (Array.isArray(filter[1]) || Array.isArray(filter[2])); + case 'any': + case 'all': + for (const f of filter.slice(1)) { + if (!isExpressionFilter(f) && typeof f !== 'boolean') { + return false; + } + } + return true; + default: + return true; + } +} +/** + * Given a filter expressed as nested arrays, return a new function + * that evaluates whether a given feature (with a .properties or .tags property) + * passes its test. + * + * @private + * @param {Array} filter mapbox gl filter + * @param {string} layerType the type of the layer this filter will be applied to. + * @returns {Function} filter-evaluating function + */ +function createFilter(filter, layerType = 'fill') { + if (filter === null || filter === undefined) { + return { + filter: () => true, + needGeometry: false, + needFeature: false + }; + } + if (!isExpressionFilter(filter)) { + filter = convertFilter(filter); + } + const filterExp = filter; + let staticFilter = true; + try { + staticFilter = extractStaticFilter(filterExp); + } catch (e) { + console.warn(`Failed to extract static filter. Filter will continue working, but at higher memory usage and slower framerate. +This is most likely a bug, please report this via https://github.com/mapbox/mapbox-gl-js/issues/new?assignees=&labels=&template=Bug_report.md +and paste the contents of this message in the report. +Thank you! +Filter Expression: +${ JSON.stringify(filterExp, null, 2) } + `); + } + // Compile the static component of the filter + const filterSpec = spec[`filter_${ layerType }`]; + const compiledStaticFilter = createExpression(staticFilter, filterSpec); + let filterFunc = null; + if (compiledStaticFilter.result === 'error') { + throw new Error(compiledStaticFilter.value.map(err => `${ err.key }: ${ err.message }`).join(', ')); + } else { + filterFunc = (globalProperties, feature, canonical) => compiledStaticFilter.value.evaluate(globalProperties, feature, {}, canonical); + } + // If the static component is not equal to the entire filter then we have a dynamic component + // Compile the dynamic component separately + let dynamicFilterFunc = null; + let needFeature = null; + if (staticFilter !== filterExp) { + const compiledDynamicFilter = createExpression(filterExp, filterSpec); + if (compiledDynamicFilter.result === 'error') { + throw new Error(compiledDynamicFilter.value.map(err => `${ err.key }: ${ err.message }`).join(', ')); + } else { + dynamicFilterFunc = (globalProperties, feature, canonical, featureTileCoord, featureDistanceData) => compiledDynamicFilter.value.evaluate(globalProperties, feature, {}, canonical, undefined, undefined, featureTileCoord, featureDistanceData); + needFeature = !isFeatureConstant(compiledDynamicFilter.value.expression); + } + } + filterFunc = filterFunc; + const needGeometry = geometryNeeded(staticFilter); + return { + filter: filterFunc, + dynamicFilter: dynamicFilterFunc ? dynamicFilterFunc : undefined, + needGeometry, + needFeature: !!needFeature + }; +} +function extractStaticFilter(filter) { + if (!isDynamicFilter(filter)) { + return filter; + } + // Shallow copy so we can replace expressions in-place + let result = deepUnbundle(filter); + // 1. Union branches + unionDynamicBranches(result); + // 2. Collapse dynamic conditions to `true` + result = collapseDynamicBooleanExpressions(result); + return result; +} +function collapseDynamicBooleanExpressions(expression) { + if (!Array.isArray(expression)) { + return expression; + } + const collapsed = collapsedExpression(expression); + if (collapsed === true) { + return collapsed; + } else { + return collapsed.map(subExpression => collapseDynamicBooleanExpressions(subExpression)); + } +} +/** + * Traverses the expression and replaces all instances of branching on a + * `dynamic` conditional (such as `['pitch']` or `['distance-from-center']`) + * into an `any` expression. + * This ensures that all possible outcomes of a `dynamic` branch are considered + * when evaluating the expression upfront during filtering. + * + * @param {Array} filter the filter expression mutated in-place. + */ +function unionDynamicBranches(filter) { + let isBranchingDynamically = false; + const branches = []; + if (filter[0] === 'case') { + for (let i = 1; i < filter.length - 1; i += 2) { + isBranchingDynamically = isBranchingDynamically || isDynamicFilter(filter[i]); + branches.push(filter[i + 1]); + } + branches.push(filter[filter.length - 1]); + } else if (filter[0] === 'match') { + isBranchingDynamically = isBranchingDynamically || isDynamicFilter(filter[1]); + for (let i = 2; i < filter.length - 1; i += 2) { + branches.push(filter[i + 1]); + } + branches.push(filter[filter.length - 1]); + } else if (filter[0] === 'step') { + isBranchingDynamically = isBranchingDynamically || isDynamicFilter(filter[1]); + for (let i = 1; i < filter.length - 1; i += 2) { + branches.push(filter[i + 1]); + } + } + if (isBranchingDynamically) { + filter.length = 0; + filter.push('any', ...branches); + } + // traverse and recurse into children + for (let i = 1; i < filter.length; i++) { + unionDynamicBranches(filter[i]); + } +} +function isDynamicFilter(filter) { + // Base Cases + if (!Array.isArray(filter)) { + return false; + } + if (isRootExpressionDynamic(filter[0])) { + return true; + } + for (let i = 1; i < filter.length; i++) { + const child = filter[i]; + if (isDynamicFilter(child)) { + return true; + } + } + return false; +} +function isRootExpressionDynamic(expression) { + return expression === 'pitch' || expression === 'distance-from-center'; +} +const dynamicConditionExpressions = new Set([ + 'in', + '==', + '!=', + '>', + '>=', + '<', + '<=', + 'to-boolean' +]); +function collapsedExpression(expression) { + if (dynamicConditionExpressions.has(expression[0])) { + for (let i = 1; i < expression.length; i++) { + const param = expression[i]; + if (isDynamicFilter(param)) { + return true; + } + } + } + return expression; +} +// Comparison function to sort numbers and strings +function compare(a, b) { + return a < b ? -1 : a > b ? 1 : 0; +} +function geometryNeeded(filter) { + if (!Array.isArray(filter)) + return false; + if (filter[0] === 'within') + return true; + for (let index = 1; index < filter.length; index++) { + if (geometryNeeded(filter[index])) + return true; + } + return false; +} +function convertFilter(filter) { + if (!filter) + return true; + const op = filter[0]; + if (filter.length <= 1) + return op !== 'any'; + const converted = op === '==' ? convertComparisonOp(filter[1], filter[2], '==') : op === '!=' ? convertNegation(convertComparisonOp(filter[1], filter[2], '==')) : op === '<' || op === '>' || op === '<=' || op === '>=' ? convertComparisonOp(filter[1], filter[2], op) : op === 'any' ? convertDisjunctionOp(filter.slice(1)) : op === 'all' ? ['all'].concat(filter.slice(1).map(convertFilter)) : op === 'none' ? ['all'].concat(filter.slice(1).map(convertFilter).map(convertNegation)) : op === 'in' ? convertInOp(filter[1], filter.slice(2)) : op === '!in' ? convertNegation(convertInOp(filter[1], filter.slice(2))) : op === 'has' ? convertHasOp(filter[1]) : op === '!has' ? convertNegation(convertHasOp(filter[1])) : op === 'within' ? filter : true; + return converted; +} +function convertComparisonOp(property, value, op) { + switch (property) { + case '$type': + return [ + `filter-type-${ op }`, + value + ]; + case '$id': + return [ + `filter-id-${ op }`, + value + ]; + default: + return [ + `filter-${ op }`, + property, + value + ]; + } +} +function convertDisjunctionOp(filters) { + return ['any'].concat(filters.map(convertFilter)); +} +function convertInOp(property, values) { + if (values.length === 0) { + return false; + } + switch (property) { + case '$type': + return [ + `filter-type-in`, + [ + 'literal', + values + ] + ]; + case '$id': + return [ + `filter-id-in`, + [ + 'literal', + values + ] + ]; + default: + if (values.length > 200 && !values.some(v => typeof v !== typeof values[0])) { + return [ + 'filter-in-large', + property, + [ + 'literal', + values.sort(compare) + ] + ]; + } else { + return [ + 'filter-in-small', + property, + [ + 'literal', + values + ] + ]; + } + } +} +function convertHasOp(property) { + switch (property) { + case '$type': + return true; + case '$id': + return [`filter-has-id`]; + default: + return [ + `filter-has`, + property + ]; + } +} +function convertNegation(filter) { + return [ + '!', + filter + ]; +} + +// +var refProperties = [ + 'type', + 'source', + 'source-layer', + 'minzoom', + 'maxzoom', + 'filter', + 'layout' +]; + +// +function deref(layer, parent) { + const result = {}; + for (const k in layer) { + if (k !== 'ref') { + result[k] = layer[k]; + } + } + refProperties.forEach(k => { + if (k in parent) { + result[k] = parent[k]; + } + }); + return result; +} +/** + * Given an array of layers, some of which may contain `ref` properties + * whose value is the `id` of another property, return a new array where + * such layers have been augmented with the 'type', 'source', etc. properties + * from the parent layer, and the `ref` property has been removed. + * + * The input is not modified. The output may contain references to portions + * of the input. + * + * @private + * @param {Array} layers + * @returns {Array} + */ +function derefLayers(layers) { + layers = layers.slice(); + const map = Object.create(null); + for (let i = 0; i < layers.length; i++) { + map[layers[i].id] = layers[i]; + } + for (let i = 0; i < layers.length; i++) { + if ('ref' in layers[i]) { + layers[i] = deref(layers[i], map[layers[i].ref]); + } + } + return layers; +} + +var fontWeights = { + thin: 100, + hairline: 100, + 'ultra-light': 200, + 'extra-light': 200, + light: 300, + book: 300, + regular: 400, + normal: 400, + plain: 400, + roman: 400, + standard: 400, + medium: 500, + 'semi-bold': 600, + 'demi-bold': 600, + bold: 700, + 'extra-bold': 800, + 'ultra-bold': 800, + heavy: 900, + black: 900, + 'heavy-black': 900, + fat: 900, + poster: 900, + 'ultra-black': 950, + 'extra-black': 950 +}; +var sp = ' '; +var italicRE = /(italic|oblique)$/i; +var fontCache = {}; +var mapboxToCssFont = function (fonts, size, lineHeight) { + var cssData = fontCache[fonts]; + if (!cssData) { + if (!Array.isArray(fonts)) { + fonts = [fonts]; + } + var weight = 400; + var style = 'normal'; + var fontFamilies = []; + var haveWeight, haveStyle; + for (var i = 0, ii = fonts.length; i < ii; ++i) { + var font = fonts[i]; + var parts = font.split(' '); + var maybeWeight = parts[parts.length - 1].toLowerCase(); + if (maybeWeight == 'normal' || maybeWeight == 'italic' || maybeWeight == 'oblique') { + style = haveStyle ? style : maybeWeight; + haveStyle = true; + parts.pop(); + maybeWeight = parts[parts.length - 1].toLowerCase(); + } else if (italicRE.test(maybeWeight)) { + maybeWeight = maybeWeight.replace(italicRE, ''); + style = haveStyle ? style : parts[parts.length - 1].replace(maybeWeight, ''); + haveStyle = true; + } + for (var w in fontWeights) { + var previousPart = parts.length > 1 ? parts[parts.length - 2].toLowerCase() : ''; + if (maybeWeight == w || maybeWeight == w.replace('-', '') || previousPart + '-' + maybeWeight == w) { + weight = haveWeight ? weight : fontWeights[w]; + parts.pop(); + if (previousPart && w.startsWith(previousPart)) { + parts.pop(); + } + break; + } + } + if (!haveWeight && typeof maybeWeight == 'number') { + weight = maybeWeight; + haveWeight = true; + } + var fontFamily = parts.join(sp).replace('Klokantech Noto Sans', 'Noto Sans'); + if (fontFamily.indexOf(sp) !== -1) { + fontFamily = '"' + fontFamily + '"'; + } + fontFamilies.push(fontFamily); + } + // CSS font property: font-style font-weight font-size/line-height font-family + cssData = fontCache[fonts] = [ + style, + weight, + fontFamilies + ]; + } + return cssData[0] + sp + cssData[1] + sp + size + 'px' + (lineHeight ? '/' + lineHeight : '') + sp + cssData[2]; +}; + +var mb2css = /*@__PURE__*/getDefaultExportFromCjs(mapboxToCssFont); + +const mapboxBaseUrl = 'https://api.mapbox.com'; +/** + * Gets the path from a mapbox:// URL. + * @param {string} url The Mapbox URL. + * @return {string} The path. + * @private + */ +function getMapboxPath(url) { + const startsWith = 'mapbox://'; + if (url.indexOf(startsWith) !== 0) { + return ''; + } + return url.slice(startsWith.length); +} +/** + * Turns mapbox:// sprite URLs into resolvable URLs. + * @param {string} url The sprite URL. + * @param {string} token The access token. + * @param {string} styleUrl The style URL. + * @return {string} A resolvable URL. + * @private + */ +function normalizeSpriteUrl(url, token, styleUrl) { + const mapboxPath = getMapboxPath(url); + if (!mapboxPath) { + return decodeURI(new URL(url, styleUrl).href); + } + const startsWith = 'sprites/'; + if (mapboxPath.indexOf(startsWith) !== 0) { + throw new Error(`unexpected sprites url: ${ url }`); + } + const sprite = mapboxPath.slice(startsWith.length); + return `${ mapboxBaseUrl }/styles/v1/${ sprite }/sprite?access_token=${ token }`; +} +/** + * Turns mapbox:// style URLs into resolvable URLs. + * @param {string} url The style URL. + * @param {string} token The access token. + * @return {string} A resolvable URL. + * @private + */ +function normalizeStyleUrl(url, token) { + const mapboxPath = getMapboxPath(url); + if (!mapboxPath) { + return decodeURI(new URL(url, location.href).href); + } + const startsWith = 'styles/'; + if (mapboxPath.indexOf(startsWith) !== 0) { + throw new Error(`unexpected style url: ${ url }`); + } + const style = mapboxPath.slice(startsWith.length); + return `${ mapboxBaseUrl }/styles/v1/${ style }?&access_token=${ token }`; +} +const mapboxSubdomains = [ + 'a', + 'b', + 'c', + 'd' +]; +/** + * Turns mapbox:// source URLs into vector tile URL templates. + * @param {string} url The source URL. + * @param {string} token The access token. + * @param {string} tokenParam The access token key. + * @param {string} styleUrl The style URL. + * @return {Array} A vector tile template. + * @private + */ +function normalizeSourceUrl(url, token, tokenParam, styleUrl) { + const urlObject = new URL(url, styleUrl); + const mapboxPath = getMapboxPath(url); + if (!mapboxPath) { + if (!token) { + return [decodeURI(urlObject.href)]; + } + if (!urlObject.searchParams.has(tokenParam)) { + urlObject.searchParams.set(tokenParam, token); + } + return [decodeURI(urlObject.href)]; + } + if (mapboxPath === 'mapbox.satellite') { + const sizeFactor = window.devicePixelRatio >= 1.5 ? '@2x' : ''; + return [`https://api.mapbox.com/v4/${ mapboxPath }/{z}/{x}/{y}${ sizeFactor }.webp?access_token=${ token }`]; + } + return mapboxSubdomains.map(sub => `https://${ sub }.tiles.mapbox.com/v4/${ mapboxPath }/{z}/{x}/{y}.vector.pbf?access_token=${ token }`); +} + +/** @typedef {'Style'|'Source'|'Sprite'|'SpriteImage'|'Tiles'|'GeoJSON'} ResourceType */ +/** @typedef {import("ol").Map} Map */ +/** @typedef {import("ol/layer").Layer} Layer */ +/** @typedef {import("ol/layer").Group} LayerGroup */ +/** @typedef {import("ol/layer").Vector} VectorLayer */ +/** @typedef {import("ol/layer").VectorTile} VectorTileLayer */ +/** @typedef {import("ol/source").Source} Source */ +const functionCacheByStyleId = {}; +const filterCacheByStyleId = {}; +let styleId = 0; +function getStyleId(glStyle) { + if (!glStyle.id) { + glStyle.id = styleId++; + } + return glStyle.id; +} +function getStyleFunctionKey(glStyle, olLayer) { + return getStyleId(glStyle) + '.' + getUid(olLayer); +} +/** + * @param {Object} glStyle Mapboox style object. + * @return {Object} Function cache. + */ +function getFunctionCache(glStyle) { + let functionCache = functionCacheByStyleId[glStyle.id]; + if (!functionCache) { + functionCache = {}; + functionCacheByStyleId[getStyleId(glStyle)] = functionCache; + } + return functionCache; +} +function clearFunctionCache() { + for (const key in functionCacheByStyleId) { + delete functionCacheByStyleId[key]; + } +} +/** + * @param {Object} glStyle Mapboox style object. + * @return {Object} Filter cache. + */ +function getFilterCache(glStyle) { + let filterCache = filterCacheByStyleId[glStyle.id]; + if (!filterCache) { + filterCache = {}; + filterCacheByStyleId[getStyleId(glStyle)] = filterCache; + } + return filterCache; +} +function deg2rad(degrees) { + return degrees * Math.PI / 180; +} +const defaultResolutions = (function () { + const resolutions = []; + for (let res = 78271.51696402048; resolutions.length <= 24; res /= 2) { + resolutions.push(res); + } + return resolutions; +}()); +/** + * @param {number} width Width of the canvas. + * @param {number} height Height of the canvas. + * @return {HTMLCanvasElement} Canvas. + */ +function createCanvas(width, height) { + if (typeof WorkerGlobalScope !== 'undefined' && self instanceof WorkerGlobalScope && typeof OffscreenCanvas !== 'undefined') { + // eslint-disable-line + return new OffscreenCanvas(width, height); + } + const canvas = document.createElement('canvas'); + canvas.width = width; + canvas.height = height; + return canvas; +} +function getZoomForResolution(resolution, resolutions) { + let i = 0; + const ii = resolutions.length; + for (; i < ii; ++i) { + const candidate = resolutions[i]; + if (candidate < resolution && i + 1 < ii) { + const zoomFactor = resolutions[i] / resolutions[i + 1]; + return i + Math.log(resolutions[i] / resolution) / Math.log(zoomFactor); + } + } + return ii - 1; +} +function getResolutionForZoom(zoom, resolutions) { + const base = Math.floor(zoom); + const factor = Math.pow(2, zoom - base); + return resolutions[base] / factor; +} +const pendingRequests = {}; +/** + * @param {ResourceType} resourceType Type of resource to load. + * @param {string} url Url of the resource. + * @param {Options} [options={}] Options. + * @param {{request?: Request}} [metadata] Object to be filled with the request. + * @return {Promise} Promise that resolves with the loaded resource + * or rejects with the Response object. + * @private + */ +function fetchResource(resourceType, url, options = {}, metadata) { + if (url in pendingRequests) { + if (metadata) { + metadata.request = pendingRequests[url][0]; + } + return pendingRequests[url][1]; + } + const transformedRequest = options.transformRequest ? options.transformRequest(url, resourceType) || url : url; + const pendingRequest = toPromise(() => transformedRequest).then(transformedRequest => { + if (!(transformedRequest instanceof Request)) { + transformedRequest = new Request(transformedRequest); + } + if (!transformedRequest.headers.get('Accept')) { + transformedRequest.headers.set('Accept', 'application/json'); + } + if (metadata) { + metadata.request = transformedRequest; + } + return fetch(transformedRequest).then(function (response) { + delete pendingRequests[url]; + return response.ok ? response.json() : Promise.reject(new Error('Error fetching source ' + url)); + }).catch(function (error) { + delete pendingRequests[url]; + return Promise.reject(new Error('Error fetching source ' + url)); + }); + }); + pendingRequests[url] = [ + transformedRequest, + pendingRequest + ]; + return pendingRequest; +} +function getGlStyle(glStyleOrUrl, options) { + if (typeof glStyleOrUrl === 'string') { + if (glStyleOrUrl.trim().startsWith('{')) { + try { + const glStyle = JSON.parse(glStyleOrUrl); + return Promise.resolve(glStyle); + } catch (error) { + return Promise.reject(error); + } + } else { + glStyleOrUrl = normalizeStyleUrl(glStyleOrUrl, options.accessToken); + return fetchResource('Style', glStyleOrUrl, options); + } + } else { + return Promise.resolve(glStyleOrUrl); + } +} +const tilejsonCache = {}; +/** + * @param {Object} glSource glStyle source object. + * @param {string} styleUrl Style URL. + * @param {Options} options Options. + * @return {Promise<{tileJson: Object, tileLoadFunction: import('ol/Tile.js').LoadFunction}?>} TileJson and load function + */ +function getTileJson(glSource, styleUrl, options = {}) { + const cacheKey = [ + styleUrl, + JSON.stringify(glSource) + ].toString(); + let promise = tilejsonCache[cacheKey]; + if (!promise || options.transformRequest) { + let tileLoadFunction; + if (options.transformRequest) { + tileLoadFunction = (tile, src) => { + const transformedRequest = options.transformRequest ? options.transformRequest(src, 'Tiles') || src : src; + if (tile instanceof VectorTile) { + tile.setLoader((extent, resolution, projection) => { + toPromise(() => transformedRequest).then(transformedRequest => { + fetch(transformedRequest).then(response => response.arrayBuffer()).then(data => { + const format = tile.getFormat(); + const features = format.readFeatures(data, { + extent: extent, + featureProjection: projection + }); + // @ts-ignore + tile.setFeatures(features); + }).catch(e => tile.setState(TileState.ERROR)); + }); + }); + } else { + const img = tile.getImage(); + toPromise(() => transformedRequest).then(transformedRequest => { + if (transformedRequest instanceof Request) { + fetch(transformedRequest).then(response => response.blob()).then(blob => { + const url = URL.createObjectURL(blob); + img.addEventListener('load', () => URL.revokeObjectURL(url)); + img.addEventListener('error', () => URL.revokeObjectURL(url)); + img.src = url; + }).catch(e => tile.setState(TileState.ERROR)); + } else { + img.src = transformedRequest; + } + }); + } + }; + } + const url = glSource.url; + if (url && !glSource.tiles) { + const normalizedSourceUrl = normalizeSourceUrl(url, options.accessToken, options.accessTokenParam || 'access_token', styleUrl || location.href); + if (url.startsWith('mapbox://')) { + promise = Promise.resolve({ + tileJson: Object.assign({}, glSource, { + url: undefined, + tiles: normalizedSourceUrl + }), + tileLoadFunction + }); + } else { + const metadata = {}; + promise = fetchResource('Source', normalizedSourceUrl[0], options, metadata).then(function (tileJson) { + tileJson.tiles = tileJson.tiles.map(function (tileUrl) { + if (tileJson.scheme === 'tms') { + tileUrl = tileUrl.replace('{y}', '{-y}'); + } + return normalizeSourceUrl(tileUrl, options.accessToken, options.accessTokenParam || 'access_token', metadata.request.url)[0]; + }); + return Promise.resolve({ + tileJson, + tileLoadFunction + }); + }); + } + } else { + glSource = Object.assign({}, glSource, { + tiles: glSource.tiles.map(function (tileUrl) { + if (glSource.scheme === 'tms') { + tileUrl = tileUrl.replace('{y}', '{-y}'); + } + return normalizeSourceUrl(tileUrl, options.accessToken, options.accessTokenParam || 'access_token', styleUrl || location.href)[0]; + }) + }); + promise = Promise.resolve({ + tileJson: Object.assign({}, glSource), + tileLoadFunction + }); + } + tilejsonCache[cacheKey] = promise; + } + return promise; +} +/** + * @param {HTMLImageElement|HTMLCanvasElement} spriteImage Sprite image id. + * @param {{x: number, y: number, width: number, height: number, pixelRatio: number}} spriteImageData Sprite image data. + * @param {number} haloWidth Halo width. + * @param {{r: number, g: number, b: number, a: number}} haloColor Halo color. + * @return {HTMLCanvasElement} Canvas element with the halo. + */ +function drawIconHalo(spriteImage, spriteImageData, haloWidth, haloColor) { + const imgSize = [ + 2 * haloWidth * spriteImageData.pixelRatio + spriteImageData.width, + 2 * haloWidth * spriteImageData.pixelRatio + spriteImageData.height + ]; + const imageCanvas = createCanvas(imgSize[0], imgSize[1]); + const imageContext = imageCanvas.getContext('2d'); + imageContext.drawImage(spriteImage, spriteImageData.x, spriteImageData.y, spriteImageData.width, spriteImageData.height, haloWidth * spriteImageData.pixelRatio, haloWidth * spriteImageData.pixelRatio, spriteImageData.width, spriteImageData.height); + const imageData = imageContext.getImageData(0, 0, imgSize[0], imgSize[1]); + imageContext.globalCompositeOperation = 'destination-over'; + imageContext.fillStyle = `rgba(${ haloColor.r * 255 },${ haloColor.g * 255 },${ haloColor.b * 255 },${ haloColor.a })`; + const data = imageData.data; + for (let i = 0, ii = imageData.width; i < ii; ++i) { + for (let j = 0, jj = imageData.height; j < jj; ++j) { + const index = (j * ii + i) * 4; + const alpha = data[index + 3]; + if (alpha > 0) { + imageContext.arc(i, j, haloWidth * spriteImageData.pixelRatio, 0, 2 * Math.PI); + } + } + } + imageContext.fill(); + return imageCanvas; +} +function smoothstep(min, max, value) { + const x = Math.max(0, Math.min(1, (value - min) / (max - min))); + return x * x * (3 - 2 * x); +} +/** + * @param {HTMLImageElement} image SDF image + * @param {{x: number, y: number, width: number, height: number}} area Area to unSDF + * @param {{r: number, g: number, b: number, a: number}} color Color to use + * @return {HTMLCanvasElement} Regular image + */ +function drawSDF(image, area, color) { + const imageCanvas = createCanvas(area.width, area.height); + const imageContext = imageCanvas.getContext('2d'); + imageContext.drawImage(image, area.x, area.y, area.width, area.height, 0, 0, area.width, area.height); + const imageData = imageContext.getImageData(0, 0, area.width, area.height); + const data = imageData.data; + for (let i = 0, ii = imageData.width; i < ii; ++i) { + for (let j = 0, jj = imageData.height; j < jj; ++j) { + const index = (j * ii + i) * 4; + const dist = data[index + 3] / 255; + const buffer = 0.75; + const gamma = 0.1; + const alpha = smoothstep(buffer - gamma, buffer + gamma, dist); + if (alpha > 0) { + data[index + 0] = Math.round(255 * color.r * alpha); + data[index + 1] = Math.round(255 * color.g * alpha); + data[index + 2] = Math.round(255 * color.b * alpha); + data[index + 3] = Math.round(255 * alpha); + } else { + data[index + 3] = 0; + } + } + } + imageContext.putImageData(imageData, 0, 0); + return imageCanvas; +} /** + * @typedef {import("./apply.js").Options} Options + * @private + */ + +const hairSpacePool = Array(256).join('\u200A'); +function applyLetterSpacing(text, letterSpacing) { + if (letterSpacing >= 0.05) { + let textWithLetterSpacing = ''; + const lines = text.split('\n'); + const joinSpaceString = hairSpacePool.slice(0, Math.round(letterSpacing / 0.1)); + for (let l = 0, ll = lines.length; l < ll; ++l) { + if (l > 0) { + textWithLetterSpacing += '\n'; + } + textWithLetterSpacing += lines[l].split('').join(joinSpaceString); + } + return textWithLetterSpacing; + } + return text; +} +let measureContext; +function getMeasureContext() { + if (!measureContext) { + measureContext = createCanvas(1, 1).getContext('2d'); + } + return measureContext; +} +function measureText(text, letterSpacing) { + return getMeasureContext().measureText(text).width + (text.length - 1) * letterSpacing; +} +const measureCache = {}; +function wrapText(text, font, em, letterSpacing) { + if (text.indexOf('\n') !== -1) { + const hardLines = text.split('\n'); + const lines = []; + for (let i = 0, ii = hardLines.length; i < ii; ++i) { + lines.push(wrapText(hardLines[i], font, em, letterSpacing)); + } + return lines.join('\n'); + } + const key = em + ',' + font + ',' + text + ',' + letterSpacing; + let wrappedText = measureCache[key]; + if (!wrappedText) { + const words = text.split(' '); + if (words.length > 1) { + const ctx = getMeasureContext(); + ctx.font = font; + const oneEm = ctx.measureText('M').width; + const maxWidth = oneEm * em; + let line = ''; + const lines = []; + // Pass 1 - wrap lines to not exceed maxWidth + for (let i = 0, ii = words.length; i < ii; ++i) { + const word = words[i]; + const testLine = line + (line ? ' ' : '') + word; + if (measureText(testLine, letterSpacing) <= maxWidth) { + line = testLine; + } else { + if (line) { + lines.push(line); + } + line = word; + } + } + if (line) { + lines.push(line); + } + // Pass 2 - add lines with a width of less than 30% of maxWidth to the previous or next line + for (let i = 0, ii = lines.length; i < ii && ii > 1; ++i) { + const line = lines[i]; + if (measureText(line, letterSpacing) < maxWidth * 0.35) { + const prevWidth = i > 0 ? measureText(lines[i - 1], letterSpacing) : Infinity; + const nextWidth = i < ii - 1 ? measureText(lines[i + 1], letterSpacing) : Infinity; + lines.splice(i, 1); + ii -= 1; + if (prevWidth < nextWidth) { + lines[i - 1] += ' ' + line; + i -= 1; + } else { + lines[i] = line + ' ' + lines[i]; + } + } + } + // Pass 3 - try to fill 80% of maxWidth for each line + for (let i = 0, ii = lines.length - 1; i < ii; ++i) { + const line = lines[i]; + const next = lines[i + 1]; + if (measureText(line, letterSpacing) > maxWidth * 0.7 && measureText(next, letterSpacing) < maxWidth * 0.6) { + const lineWords = line.split(' '); + const lastWord = lineWords.pop(); + if (measureText(lastWord, letterSpacing) < maxWidth * 0.2) { + lines[i] = lineWords.join(' '); + lines[i + 1] = lastWord + ' ' + next; + } + ii -= 1; + } + } + wrappedText = lines.join('\n'); + } else { + wrappedText = text; + } + wrappedText = applyLetterSpacing(wrappedText, letterSpacing); + measureCache[key] = wrappedText; + } + return wrappedText; +} +const fontFamilyRegEx = /font-family: ?([^;]*);/; +const stripQuotesRegEx = /("|')/g; +let loadedFontFamilies; +function hasFontFamily(family) { + if (!loadedFontFamilies) { + loadedFontFamilies = {}; + const styleSheets = document.styleSheets; + for (let i = 0, ii = styleSheets.length; i < ii; ++i) { + const styleSheet = styleSheets[i]; + try { + const cssRules = styleSheet.rules || styleSheet.cssRules; + if (cssRules) { + for (let j = 0, jj = cssRules.length; j < jj; ++j) { + const cssRule = cssRules[j]; + if (cssRule.type == 5) { + const match = cssRule.cssText.match(fontFamilyRegEx); + loadedFontFamilies[match[1].replace(stripQuotesRegEx, '')] = true; + } + } + } + } catch (e) { + } + } + } + return family in loadedFontFamilies; +} +const processedFontFamilies = {}; +/** + * @param {Array} fonts Fonts. + * @param {string} [templateUrl] Template URL. + * @return {Array} Processed fonts. + * @private + */ +function getFonts(fonts, templateUrl = 'https://cdn.jsdelivr.net/npm/@fontsource/{font-family}/{fontweight}{-fontstyle}.css') { + const fontsKey = fonts.toString(); + if (fontsKey in processedFontFamilies) { + return processedFontFamilies[fontsKey]; + } + const fontDescriptions = []; + for (let i = 0, ii = fonts.length; i < ii; ++i) { + fonts[i] = fonts[i].replace('Arial Unicode MS', 'Arial'); + const font = fonts[i]; + const cssFont = mb2css(font, 1); + registerFont(cssFont); + const parts = cssFont.split(' '); + fontDescriptions.push([ + parts.slice(3).join(' ').replace(/"/g, ''), + parts[1], + parts[0] + ]); + } + for (let i = 0, ii = fontDescriptions.length; i < ii; ++i) { + const fontDescription = fontDescriptions[i]; + const family = fontDescription[0]; + if (!hasFontFamily(family)) { + if (checkedFonts.get(`${ fontDescription[2] }\n${ fontDescription[1] } \n${ family }`) !== 100) { + const fontUrl = templateUrl.replace('{font-family}', family.replace(/ /g, '-').toLowerCase()).replace('{Font+Family}', family.replace(/ /g, '+')).replace('{fontweight}', fontDescription[1]).replace('{-fontstyle}', fontDescription[2].replace('normal', '').replace(/(.+)/, '-$1')).replace('{fontstyle}', fontDescription[2]); + if (!document.querySelector('link[href="' + fontUrl + '"]')) { + const markup = document.createElement('link'); + markup.href = fontUrl; + markup.rel = 'stylesheet'; + document.head.appendChild(markup); + } + } + } + } + processedFontFamilies[fontsKey] = fonts; + return fonts; +} + +/* +ol-mapbox-style - Use Mapbox/MapLibre Style objects with OpenLayers +Copyright 2016-present ol-mapbox-style contributors +License: https://raw.githubusercontent.com/openlayers/ol-mapbox-style/master/LICENSE +*/ +/** + * @typedef {import("ol/layer/Vector").default} VectorLayer + * @typedef {import("ol/layer/VectorTile").default} VectorTileLayer + * @typedef {import("ol/style/Style").StyleFunction} StyleFunction + * @typedef {import('./util.js').ResourceType} ResourceType + */ +const types = { + 'Point': 1, + 'MultiPoint': 1, + 'LineString': 2, + 'MultiLineString': 2, + 'Polygon': 3, + 'MultiPolygon': 3 +}; +const anchor = { + 'center': [ + 0.5, + 0.5 + ], + 'left': [ + 0, + 0.5 + ], + 'right': [ + 1, + 0.5 + ], + 'top': [ + 0.5, + 0 + ], + 'bottom': [ + 0.5, + 1 + ], + 'top-left': [ + 0, + 0 + ], + 'top-right': [ + 1, + 0 + ], + 'bottom-left': [ + 0, + 1 + ], + 'bottom-right': [ + 1, + 1 + ] +}; +const expressionData = function (rawExpression, propertySpec) { + const compiledExpression = createPropertyExpression(rawExpression, propertySpec); + if (compiledExpression.result === 'error') { + throw new Error(compiledExpression.value.map(err => `${ err.key }: ${ err.message }`).join(', ')); + } + return compiledExpression.value; +}; +const emptyObj$1 = {}; +const zoomObj = { zoom: 0 }; +let renderFeatureCoordinates, renderFeature; +/** + * @private + * @param {Object} layer Gl object layer. + * @param {string} layoutOrPaint 'layout' or 'paint'. + * @param {string} property Feature property. + * @param {number} zoom Zoom. + * @param {Object} feature Gl feature. + * @param {Object} [functionCache] Function cache. + * @param {Object} [featureState] Feature state. + * @return {?} Value. + */ +function getValue(layer, layoutOrPaint, property, zoom, feature, functionCache, featureState) { + const layerId = layer.id; + if (!functionCache) { + functionCache = {}; + console.warn('No functionCache provided to getValue()'); //eslint-disable-line no-console + } + if (!functionCache[layerId]) { + functionCache[layerId] = {}; + } + const functions = functionCache[layerId]; + if (!functions[property]) { + let value = (layer[layoutOrPaint] || emptyObj$1)[property]; + const propertySpec = spec[`${ layoutOrPaint }_${ layer.type }`][property]; + if (value === undefined) { + value = propertySpec.default; + } + let isExpr = isExpression(value); + if (!isExpr && isFunction(value)) { + value = convertFunction(value, propertySpec); + isExpr = true; + } + if (isExpr) { + const compiledExpression = expressionData(value, propertySpec); + functions[property] = compiledExpression.evaluate.bind(compiledExpression); + } else { + if (propertySpec.type == 'color') { + value = Color$1.parse(value); + } + functions[property] = function () { + return value; + }; + } + } + zoomObj.zoom = zoom; + return functions[property](zoomObj, feature, featureState); +} +/** + * @private + * @param {Object} layer Gl object layer. + * @param {number} zoom Zoom. + * @param {Object} feature Gl feature. + * @param {"icon"|"text"} prefix Style property prefix. + * @param {Object} [functionCache] Function cache. + * @return {"declutter"|"obstacle"|"none"} Value. + */ +function getDeclutterMode(layer, zoom, feature, prefix, functionCache) { + const allowOverlap = getValue(layer, 'layout', `${ prefix }-allow-overlap`, zoom, feature, functionCache); + if (!allowOverlap) { + return 'declutter'; + } + const ignorePlacement = getValue(layer, 'layout', `${ prefix }-ignore-placement`, zoom, feature, functionCache); + if (!ignorePlacement) { + return 'obstacle'; + } + return 'none'; +} +/** + * @private + * @param {string} layerId Layer id. + * @param {?} filter Filter. + * @param {Object} feature Feature. + * @param {number} zoom Zoom. + * @param {Object} [filterCache] Filter cache. + * @return {boolean} Filter result. + */ +function evaluateFilter(layerId, filter, feature, zoom, filterCache) { + if (!filterCache) { + console.warn('No filterCache provided to evaluateFilter()'); //eslint-disable-line no-console + } + if (!(layerId in filterCache)) { + filterCache[layerId] = createFilter(filter).filter; + } + zoomObj.zoom = zoom; + return filterCache[layerId](zoomObj, feature); +} +let renderTransparentEnabled = false; +/** + * Configure whether features with a transparent style should be rendered. When + * set to `true`, it will be possible to hit detect content that is not visible, + * like transparent fills of polygons, using `ol/layer/Layer#getFeatures()` or + * `ol/Map#getFeaturesAtPixel()` + * @param {boolean} enabled Rendering of transparent elements is enabled. + * Default is `false`. + */ +function renderTransparent(enabled) { + if (enabled !== renderTransparentEnabled) { + clearFunctionCache(); + renderTransparentEnabled = enabled; + } +} +/** + * @private + * @param {?} color Color. + * @param {number} [opacity] Opacity. + * @return {string} Color. + */ +function colorWithOpacity(color, opacity) { + if (color) { + if (!renderTransparentEnabled && (color.a === 0 || opacity === 0)) { + return undefined; + } + const a = color.a; + opacity = opacity === undefined ? 1 : opacity; + return a === 0 ? 'transparent' : 'rgba(' + Math.round(color.r * 255 / a) + ',' + Math.round(color.g * 255 / a) + ',' + Math.round(color.b * 255 / a) + ',' + a * opacity + ')'; + } + return color; +} +const templateRegEx = /\{[^{}}]*\}/g; +/** + * @private + * @param {string} text Text. + * @param {Object} properties Properties. + * @return {string} Text. + */ +function fromTemplate(text, properties) { + return text.replace(templateRegEx, function (match) { + return properties[match.slice(1, -1)] || ''; + }); +} +let recordLayer = false; +/** + * Turns recording of the Mapbox/MapLibre Style's `layer` on and off. When turned on, + * the layer that a rendered feature belongs to will be set as the feature's + * `mapbox-layer` property. + * @param {boolean} record Recording of the style layer is on. + */ +function recordStyleLayer(record = false) { + recordLayer = record; +} +const styleFunctionArgs = {}; +/** + * Creates a style function from the `glStyle` object for all layers that use + * the specified `source`, which needs to be a `"type": "vector"` or + * `"type": "geojson"` source and applies it to the specified OpenLayers layer. + * + * Two additional properties will be set on the provided layer: + * + * * `mapbox-source`: The `id` of the Mapbox/MapLibre Style document's source that the + * OpenLayers layer was created from. Usually `apply()` creates one + * OpenLayers layer per Mapbox/MapLibre Style source, unless the layer stack has + * layers from different sources in between. + * * `mapbox-layers`: The `id`s of the Mapbox/MapLibre Style document's layers that are + * included in the OpenLayers layer. + * + * This function also works in a web worker. In worker mode, the main thread needs + * to listen to messages from the worker and respond with another message to make + * sure that sprite image loading works: + * + * ```js + * worker.addEventListener('message', event => { + * if (event.data.action === 'loadImage') { + * const image = new Image(); + * image.crossOrigin = 'anonymous'; + * image.addEventListener('load', function() { + * createImageBitmap(image, 0, 0, image.width, image.height).then(imageBitmap => { + * worker.postMessage({ + * action: 'imageLoaded', + * image: imageBitmap, + * src: event.data.src + * }, [imageBitmap]); + * }); + * }); + * image.src = event.data.src; + * } + * }); + * ``` + * + * @param {VectorLayer|VectorTileLayer} olLayer OpenLayers layer to + * apply the style to. In addition to the style, the layer will get two + * properties: `mapbox-source` will be the `id` of the `glStyle`'s source used + * for the layer, and `mapbox-layers` will be an array of the `id`s of the + * `glStyle`'s layers. + * @param {string|Object} glStyle Mapbox/MapLibre Style object. + * @param {string|Array} sourceOrLayers `source` key or an array of layer `id`s + * from the Mapbox/MapLibre Style object. When a `source` key is provided, all layers for + * the specified source will be included in the style function. When layer `id`s + * are provided, they must be from layers that use the same source. + * @param {Array} resolutions + * Resolutions for mapping resolution to zoom level. + * @param {Object} spriteData Sprite data from the url specified in + * the Mapbox/MapLibre Style object's `sprite` property. Only required if a `sprite` + * property is specified in the Mapbox/MapLibre Style object. + * @param {string|Request|Promise} spriteImageUrl Sprite image url for the sprite + * specified in the Mapbox/MapLibre Style object's `sprite` property. Only required if a + * `sprite` property is specified in the Mapbox/MapLibre Style object. + * @param {function(Array, string=):Array} getFonts Function that + * receives a font stack and the url template from the GL style's `metadata['ol:webfonts']` + * property (if set) as arguments, and returns a (modified) font stack that + * is available. Font names are the names used in the Mapbox/MapLibre Style object. If + * not provided, the font stack will be used as-is. This function can also be + * used for loading web fonts. + * @param {function(VectorLayer|VectorTileLayer, string):HTMLImageElement|HTMLCanvasElement|string|undefined} [getImage=undefined] + * Function that returns an image or a URL for an image name. If the result is an HTMLImageElement, it must already be + * loaded. The layer can be used to call layer.changed() when the loading and processing of the image has finished. + * This function can be used for icons not in the sprite or to override sprite icons. + * @return {StyleFunction} Style function for use in + * `ol.layer.Vector` or `ol.layer.VectorTile`. + */ +function stylefunction(olLayer, glStyle, sourceOrLayers, resolutions = defaultResolutions, spriteData = undefined, spriteImageUrl = undefined, getFonts = undefined, getImage = undefined) { + if (typeof glStyle == 'string') { + glStyle = JSON.parse(glStyle); + } + if (glStyle.version != 8) { + throw new Error('glStyle version 8 required.'); + } + styleFunctionArgs[getStyleFunctionKey(glStyle, olLayer)] = Array.from(arguments); + let spriteImage, spriteImageSize; + let spriteImageUnSDFed; + if (spriteImageUrl) { + if (typeof Image !== 'undefined') { + const img = new Image(); + let blobUrl; + toPromise(() => spriteImageUrl).then(spriteImageUrl => { + if (spriteImageUrl instanceof Request) { + fetch(spriteImageUrl).then(response => response.blob()).then(blob => { + blobUrl = URL.createObjectURL(blob); + img.src = blobUrl; + }).catch(() => { + }); + } else { + img.crossOrigin = 'anonymous'; + img.src = spriteImageUrl; + if (blobUrl) { + URL.revokeObjectURL(blobUrl); + } + } + }); + img.onload = function () { + spriteImage = img; + spriteImageSize = [ + img.width, + img.height + ]; + olLayer.changed(); + img.onload = null; + }; + } else if (typeof WorkerGlobalScope !== 'undefined' && self instanceof WorkerGlobalScope) { + //eslint-disable-line + const worker = self; + // Main thread needs to handle 'loadImage' and dispatch 'imageLoaded' + worker.postMessage({ + action: 'loadImage', + src: spriteImageUrl + }); + worker.addEventListener('message', function handler(event) { + if (event.data.action === 'imageLoaded' && event.data.src === spriteImageUrl) { + spriteImage = event.data.image; + spriteImageSize = [ + spriteImage.width, + spriteImage.height + ]; + } + }); + } + } + const allLayers = derefLayers(glStyle.layers); + const layersBySourceLayer = {}; + const mapboxLayers = []; + const iconImageCache = {}; + const patternCache = {}; + const functionCache = getFunctionCache(glStyle); + const filterCache = getFilterCache(glStyle); + let mapboxSource; + for (let i = 0, ii = allLayers.length; i < ii; ++i) { + const layer = allLayers[i]; + const layerId = layer.id; + if (typeof sourceOrLayers == 'string' && layer.source == sourceOrLayers || Array.isArray(sourceOrLayers) && sourceOrLayers.indexOf(layerId) !== -1) { + const sourceLayer = layer['source-layer']; + if (!mapboxSource) { + mapboxSource = layer.source; + const source = glStyle.sources[mapboxSource]; + if (!source) { + throw new Error(`Source "${ mapboxSource }" is not defined`); + } + const type = source.type; + if (type !== 'vector' && type !== 'geojson') { + throw new Error(`Source "${ mapboxSource }" is not of type "vector" or "geojson", but "${ type }"`); + } + } else if (layer.source !== mapboxSource) { + throw new Error(`Layer "${ layerId }" does not use source "${ mapboxSource }`); + } + let layers = layersBySourceLayer[sourceLayer]; + if (!layers) { + layers = []; + layersBySourceLayer[sourceLayer] = layers; + } + layers.push({ + layer: layer, + index: i + }); + mapboxLayers.push(layerId); + } + } + const textHalo = new Stroke(); + const textColor = new Fill(); + const styles = []; + /** + * @param {import("ol/Feature").default|import("ol/render/Feature").default} feature Feature. + * @param {number} resolution Resolution. + * @param {string} [onlyLayer] Calculate style for this layer only. + * @return {Array} Style. + */ + const styleFunction = function (feature, resolution, onlyLayer) { + const properties = feature.getProperties(); + const layers = layersBySourceLayer[properties.layer]; + if (!layers) { + return undefined; + } + let zoom = resolutions.indexOf(resolution); + if (zoom == -1) { + zoom = getZoomForResolution(resolution, resolutions); + } + const type = types[feature.getGeometry().getType()]; + const f = { + id: feature.getId(), + properties: properties, + type: type + }; + const featureState = olLayer.get('mapbox-featurestate')[feature.getId()]; + let stylesLength = -1; + let featureBelongsToLayer; + for (let i = 0, ii = layers.length; i < ii; ++i) { + const layerData = layers[i]; + const layer = layerData.layer; + const layerId = layer.id; + if (onlyLayer !== undefined && onlyLayer !== layerId) { + continue; + } + const layout = layer.layout || emptyObj$1; + const paint = layer.paint || emptyObj$1; + if (layout.visibility === 'none' || 'minzoom' in layer && zoom < layer.minzoom || 'maxzoom' in layer && zoom >= layer.maxzoom) { + continue; + } + const filter = layer.filter; + if (!filter || evaluateFilter(layerId, filter, f, zoom, filterCache)) { + featureBelongsToLayer = layer; + let color, opacity, fill, stroke, strokeColor, style; + const index = layerData.index; + if (type == 3 && (layer.type == 'fill' || layer.type == 'fill-extrusion')) { + opacity = getValue(layer, 'paint', layer.type + '-opacity', zoom, f, functionCache, featureState); + if (layer.type + '-pattern' in paint) { + const fillIcon = getValue(layer, 'paint', layer.type + '-pattern', zoom, f, functionCache, featureState); + if (fillIcon) { + const icon = typeof fillIcon === 'string' ? fromTemplate(fillIcon, properties) : fillIcon.toString(); + if (spriteImage && spriteData && spriteData[icon]) { + ++stylesLength; + style = styles[stylesLength]; + if (!style || !style.getFill() || style.getStroke() || style.getText()) { + style = new Style({ fill: new Fill() }); + styles[stylesLength] = style; + } + fill = style.getFill(); + style.setZIndex(index); + const icon_cache_key = icon + '.' + opacity; + let pattern = patternCache[icon_cache_key]; + if (!pattern) { + const spriteImageData = spriteData[icon]; + const canvas = createCanvas(spriteImageData.width, spriteImageData.height); + const ctx = canvas.getContext('2d'); + ctx.globalAlpha = opacity; + ctx.drawImage(spriteImage, spriteImageData.x, spriteImageData.y, spriteImageData.width, spriteImageData.height, 0, 0, spriteImageData.width, spriteImageData.height); + pattern = ctx.createPattern(canvas, 'repeat'); + patternCache[icon_cache_key] = pattern; + } + fill.setColor(pattern); + } + } + } else { + color = colorWithOpacity(getValue(layer, 'paint', layer.type + '-color', zoom, f, functionCache, featureState), opacity); + if (layer.type + '-outline-color' in paint) { + strokeColor = colorWithOpacity(getValue(layer, 'paint', layer.type + '-outline-color', zoom, f, functionCache, featureState), opacity); + } + if (!strokeColor) { + strokeColor = color; + } + if (color || strokeColor) { + ++stylesLength; + style = styles[stylesLength]; + if (!style || color && !style.getFill() || !color && style.getFill() || strokeColor && !style.getStroke() || !strokeColor && style.getStroke() || style.getText()) { + style = new Style({ + fill: color ? new Fill() : undefined, + stroke: strokeColor ? new Stroke() : undefined + }); + styles[stylesLength] = style; + } + if (color) { + fill = style.getFill(); + fill.setColor(color); + } + if (strokeColor) { + stroke = style.getStroke(); + stroke.setColor(strokeColor); + stroke.setWidth(0.5); + } + style.setZIndex(index); + } + } + } + if (type != 1 && layer.type == 'line') { + if (!('line-pattern' in paint)) { + color = colorWithOpacity(getValue(layer, 'paint', 'line-color', zoom, f, functionCache, featureState), getValue(layer, 'paint', 'line-opacity', zoom, f, functionCache, featureState)); + } else { + color = undefined; + } + const width = getValue(layer, 'paint', 'line-width', zoom, f, functionCache, featureState); + if (color && width > 0) { + ++stylesLength; + style = styles[stylesLength]; + if (!style || !style.getStroke() || style.getFill() || style.getText()) { + style = new Style({ stroke: new Stroke() }); + styles[stylesLength] = style; + } + stroke = style.getStroke(); + stroke.setLineCap(getValue(layer, 'layout', 'line-cap', zoom, f, functionCache, featureState)); + stroke.setLineJoin(getValue(layer, 'layout', 'line-join', zoom, f, functionCache, featureState)); + stroke.setMiterLimit(getValue(layer, 'layout', 'line-miter-limit', zoom, f, functionCache, featureState)); + stroke.setColor(color); + stroke.setWidth(width); + stroke.setLineDash(paint['line-dasharray'] ? getValue(layer, 'paint', 'line-dasharray', zoom, f, functionCache, featureState).map(function (x) { + return x * width; + }) : null); + style.setZIndex(index); + } + } + let hasImage = false; + let text = null; + let placementAngle = 0; + let icon, iconImg, skipLabel; + if ((type == 1 || type == 2) && 'icon-image' in layout) { + const iconImage = getValue(layer, 'layout', 'icon-image', zoom, f, functionCache, featureState); + if (iconImage) { + icon = typeof iconImage === 'string' ? fromTemplate(iconImage, properties) : iconImage.toString(); + let styleGeom = undefined; + const imageElement = getImage ? getImage(olLayer, icon) : undefined; + if (spriteImage && spriteData && spriteData[icon] || imageElement) { + const iconRotationAlignment = getValue(layer, 'layout', 'icon-rotation-alignment', zoom, f, functionCache, featureState); + if (type == 2) { + const geom = feature.getGeometry(); + // ol package and ol-debug.js only + if (geom.getFlatMidpoint || geom.getFlatMidpoints) { + const extent = geom.getExtent(); + const size = Math.sqrt(Math.max(Math.pow((extent[2] - extent[0]) / resolution, 2), Math.pow((extent[3] - extent[1]) / resolution, 2))); + if (size > 150) { + //FIXME Do not hard-code a size of 150 + const midpoint = geom.getType() === 'MultiLineString' ? geom.getFlatMidpoints() : geom.getFlatMidpoint(); + if (!renderFeature) { + renderFeatureCoordinates = [ + NaN, + NaN + ]; + renderFeature = new RenderFeature('Point', renderFeatureCoordinates, [], 2, {}, undefined); + } + styleGeom = renderFeature; + renderFeatureCoordinates[0] = midpoint[0]; + renderFeatureCoordinates[1] = midpoint[1]; + const placement = getValue(layer, 'layout', 'symbol-placement', zoom, f, functionCache, featureState); + if (placement === 'line' && iconRotationAlignment === 'map') { + const stride = geom.getStride(); + const coordinates = geom.getFlatCoordinates(); + for (let i = 0, ii = coordinates.length - stride; i < ii; i += stride) { + const x1 = coordinates[i]; + const y1 = coordinates[i + 1]; + const x2 = coordinates[i + stride]; + const y2 = coordinates[i + stride + 1]; + const minX = Math.min(x1, x2); + const maxX = Math.max(x1, x2); + const xM = midpoint[0]; + const yM = midpoint[1]; + const dotProduct = (y2 - y1) * (xM - x1) - (x2 - x1) * (yM - y1); + if (Math.abs(dotProduct) < 0.001 && //midpoint is aligned with the segment + xM <= maxX && xM >= minX //midpoint is on the segment and not outside it +) { + placementAngle = Math.atan2(y1 - y2, x2 - x1); + break; + } + } + } + } + } + } + if (type !== 2 || styleGeom) { + const iconSize = getValue(layer, 'layout', 'icon-size', zoom, f, functionCache, featureState); + const iconColor = paint['icon-color'] !== undefined ? getValue(layer, 'paint', 'icon-color', zoom, f, functionCache, featureState) : null; + if (!iconColor || iconColor.a !== 0) { + const haloColor = getValue(layer, 'paint', 'icon-halo-color', zoom, f, functionCache, featureState); + const haloWidth = getValue(layer, 'paint', 'icon-halo-width', zoom, f, functionCache, featureState); + let iconCacheKey = `${ icon }.${ iconSize }.${ haloWidth }.${ haloColor }`; + if (iconColor !== null) { + iconCacheKey += `.${ iconColor }`; + } + iconImg = iconImageCache[iconCacheKey]; + if (!iconImg) { + const declutterMode = getDeclutterMode(layer, zoom, f, 'icon', functionCache); + let displacement; + if ('icon-offset' in layout) { + displacement = getValue(layer, 'layout', 'icon-offset', zoom, f, functionCache, featureState).slice(0); + displacement[0] *= iconSize; + displacement[1] *= -iconSize; + } + let color = iconColor ? [ + iconColor.r * 255, + iconColor.g * 255, + iconColor.b * 255, + iconColor.a + ] : undefined; + if (imageElement) { + const iconOptions = { + color: color, + rotateWithView: iconRotationAlignment === 'map', + displacement: displacement, + declutterMode: declutterMode, + scale: iconSize + }; + if (typeof imageElement === 'string') { + // it is a src URL + iconOptions.src = imageElement; + } else { + iconOptions.img = imageElement; + iconOptions.imgSize = [ + imageElement.width, + imageElement.height + ]; + } + iconImg = new Icon(iconOptions); + } else { + const spriteImageData = spriteData[icon]; + let img, size, offset; + if (haloWidth) { + if (spriteImageData.sdf) { + img = drawIconHalo(drawSDF(spriteImage, spriteImageData, iconColor || [ + 0, + 0, + 0, + 1 + ]), { + x: 0, + y: 0, + width: spriteImageData.width, + height: spriteImageData.height, + pixelRatio: spriteImageData.pixelRatio + }, haloWidth, haloColor); + color = undefined; // do not tint haloed icons + } else { + img = drawIconHalo(spriteImage, spriteImageData, haloWidth, haloColor); + } + } else { + if (spriteImageData.sdf) { + if (!spriteImageUnSDFed) { + spriteImageUnSDFed = drawSDF(spriteImage, { + x: 0, + y: 0, + width: spriteImageSize[0], + height: spriteImageSize[1] + }, { + r: 1, + g: 1, + b: 1, + a: 1 + }); + } + img = spriteImageUnSDFed; + } else { + img = spriteImage; + } + size = [ + spriteImageData.width, + spriteImageData.height + ]; + offset = [ + spriteImageData.x, + spriteImageData.y + ]; + } + iconImg = new Icon({ + color: color, + img: img, + // @ts-ignore + imgSize: spriteImageSize, + size: size, + offset: offset, + rotateWithView: iconRotationAlignment === 'map', + scale: iconSize / spriteImageData.pixelRatio, + displacement: displacement, + declutterMode: declutterMode + }); + } + iconImageCache[iconCacheKey] = iconImg; + } + } + if (iconImg) { + ++stylesLength; + style = styles[stylesLength]; + if (!style || !style.getImage() || style.getFill() || style.getStroke()) { + style = new Style(); + styles[stylesLength] = style; + } + style.setGeometry(styleGeom); + iconImg.setRotation(placementAngle + deg2rad(getValue(layer, 'layout', 'icon-rotate', zoom, f, functionCache, featureState))); + iconImg.setOpacity(getValue(layer, 'paint', 'icon-opacity', zoom, f, functionCache, featureState)); + iconImg.setAnchor(anchor[getValue(layer, 'layout', 'icon-anchor', zoom, f, functionCache, featureState)]); + style.setImage(iconImg); + text = style.getText(); + style.setText(undefined); + style.setZIndex(index); + hasImage = true; + skipLabel = false; + } + } else { + skipLabel = true; + } + } + } + } + if (type == 1 && layer.type === 'circle') { + ++stylesLength; + style = styles[stylesLength]; + if (!style || !style.getImage() || style.getFill() || style.getStroke()) { + style = new Style(); + styles[stylesLength] = style; + } + const circleRadius = 'circle-radius' in paint ? getValue(layer, 'paint', 'circle-radius', zoom, f, functionCache, featureState) : 5; + const circleStrokeColor = colorWithOpacity(getValue(layer, 'paint', 'circle-stroke-color', zoom, f, functionCache, featureState), getValue(layer, 'paint', 'circle-stroke-opacity', zoom, f, functionCache, featureState)); + const circleTranslate = getValue(layer, 'paint', 'circle-translate', zoom, f, functionCache, featureState); + const circleColor = colorWithOpacity(getValue(layer, 'paint', 'circle-color', zoom, f, functionCache, featureState), getValue(layer, 'paint', 'circle-opacity', zoom, f, functionCache, featureState)); + const circleStrokeWidth = getValue(layer, 'paint', 'circle-stroke-width', zoom, f, functionCache, featureState); + const cache_key = circleRadius + '.' + circleStrokeColor + '.' + circleColor + '.' + circleStrokeWidth + '.' + circleTranslate[0] + '.' + circleTranslate[1]; + iconImg = iconImageCache[cache_key]; + if (!iconImg) { + iconImg = new Circle({ + radius: circleRadius, + displacement: [ + circleTranslate[0], + -circleTranslate[1] + ], + stroke: circleStrokeColor && circleStrokeWidth > 0 ? new Stroke({ + width: circleStrokeWidth, + color: circleStrokeColor + }) : undefined, + fill: circleColor ? new Fill({ color: circleColor }) : undefined, + declutterMode: 'none' + }); + iconImageCache[cache_key] = iconImg; + } + style.setImage(iconImg); + text = style.getText(); + style.setText(undefined); + style.setGeometry(undefined); + style.setZIndex(index); + hasImage = true; + } + let label, font, textLineHeight, textSize, letterSpacing, maxTextWidth; + if ('text-field' in layout) { + textSize = Math.round(getValue(layer, 'layout', 'text-size', zoom, f, functionCache, featureState)); + const fontArray = getValue(layer, 'layout', 'text-font', zoom, f, functionCache, featureState); + textLineHeight = getValue(layer, 'layout', 'text-line-height', zoom, f, functionCache, featureState); + font = mb2css(getFonts ? getFonts(fontArray, glStyle.metadata ? glStyle.metadata['ol:webfonts'] : undefined) : fontArray, textSize, textLineHeight); + if (!font.includes('sans-serif')) { + font += ',sans-serif'; + } + letterSpacing = getValue(layer, 'layout', 'text-letter-spacing', zoom, f, functionCache, featureState); + maxTextWidth = getValue(layer, 'layout', 'text-max-width', zoom, f, functionCache, featureState); + const textField = getValue(layer, 'layout', 'text-field', zoom, f, functionCache, featureState); + if (typeof textField === 'object' && textField.sections) { + if (textField.sections.length === 1) { + label = textField.toString(); + } else { + label = textField.sections.reduce((acc, chunk, i) => { + const fonts = chunk.fontStack ? chunk.fontStack.split(',') : fontArray; + const chunkFont = mb2css(getFonts ? getFonts(fonts) : fonts, textSize * (chunk.scale || 1), textLineHeight); + let text = chunk.text; + if (text === '\n') { + acc.push('\n', ''); + return acc; + } + if (type == 2) { + acc.push(applyLetterSpacing(text, letterSpacing), chunkFont); + return acc; + } + text = wrapText(text, chunkFont, maxTextWidth, letterSpacing).split('\n'); + for (let i = 0, ii = text.length; i < ii; ++i) { + if (i > 0) { + acc.push('\n', ''); + } + acc.push(text[i], chunkFont); + } + return acc; + }, []); + } + } else { + label = fromTemplate(textField, properties).trim(); + } + opacity = getValue(layer, 'paint', 'text-opacity', zoom, f, functionCache, featureState); + } + if (label && opacity && !skipLabel) { + if (!hasImage) { + ++stylesLength; + style = styles[stylesLength]; + if (!style || !style.getText() || style.getFill() || style.getStroke()) { + style = new Style(); + styles[stylesLength] = style; + } + style.setImage(undefined); + style.setGeometry(undefined); + } + const declutterMode = getDeclutterMode(layer, zoom, f, 'text', functionCache); + if (!style.getText()) { + style.setText(text); + } + text = style.getText(); + if (!text || 'getDeclutterMode' in text && text.getDeclutterMode() !== declutterMode) { + text = new Text({ + padding: [ + 2, + 2, + 2, + 2 + ], + // @ts-ignore + declutterMode: declutterMode + }); + style.setText(text); + } + const textTransform = getValue(layer, 'layout', 'text-transform', zoom, f, functionCache, featureState); + if (textTransform == 'uppercase') { + label = Array.isArray(label) ? label.map((t, i) => i % 2 ? t : t.toUpperCase()) : label.toUpperCase(); + } else if (textTransform == 'lowercase') { + label = Array.isArray(label) ? label.map((t, i) => i % 2 ? t : t.toLowerCase()) : label.toLowerCase(); + } + const wrappedLabel = Array.isArray(label) ? label : type == 2 ? applyLetterSpacing(label, letterSpacing) : wrapText(label, font, maxTextWidth, letterSpacing); + text.setText(wrappedLabel); + text.setFont(font); + text.setRotation(deg2rad(getValue(layer, 'layout', 'text-rotate', zoom, f, functionCache, featureState))); + if (typeof text.setKeepUpright === 'function') { + const keepUpright = getValue(layer, 'layout', 'text-keep-upright', zoom, f, functionCache, featureState); + text.setKeepUpright(keepUpright); + } + const textAnchor = getValue(layer, 'layout', 'text-anchor', zoom, f, functionCache, featureState); + const placement = hasImage || type == 1 ? 'point' : getValue(layer, 'layout', 'symbol-placement', zoom, f, functionCache, featureState); + let textAlign; + if (placement === 'line-center') { + text.setPlacement('line'); + textAlign = 'center'; + } else { + text.setPlacement(placement); + } + if (placement === 'line' && typeof text.setRepeat === 'function') { + const symbolSpacing = getValue(layer, 'layout', 'symbol-spacing', zoom, f, functionCache, featureState); + text.setRepeat(symbolSpacing * 2); + } + text.setOverflow(placement === 'point'); + let textHaloWidth = getValue(layer, 'paint', 'text-halo-width', zoom, f, functionCache, featureState); + const textOffset = getValue(layer, 'layout', 'text-offset', zoom, f, functionCache, featureState); + const textTranslate = getValue(layer, 'paint', 'text-translate', zoom, f, functionCache, featureState); + // Text offset has to take halo width and line height into account + let vOffset = 0; + let hOffset = 0; + if (placement == 'point') { + textAlign = 'center'; + if (textAnchor.indexOf('left') !== -1) { + textAlign = 'left'; + hOffset = textHaloWidth; + } else if (textAnchor.indexOf('right') !== -1) { + textAlign = 'right'; + hOffset = -textHaloWidth; + } + const textRotationAlignment = getValue(layer, 'layout', 'text-rotation-alignment', zoom, f, functionCache, featureState); + text.setRotateWithView(textRotationAlignment == 'map'); + } else { + text.setMaxAngle(deg2rad(getValue(layer, 'layout', 'text-max-angle', zoom, f, functionCache, featureState)) * label.length / wrappedLabel.length); + text.setRotateWithView(false); + } + text.setTextAlign(textAlign); + let textBaseline = 'middle'; + if (textAnchor.indexOf('bottom') == 0) { + textBaseline = 'bottom'; + vOffset = -textHaloWidth - 0.5 * (textLineHeight - 1) * textSize; + } else if (textAnchor.indexOf('top') == 0) { + textBaseline = 'top'; + vOffset = textHaloWidth + 0.5 * (textLineHeight - 1) * textSize; + } + text.setTextBaseline(textBaseline); + const textJustify = getValue(layer, 'layout', 'text-justify', zoom, f, functionCache, featureState); + text.setJustify(textJustify === 'auto' ? undefined : textJustify); + text.setOffsetX(textOffset[0] * textSize + hOffset + textTranslate[0]); + text.setOffsetY(textOffset[1] * textSize + vOffset + textTranslate[1]); + textColor.setColor(colorWithOpacity(getValue(layer, 'paint', 'text-color', zoom, f, functionCache, featureState), opacity)); + text.setFill(textColor); + const haloColor = colorWithOpacity(getValue(layer, 'paint', 'text-halo-color', zoom, f, functionCache, featureState), opacity); + if (haloColor && textHaloWidth > 0) { + textHalo.setColor(haloColor); + // spec here : https://docs.mapbox.com/mapbox-gl-js/style-spec/#paint-symbol-text-halo-width + // Halo width must be doubled because it is applied around the center of the text outline + textHaloWidth *= 2; + // 1/4 of text size (spec) x 2 + const halfTextSize = 0.5 * textSize; + textHalo.setWidth(textHaloWidth <= halfTextSize ? textHaloWidth : halfTextSize); + text.setStroke(textHalo); + } else { + text.setStroke(undefined); + } + const textPadding = getValue(layer, 'layout', 'text-padding', zoom, f, functionCache, featureState); + const padding = text.getPadding(); + if (textPadding !== padding[0]) { + padding[0] = textPadding; + padding[1] = textPadding; + padding[2] = textPadding; + padding[3] = textPadding; + } + style.setZIndex(index); + } + } + } + if (stylesLength > -1) { + styles.length = stylesLength + 1; + if (recordLayer) { + if ('set' in feature) { + // ol/Feature + feature.set('mapbox-layer', featureBelongsToLayer); + } else { + // ol/render/Feature + feature.getProperties()['mapbox-layer'] = featureBelongsToLayer; + } + } + return styles; + } + return undefined; + }; + olLayer.setStyle(styleFunction); + olLayer.set('mapbox-source', mapboxSource); + olLayer.set('mapbox-layers', mapboxLayers); + olLayer.set('mapbox-featurestate', olLayer.get('mapbox-featurestate') || {}); + return styleFunction; +} +/** + * Get the the style for a specific Mapbox layer only. This can be useful for creating a legend. + * @param {import("ol/Feature").default|import("ol/render/Feature").default} feature OpenLayers feature. + * @param {number} resolution View resolution. + * @param {import("ol/layer").Vector|import("ol/layer").VectorTile} olLayer OpenLayers layer. + * @param {string} layerId Id of the Mapbox layer to get the style for + * @return {Array} Styles for the provided Mapbox layer. + */ +function getStyleForLayer(feature, resolution, olLayer, layerId) { + const evaluateStyle = olLayer.getStyleFunction(); + if (evaluateStyle.length === 3) { + // @ts-ignore + return evaluateStyle(feature, resolution, layerId); + } + return undefined; +} + +/** + * Generates a shaded relief image given elevation data. Uses a 3x3 + * neighborhood for determining slope and aspect. + * @param {Array} inputs Array of input images. + * @param {Object} data Data added in the "beforeoperations" event. + * @return {ImageData} Output image. + */ +function hillshade(inputs, data) { + const elevationImage = inputs[0]; + const width = elevationImage.width; + const height = elevationImage.height; + const elevationData = elevationImage.data; + const shadeData = new Uint8ClampedArray(elevationData.length); + const dp = data.resolution * 2; + const maxX = width - 1; + const maxY = height - 1; + const pixel = [ + 0, + 0, + 0, + 0 + ]; + const twoPi = 2 * Math.PI; + const halfPi = Math.PI / 2; + const sunEl = Math.PI * data.sunEl / 180; + const sunAz = Math.PI * data.sunAz / 180; + const cosSunEl = Math.cos(sunEl); + const sinSunEl = Math.sin(sunEl); + const highlightColor = data.highlightColor; + const shadowColor = data.shadowColor; + const accentColor = data.accentColor; + const encoding = data.encoding; + let pixelX, pixelY, x0, x1, y0, y1, offset, z0, z1, dzdx, dzdy, slope, aspect, accent, scaled, shade, scaledAccentColor, compositeShadeColor, clamp, slopeScaleBase, scaledSlope, cosIncidence; + function calculateElevation(pixel, encoding = 'mapbox') { + // The method used to extract elevations from the DEM. + // + // The supported methods are the Mapbox format + // (red * 256 * 256 + green * 256 + blue) * 0.1 - 10000 + // and the Terrarium format + // (red * 256 + green + blue / 256) - 32768 + // + if (encoding === 'mapbox') { + return (pixel[0] * 256 * 256 + pixel[1] * 256 + pixel[2]) * 0.1 - 10000; + } + if (encoding === 'terrarium') { + return pixel[0] * 256 + pixel[1] + pixel[2] / 256 - 32768; + } + } + for (pixelY = 0; pixelY <= maxY; ++pixelY) { + y0 = pixelY === 0 ? 0 : pixelY - 1; + y1 = pixelY === maxY ? maxY : pixelY + 1; + for (pixelX = 0; pixelX <= maxX; ++pixelX) { + x0 = pixelX === 0 ? 0 : pixelX - 1; + x1 = pixelX === maxX ? maxX : pixelX + 1; + // determine elevation for (x0, pixelY) + offset = (pixelY * width + x0) * 4; + pixel[0] = elevationData[offset]; + pixel[1] = elevationData[offset + 1]; + pixel[2] = elevationData[offset + 2]; + pixel[3] = elevationData[offset + 3]; + z0 = data.vert * calculateElevation(pixel, encoding); + // determine elevation for (x1, pixelY) + offset = (pixelY * width + x1) * 4; + pixel[0] = elevationData[offset]; + pixel[1] = elevationData[offset + 1]; + pixel[2] = elevationData[offset + 2]; + pixel[3] = elevationData[offset + 3]; + z1 = data.vert * calculateElevation(pixel, encoding); + dzdx = (z1 - z0) / dp; + // determine elevation for (pixelX, y0) + offset = (y0 * width + pixelX) * 4; + pixel[0] = elevationData[offset]; + pixel[1] = elevationData[offset + 1]; + pixel[2] = elevationData[offset + 2]; + pixel[3] = elevationData[offset + 3]; + z0 = data.vert * calculateElevation(pixel, encoding); + // determine elevation for (pixelX, y1) + offset = (y1 * width + pixelX) * 4; + pixel[0] = elevationData[offset]; + pixel[1] = elevationData[offset + 1]; + pixel[2] = elevationData[offset + 2]; + pixel[3] = elevationData[offset + 3]; + z1 = data.vert * calculateElevation(pixel, encoding); + dzdy = (z1 - z0) / dp; + aspect = Math.atan2(dzdy, -dzdx); + if (aspect < 0) { + aspect = halfPi - aspect; + } else if (aspect > halfPi) { + aspect = twoPi - aspect + halfPi; + } else { + aspect = halfPi - aspect; + } + // Bootstrap slope and corresponding incident values + slope = Math.atan(Math.sqrt(dzdx * dzdx + dzdy * dzdy)); + cosIncidence = sinSunEl * Math.cos(slope) + cosSunEl * Math.sin(slope) * Math.cos(sunAz - aspect); + accent = Math.cos(slope); + // 255 for Hex colors + scaled = 255 * cosIncidence; + /* + * The following is heavily inspired + * by [Maplibre's equivalent WebGL shader](https://github.com/maplibre/maplibre-gl-js/blob/main/src/shaders/hillshade.fragment.glsl) + */ + // Forces given value to stay between two given extremes + clamp = Math.min(Math.max(2 * data.sunEl, 0), 1); + // Intensity basis for hillshade opacity + slopeScaleBase = 1.875 - data.opacity * 1.75; + // Intensity interpolation so that higher intensity values create more opaque hillshading + scaledSlope = data.opacity !== 0.5 ? halfPi * ((Math.pow(slopeScaleBase, slope) - 1) / (Math.pow(slopeScaleBase, halfPi) - 1)) : slope; + // Accent hillshade color with given accentColor to emphasize rougher terrain + scaledAccentColor = { + r: (1 - accent) * accentColor.r * clamp * 255, + g: (1 - accent) * accentColor.g * clamp * 255, + b: (1 - accent) * accentColor.b * clamp * 255, + a: (1 - accent) * accentColor.a * clamp * 255 + }; + // Allows highlight vs shadow discrimination + shade = Math.abs(((aspect + sunAz) / Math.PI + 0.5) % 2 - 1); + // Creates a composite color mix between highlight & shadow colors to emphasize slopes + compositeShadeColor = { + r: (highlightColor.r * (1 - shade) + shadowColor.r * shade) * scaled, + g: (highlightColor.g * (1 - shade) + shadowColor.g * shade) * scaled, + b: (highlightColor.b * (1 - shade) + shadowColor.b * shade) * scaled, + a: (highlightColor.a * (1 - shade) + shadowColor.a * shade) * scaled + }; + // Fill in result color value + offset = (pixelY * width + pixelX) * 4; + shadeData[offset] = scaledAccentColor.r * (1 - shade) + compositeShadeColor.r; + shadeData[offset + 1] = scaledAccentColor.g * (1 - shade) + compositeShadeColor.g; + shadeData[offset + 2] = scaledAccentColor.b * (1 - shade) + compositeShadeColor.b; + // Key opacity on the scaledSlope to improve legibility by increasing higher elevation rates' contrast + shadeData[offset + 3] = elevationData[offset + 3] * data.opacity * clamp * Math.sin(scaledSlope); + } + } + return new ImageData(shadeData, width, height); +} + +/* +ol-mapbox-style - Use Mapbox/MapLibre Style objects with OpenLayers +Copyright 2016-present ol-mapbox-style contributors +License: https://raw.githubusercontent.com/openlayers/ol-mapbox-style/master/LICENSE +*/ +/** + * @typedef {Object} FeatureIdentifier + * @property {string|number} id The feature id. + * @property {string} source The source id. + */ +/** + * @typedef {Object} Options + * @property {string} [accessToken] Access token for 'mapbox://' urls. + * @property {function(string, import("./util.js").ResourceType): (Request|string|Promise|void)} [transformRequest] + * Function for controlling how `ol-mapbox-style` fetches resources. Can be used for modifying + * the url, adding headers or setting credentials options. Called with the url and the resource + * type as arguments, this function is supposed to return a `Request` or a url `string`, or a promise tehereof. + * Without a return value the original request will not be modified. + * @property {string} [projection='EPSG:3857'] Only useful when working with non-standard projections. + * Code of a projection registered with OpenLayers. All sources of the style must be provided in this + * projection. The projection must also have a valid extent defined, which will be used to determine the + * origin and resolutions of the tile grid for all tiled sources of the style. When provided, the bbox + * placeholder in tile and geojson urls changes: the default is `{bbox-epsg-3857}`, when projection is e.g. + * set to `EPSG:4326`, the bbox placeholder will be `{bbox-epsg-4326}`. + * @property {Array} [resolutions] Only useful when working with non-standard projections. + * Resolutions for mapping resolution to the `zoom` used in the Mapbox/MapLibre style. + * @property {string} [styleUrl] URL of the Mapbox GL style. Required for styles that were provided + * as object, when they contain a relative sprite url, or sources referencing data by relative url. + * @property {string} [webfonts] Template for resolving webfonts. Can be used to specify where to fetch + * web fonts when no `ol:webfonts` metadata is set in the style object. See `getFonts()` and the + * "Font handling" section in `README.md` for details. + * @property {function(VectorLayer|VectorTileLayer, string):HTMLImageElement|HTMLCanvasElement|string|undefined} [getImage=undefined] + * Function that returns an image for an icon name. If the result is an HTMLImageElement, it must already be + * loaded. The layer can be used to call layer.changed() when the loading and processing of the image has finished. + * This function be used for icons not in the sprite or to override sprite icons. + * @property {string} [accessTokenParam='access_token'] Access token param. For internal use. + */ +/** + * @typedef {Object} ApplyStyleOptions + * @property {string} [source=''] Source. Default is `''`, which causes the first source in the + * style to be used. + * @property {Array} [layers] Layers. If no source is provided, the layers with the + * provided ids will be used from the style's `layers` array. All layers need to use the same source. + * @property {boolean} [updateSource=true] Update or create vector (tile) layer source with parameters + * specified for the source in the mapbox style definition. + */ +/** + * @param {import("ol/proj/Projection.js").default} projection Projection. + * @param {number} [tileSize=512] Tile size. + * @return {Array} Resolutions. + */ +function getTileResolutions(projection, tileSize = 512) { + return projection.getExtent() ? createXYZ({ + extent: projection.getExtent(), + tileSize: tileSize, + maxZoom: 22 + }).getResolutions() : defaultResolutions; +} +/** + * @param {string} styleUrl Style URL. + * @param {Options} options Options. + * @return {Options} Completed options with accessToken and accessTokenParam. + */ +function completeOptions(styleUrl, options) { + if (!options.accessToken) { + options = Object.assign({}, options); + const searchParams = new URL(styleUrl).searchParams; + // The last search parameter is the access token + searchParams.forEach((value, key) => { + options.accessToken = value; + options.accessTokenParam = key; + }); + } + return options; +} +/** + * Applies a style function to an `ol/layer/VectorTile` or `ol/layer/Vector` + * with an `ol/source/VectorTile` or an `ol/source/Vector`. If the layer does not have a source + * yet, it will be created and populated from the information in the `glStyle` (unless `updateSource` is + * set to `false`). + * + * **Example:** + * ```js + * import {applyStyle} from 'ol-mapbox-style'; + * import {VectorTile} from 'ol/layer.js'; + * + * const layer = new VectorTile({declutter: true}); + * applyStyle(layer, 'https://api.maptiler.com/maps/basic/style.json?key=YOUR_OPENMAPTILES_TOKEN'); + * ``` + * + * The style function will render all layers from the `glStyle` object that use the source + * of the first layer, the specified `source`, or a subset of layers from the same source. The + * source needs to be a `"type": "vector"` or `"type": "geojson"` source. + * + * Two additional properties will be set on the provided layer: + * + * * `mapbox-source`: The `id` of the Mapbox/MapLibre Style document's source that the + * OpenLayers layer was created from. Usually `apply()` creates one + * OpenLayers layer per Mapbox/MapLibre Style source, unless the layer stack has + * layers from different sources in between. + * * `mapbox-layers`: The `id`s of the Mapbox/MapLibre Style document's layers that are + * included in the OpenLayers layer. + * + * @param {VectorTileLayer|VectorLayer} layer OpenLayers layer. When the layer has a source configured, + * it will be modified to use the configuration from the glStyle's `source`. Options specified on the + * layer's source will override those from the glStyle's `source`, except for `url` and + * `tileUrlFunction`. When the source projection is the default (`EPSG:3857`), the `tileGrid` will + * also be overridden. If you'd rather not have ol-mapbox-style modify the source, configure `applyStyle()` + * with the `updateSource: false` option. + * @param {string|Object} glStyle Mapbox/MapLibre Style object. + * @param {string|Array|Options&ApplyStyleOptions} [sourceOrLayersOrOptions] Options or + * `source` key or an array of layer `id`s from the Mapbox/MapLibre Style object. When a `source` key is + * provided, all layers for the specified source will be included in the style function. When layer + * `id`s are provided, they must be from layers that use the same source. When not provided or a falsey + * value, all layers using the first source specified in the glStyle will be rendered. + * @param {Options&ApplyStyleOptions|string} [optionsOrPath] **Deprecated**. Options. Alternatively the path of the style file + * (only required when a relative path is used for the `"sprite"` property of the style). + * @param {Array} [resolutions] **Deprecated**. Resolutions for mapping resolution to zoom level. + * Only needed when working with non-standard tile grids or projections, can also be supplied with + * options. + * @return {Promise} Promise which will be resolved when the style can be used + * for rendering. + */ +function applyStyle(layer, glStyle, sourceOrLayersOrOptions = '', optionsOrPath = {}, resolutions = undefined) { + let styleUrl, sourceId; + /** @type {Options&ApplyStyleOptions} */ + let options; + let sourceOrLayers; + let updateSource = true; + if (typeof sourceOrLayersOrOptions !== 'string' && !Array.isArray(sourceOrLayersOrOptions)) { + options = sourceOrLayersOrOptions; + sourceOrLayers = options.source || options.layers; + optionsOrPath = options; + } else { + sourceOrLayers = sourceOrLayersOrOptions; + } + if (typeof optionsOrPath === 'string') { + styleUrl = optionsOrPath; + options = {}; + } else { + styleUrl = optionsOrPath.styleUrl; + options = optionsOrPath; + } + if (options.updateSource === false) { + updateSource = false; + } + if (!resolutions) { + resolutions = options.resolutions; + } + if (!styleUrl && typeof glStyle === 'string' && !glStyle.trim().startsWith('{')) { + styleUrl = glStyle; + } + if (styleUrl) { + styleUrl = styleUrl.startsWith('data:') ? location.href : normalizeStyleUrl(styleUrl, options.accessToken); + options = completeOptions(styleUrl, options); + } + return new Promise(function (resolve, reject) { + // TODO: figure out where best place to check source type is + // Note that the source arg is an array of gl layer ids and each must be + // dereferenced to get source type to validate + getGlStyle(glStyle, options).then(function (glStyle) { + if (glStyle.version != 8) { + return reject(new Error('glStyle version 8 required.')); + } + if (!(layer instanceof VectorLayer || layer instanceof VectorTileLayer)) { + return reject(new Error('Can only apply to VectorLayer or VectorTileLayer')); + } + const type = layer instanceof VectorTileLayer ? 'vector' : 'geojson'; + if (!sourceOrLayers) { + sourceId = Object.keys(glStyle.sources).find(function (key) { + return glStyle.sources[key].type === type; + }); + sourceOrLayers = sourceId; + } else if (Array.isArray(sourceOrLayers)) { + sourceId = glStyle.layers.find(function (layer) { + return layer.id === sourceOrLayers[0]; + }).source; + } else { + sourceId = sourceOrLayers; + } + if (!sourceId) { + return reject(new Error(`No ${ type } source found in the glStyle.`)); + } + function assignSource() { + if (!updateSource) { + return Promise.resolve(); + } + if (layer instanceof VectorTileLayer) { + return setupVectorSource(glStyle.sources[sourceId], styleUrl, options).then(function (source) { + const targetSource = layer.getSource(); + if (!targetSource) { + layer.setSource(source); + } else if (source !== targetSource) { + targetSource.setTileUrlFunction(source.getTileUrlFunction()); + if (typeof targetSource.setUrls === 'function' && typeof source.getUrls === 'function') { + // to get correct keys for tile cache and queue + targetSource.setUrls(source.getUrls()); + } + //@ts-ignore + if (!targetSource.format_) { + //@ts-ignore + targetSource.format_ = source.format_; + } + if (!targetSource.getAttributions()) { + targetSource.setAttributions(source.getAttributions()); + } + if (targetSource.getTileLoadFunction() === defaultLoadFunction) { + targetSource.setTileLoadFunction(source.getTileLoadFunction()); + } + if (equivalent(targetSource.getProjection(), source.getProjection())) { + targetSource.tileGrid = source.getTileGrid(); + } + } + const tileGrid = layer.getSource().getTileGrid(); + if (!isFinite(layer.getMaxResolution()) && !isFinite(layer.getMinZoom()) && tileGrid.getMinZoom() > 0) { + layer.setMaxResolution(getResolutionForZoom(Math.max(0, tileGrid.getMinZoom() - 1e-12), tileGrid.getResolutions())); + } + }); + } + const glSource = glStyle.sources[sourceId]; + let source = layer.getSource(); + if (!source || source.get('mapbox-source') !== glSource) { + source = setupGeoJSONSource(glSource, styleUrl, options); + } + const targetSource = layer.getSource(); + if (!targetSource) { + layer.setSource(source); + } else if (source !== targetSource) { + if (!targetSource.getAttributions()) { + targetSource.setAttributions(source.getAttributions()); + } + //@ts-ignore + if (!targetSource.format_) { + //@ts-ignore + targetSource.format_ = source.getFormat(); + } + //@ts-ignore + targetSource.url_ = source.getUrl(); + } + return Promise.resolve(); + } + let spriteScale, spriteData, spriteImageUrl, style; + function onChange() { + if (!style && (!glStyle.sprite || spriteData)) { + if (options.projection && !resolutions) { + const projection = get$1(options.projection); + const units = projection.getUnits(); + if (units !== 'm') { + resolutions = defaultResolutions.map(resolution => resolution / METERS_PER_UNIT[units]); + } + } + style = stylefunction(layer, glStyle, sourceOrLayers, resolutions, spriteData, spriteImageUrl, (fonts, templateUrl = options.webfonts) => getFonts(fonts, templateUrl), options.getImage); + if (!layer.getStyle()) { + reject(new Error(`Nothing to show for source [${ sourceId }]`)); + } else { + assignSource().then(resolve).catch(reject); + } + } else if (style) { + layer.setStyle(style); + assignSource().then(resolve).catch(reject); + } else { + reject(new Error('Something went wrong trying to apply style.')); + } + } + if (glStyle.sprite) { + const sprite = new URL(normalizeSpriteUrl(glStyle.sprite, options.accessToken, styleUrl || location.href)); + spriteScale = window.devicePixelRatio >= 1.5 ? 0.5 : 1; + const sizeFactor = spriteScale == 0.5 ? '@2x' : ''; + let spriteUrl = sprite.origin + sprite.pathname + sizeFactor + '.json' + sprite.search; + new Promise(function (resolve, reject) { + fetchResource('Sprite', spriteUrl, options).then(resolve).catch(function (error) { + spriteUrl = sprite.origin + sprite.pathname + '.json' + sprite.search; + fetchResource('Sprite', spriteUrl, options).then(resolve).catch(reject); + }); + }).then(function (spritesJson) { + if (spritesJson === undefined) { + reject(new Error('No sprites found.')); + } + spriteData = spritesJson; + spriteImageUrl = sprite.origin + sprite.pathname + sizeFactor + '.png' + sprite.search; + if (options.transformRequest) { + const transformed = options.transformRequest(spriteImageUrl, 'SpriteImage') || spriteImageUrl; + if (transformed instanceof Request || transformed instanceof Promise) { + spriteImageUrl = transformed; + } + } + onChange(); + }).catch(function (err) { + reject(new Error(`Sprites cannot be loaded: ${ spriteUrl }: ${ err.message }`)); + }); + } else { + onChange(); + } + }).catch(reject); + }); +} +const emptyObj = {}; +function setFirstBackground(mapOrLayer, glStyle, options) { + glStyle.layers.some(function (layer) { + if (layer.type === 'background') { + if (mapOrLayer instanceof Layer) { + mapOrLayer.setBackground(function (resolution) { + return getBackgroundColor(layer, resolution, options, {}); + }); + return true; + } + if (mapOrLayer instanceof Map || mapOrLayer instanceof LayerGroup) { + mapOrLayer.getLayers().insertAt(0, setupBackgroundLayer(layer, options, {})); + return true; + } + } + }); +} +/** + * Applies properties of the Mapbox/MapLibre Style's first `background` layer to the + * provided map or layer (group). + * + * **Example:** + * ```js + * import {applyBackground} from 'ol-mapbox-style'; + * import {Map} from 'ol'; + * + * const map = new Map({target: 'map'}); + * applyBackground(map, 'https://api.maptiler.com/maps/basic/style.json?key=YOUR_OPENMAPTILES_TOKEN'); + * ``` + * @param {Map|import("ol/layer/Base.js").default} mapOrLayer OpenLayers Map or layer (group). + * @param {Object|string} glStyle Mapbox/MapLibre Style object or url. + * @param {Options} options Options. + * @return {Promise} Promise that resolves when the background is applied. + */ +function applyBackground(mapOrLayer, glStyle, options = {}) { + return getGlStyle(glStyle, options).then(function (glStyle) { + setFirstBackground(mapOrLayer, glStyle, options); + }); +} +function getSourceIdByRef(layers, ref) { + let sourceId; + layers.some(function (layer) { + if (layer.id == ref) { + sourceId = layer.source; + return true; + } + }); + return sourceId; +} +function extentFromTileJSON(tileJSON, projection) { + const bounds = tileJSON.bounds; + if (bounds) { + const ll = fromLonLat([ + bounds[0], + bounds[1] + ], projection); + const tr = fromLonLat([ + bounds[2], + bounds[3] + ], projection); + return [ + ll[0], + ll[1], + tr[0], + tr[1] + ]; + } + return get$1(projection).getExtent(); +} +function sourceOptionsFromTileJSON(glSource, tileJSON, options) { + const tileJSONSource = new TileJSON({ + tileJSON: tileJSON, + tileSize: glSource.tileSize || tileJSON.tileSize || 512 + }); + const tileJSONDoc = tileJSONSource.getTileJSON(); + const tileGrid = tileJSONSource.getTileGrid(); + const projection = get$1(options.projection || 'EPSG:3857'); + const extent = extentFromTileJSON(tileJSONDoc, projection); + const projectionExtent = projection.getExtent(); + const minZoom = tileJSONDoc.minzoom || 0; + const maxZoom = tileJSONDoc.maxzoom || 22; + /** @type {import("ol/source/VectorTile.js").Options} */ + const sourceOptions = { + attributions: tileJSONSource.getAttributions(), + projection: projection, + tileGrid: new TileGrid({ + origin: projectionExtent ? getTopLeft(projectionExtent) : tileGrid.getOrigin(0), + extent: extent || tileGrid.getExtent(), + minZoom: minZoom, + resolutions: getTileResolutions(projection, tileJSON.tileSize).slice(0, maxZoom + 1), + tileSize: tileGrid.getTileSize(0) + }) + }; + if (Array.isArray(tileJSONDoc.tiles)) { + sourceOptions.urls = tileJSONDoc.tiles; + } else { + sourceOptions.url = tileJSONDoc.tiles; + } + return sourceOptions; +} +function getBackgroundColor(glLayer, resolution, options, functionCache) { + const background = { + id: glLayer.id, + type: glLayer.type + }; + const layout = glLayer.layout || {}; + const paint = glLayer.paint || {}; + background['paint'] = paint; + const zoom = getZoomForResolution(resolution, options.resolutions || defaultResolutions); + let opacity; + const bg = getValue(background, 'paint', 'background-color', zoom, emptyObj, functionCache); + if (paint['background-opacity'] !== undefined) { + opacity = getValue(background, 'paint', 'background-opacity', zoom, emptyObj, functionCache); + } + return layout.visibility == 'none' ? undefined : colorWithOpacity(bg, opacity); +} +/** + * @param {Object} glLayer Mapbox/MapLibre Style layer object. + * @param {Options} options Options. + * @param {Object} functionCache Cache for functions. + * @return {Layer} OpenLayers layer. + */ +function setupBackgroundLayer(glLayer, options, functionCache) { + const div = document.createElement('div'); + div.className = 'ol-mapbox-style-background'; + div.style.position = 'absolute'; + div.style.width = '100%'; + div.style.height = '100%'; + return new Layer({ + source: new Source({}), + render(frameState) { + const color = getBackgroundColor(glLayer, frameState.viewState.resolution, options, functionCache); + div.style.backgroundColor = color; + return div; + } + }); +} +/** + * Creates an OpenLayers VectorTile source for a gl source entry. + * @param {Object} glSource "source" entry from a Mapbox/MapLibre Style object. + * @param {string|undefined} styleUrl URL to use for the source. This is expected to be the complete http(s) url, + * with access key applied. + * @param {Options} options Options. + * @return {Promise} Promise resolving to a VectorTile source. + * @private + */ +function setupVectorSource(glSource, styleUrl, options) { + return new Promise(function (resolve, reject) { + getTileJson(glSource, styleUrl, options).then(function ({tileJson, tileLoadFunction}) { + const sourceOptions = sourceOptionsFromTileJSON(glSource, tileJson, options); + sourceOptions.tileLoadFunction = tileLoadFunction; + sourceOptions.format = new MVT(); + resolve(new VectorTileSource(sourceOptions)); + }).catch(reject); + }); +} +function setupVectorLayer(glSource, styleUrl, options) { + const layer = new VectorTileLayer({ + declutter: true, + visible: false + }); + setupVectorSource(glSource, styleUrl, options).then(function (source) { + source.set('mapbox-source', glSource); + layer.setSource(source); + }).catch(function (error) { + layer.setSource(undefined); + }); + return layer; +} +function getBboxTemplate(projection) { + const projCode = projection ? projection.getCode() : 'EPSG:3857'; + return `{bbox-${ projCode.toLowerCase().replace(/[^a-z0-9]/g, '-') }}`; +} +function setupRasterSource(glSource, styleUrl, options) { + return new Promise(function (resolve, reject) { + getTileJson(glSource, styleUrl, options).then(function ({tileJson, tileLoadFunction}) { + const source = new TileJSON({ + interpolate: options.interpolate === undefined ? true : options.interpolate, + transition: 0, + crossOrigin: 'anonymous', + tileJSON: tileJson + }); + source.tileGrid = sourceOptionsFromTileJSON(glSource, tileJson, options).tileGrid; + if (options.projection) { + //@ts-ignore + source.projection = get$1(options.projection); + } + const getTileUrl = source.getTileUrlFunction(); + if (tileLoadFunction) { + source.setTileLoadFunction(tileLoadFunction); + } + source.setTileUrlFunction(function (tileCoord, pixelRatio, projection) { + const bboxTemplate = getBboxTemplate(projection); + let src = getTileUrl(tileCoord, pixelRatio, projection); + if (src.indexOf(bboxTemplate) != -1) { + const bbox = source.getTileGrid().getTileCoordExtent(tileCoord); + src = src.replace(bboxTemplate, bbox.toString()); + } + return src; + }); + source.set('mapbox-source', glSource); + resolve(source); + }).catch(function (error) { + reject(error); + }); + }); +} +function setupRasterLayer(glSource, styleUrl, options) { + const layer = new TileLayer(); + setupRasterSource(glSource, styleUrl, options).then(function (source) { + layer.setSource(source); + }).catch(function () { + layer.setSource(undefined); + }); + return layer; +} +/** + * + * @param {Object} glSource "source" entry from a Mapbox/MapLibre Style object. + * @param {string} styleUrl Style url + * @param {Options} options ol-mapbox-style options. + * @return {ImageLayer} The raster layer + */ +function setupHillshadeLayer(glSource, styleUrl, options) { + const tileLayer = setupRasterLayer(glSource, styleUrl, options); + /** @type {ImageLayer} */ + const layer = new ImageLayer({ + source: new Raster({ + operationType: 'image', + operation: hillshade, + sources: [tileLayer] + }) + }); + return layer; +} +/** + * @param {Object} glSource glStyle source. + * @param {string} styleUrl Style URL. + * @param {Options} options Options. + * @return {VectorSource} Configured vector source. + */ +function setupGeoJSONSource(glSource, styleUrl, options) { + const geoJsonFormat = options.projection ? new GeoJSON({ dataProjection: options.projection }) : new GeoJSON(); + const data = glSource.data; + const sourceOptions = {}; + if (typeof data == 'string') { + const [geoJsonUrl] = normalizeSourceUrl(data, options.accessToken, options.accessTokenParam || 'access_token', styleUrl || location.href); + if (/\{bbox-[0-9a-z-]+\}/.test(geoJsonUrl)) { + const extentUrl = (extent, resolution, projection) => { + const bboxTemplate = getBboxTemplate(projection); + return geoJsonUrl.replace(bboxTemplate, `${ extent.join(',') }`); + }; + const source = new VectorSource({ + attributions: glSource.attribution, + format: geoJsonFormat, + loader: (extent, resolution, projection, success, failure) => { + const url = typeof extentUrl === 'function' ? extentUrl(extent, resolution, projection) : extentUrl; + fetchResource('GeoJSON', url, options).then(json => { + const features = source.getFormat().readFeatures(json, { featureProjection: projection }); + source.addFeatures(features); + success(features); + }).catch(response => { + source.removeLoadedExtent(extent); + failure(); + }); + }, + strategy: bbox + }); + source.set('mapbox-source', glSource); + return source; + } + const source = new VectorSource({ + attributions: glSource.attribution, + format: geoJsonFormat, + url: geoJsonUrl, + loader: (extent, resolution, projection, success, failure) => { + fetchResource('GeoJSON', geoJsonUrl, options).then(json => { + const features = source.getFormat().readFeatures(json, { featureProjection: projection }); + source.addFeatures(features); + success(features); + }).catch(response => { + source.removeLoadedExtent(extent); + failure(); + }); + } + }); + return source; + } + sourceOptions.features = geoJsonFormat.readFeatures(data, { featureProjection: getUserProjection() || 'EPSG:3857' }); + const source = new VectorSource(Object.assign({ + attributions: glSource.attribution, + format: geoJsonFormat + }, sourceOptions)); + source.set('mapbox-source', glSource); + return source; +} +function setupGeoJSONLayer(glSource, styleUrl, options) { + return new VectorLayer({ + declutter: true, + source: setupGeoJSONSource(glSource, styleUrl, options), + visible: false + }); +} +function prerenderRasterLayer(glLayer, layer, functionCache) { + let zoom = null; + return function (event) { + if (glLayer.paint && 'raster-opacity' in glLayer.paint && event.frameState.viewState.zoom !== zoom) { + zoom = event.frameState.viewState.zoom; + delete functionCache[glLayer.id]; + updateRasterLayerProperties(glLayer, layer, zoom, functionCache); + } + }; +} +function updateRasterLayerProperties(glLayer, layer, zoom, functionCache) { + const opacity = getValue(glLayer, 'paint', 'raster-opacity', zoom, emptyObj, functionCache); + layer.setOpacity(opacity); +} +function manageVisibility(layer, mapOrGroup) { + function onChange() { + const glStyle = mapOrGroup.get('mapbox-style'); + if (!glStyle) { + return; + } + const mapboxLayers = derefLayers(glStyle.layers); + const layerMapboxLayerids = layer.get('mapbox-layers'); + const visible = mapboxLayers.filter(function (mapboxLayer) { + return layerMapboxLayerids.includes(mapboxLayer.id); + }).some(function (mapboxLayer) { + return !mapboxLayer.layout || !mapboxLayer.layout.visibility || mapboxLayer.layout.visibility === 'visible'; + }); + if (layer.get('visible') !== visible) { + layer.setVisible(visible); + } + } + layer.on('change', onChange); + onChange(); +} +function setupLayer(glStyle, styleUrl, glLayer, options) { + const functionCache = getFunctionCache(glStyle); + const glLayers = glStyle.layers; + const type = glLayer.type; + const id = glLayer.source || getSourceIdByRef(glLayers, glLayer.ref); + const glSource = glStyle.sources[id]; + let layer; + if (type == 'background') { + layer = setupBackgroundLayer(glLayer, options, functionCache); + } else if (glSource.type == 'vector') { + layer = setupVectorLayer(glSource, styleUrl, options); + } else if (glSource.type == 'raster') { + layer = setupRasterLayer(glSource, styleUrl, options); + layer.setVisible(glLayer.layout ? glLayer.layout.visibility !== 'none' : true); + layer.on('prerender', prerenderRasterLayer(glLayer, layer, functionCache)); + } else if (glSource.type == 'geojson') { + layer = setupGeoJSONLayer(glSource, styleUrl, options); + } else if (glSource.type == 'raster-dem' && glLayer.type == 'hillshade') { + const hillshadeLayer = setupHillshadeLayer(glSource, styleUrl, options); + layer = hillshadeLayer; + hillshadeLayer.getSource().on('beforeoperations', function (event) { + const data = event.data; + data.resolution = getPointResolution(options.projection || 'EPSG:3857', event.resolution, getCenter(event.extent), 'm'); + const zoom = getZoomForResolution(event.resolution, options.resolutions || defaultResolutions); + data.encoding = glSource.encoding; + data.vert = 5 * getValue(glLayer, 'paint', 'hillshade-exaggeration', zoom, emptyObj, functionCache); + data.sunAz = getValue(glLayer, 'paint', 'hillshade-illumination-direction', zoom, emptyObj, functionCache); + data.sunEl = 35; + data.opacity = 0.3; + data.highlightColor = getValue(glLayer, 'paint', 'hillshade-highlight-color', zoom, emptyObj, functionCache); + data.shadowColor = getValue(glLayer, 'paint', 'hillshade-shadow-color', zoom, emptyObj, functionCache); + data.accentColor = getValue(glLayer, 'paint', 'hillshade-accent-color', zoom, emptyObj, functionCache); + }); + layer.setVisible(glLayer.layout ? glLayer.layout.visibility !== 'none' : true); + } + const glSourceId = id; + if (layer) { + layer.set('mapbox-source', glSourceId); + } + return layer; +} +/** + * @param {*} glStyle Mapbox/MapLibre Style. + * @param {Map|LayerGroup} mapOrGroup Map or layer group. + * @param {string} styleUrl Style URL. + * @param {Options} options Options. + * @return {Promise} Promise that resolves when the style is loaded. + */ +function processStyle(glStyle, mapOrGroup, styleUrl, options) { + const promises = []; + let view = null; + if (mapOrGroup instanceof Map) { + view = mapOrGroup.getView(); + if (!view.isDef() && !view.getRotation() && !view.getResolutions()) { + const projection = options.projection ? get$1(options.projection) : view.getProjection(); + view = new View(Object.assign(view.getProperties(), { + maxResolution: defaultResolutions[0] / METERS_PER_UNIT[projection.getUnits()], + projection: options.projection || view.getProjection() + })); + mapOrGroup.setView(view); + } + if ('center' in glStyle && !view.getCenter()) { + view.setCenter(fromLonLat(glStyle.center, view.getProjection())); + } + if ('zoom' in glStyle && view.getZoom() === undefined) { + view.setResolution(defaultResolutions[0] / METERS_PER_UNIT[view.getProjection().getUnits()] / Math.pow(2, glStyle.zoom)); + } + if (!view.getCenter() || view.getZoom() === undefined) { + view.fit(view.getProjection().getExtent(), { + nearest: true, + size: mapOrGroup.getSize() + }); + } + } + mapOrGroup.set('mapbox-style', glStyle); + mapOrGroup.set('mapbox-metadata', { + styleUrl, + options + }); + const glLayers = glStyle.layers; + let layerIds = []; + let layer, glSourceId, id; + for (let i = 0, ii = glLayers.length; i < ii; ++i) { + const glLayer = glLayers[i]; + const type = glLayer.type; + if (type == 'heatmap') { + //FIXME Unsupported layer type + // eslint-disable-next-line no-console + console.debug(`layers[${ i }].type "${ type }" not supported`); + continue; + } else { + id = glLayer.source || getSourceIdByRef(glLayers, glLayer.ref); + // this technique assumes gl layers will be in a particular order + if (!id || id != glSourceId) { + if (layerIds.length) { + promises.push(finalizeLayer(layer, layerIds, glStyle, styleUrl, mapOrGroup, options)); + layerIds = []; + } + layer = setupLayer(glStyle, styleUrl, glLayer, options); + if (!(layer instanceof VectorLayer || layer instanceof VectorTileLayer)) { + layerIds = []; + } + glSourceId = layer.get('mapbox-source'); + } + layerIds.push(glLayer.id); + } + } + promises.push(finalizeLayer(layer, layerIds, glStyle, styleUrl, mapOrGroup, options)); + return Promise.all(promises); +} +/** + * Loads and applies a Mapbox/MapLibre Style object into an OpenLayers Map or LayerGroup. + * This includes the map background, the layers, and for Map instances that did not + * have a View defined yet also the center and the zoom. + * + * **Example:** + * ```js + * import apply from 'ol-mapbox-style'; + * + * apply('map', 'mapbox://styles/mapbox/bright-v9', {accessToken: 'YOUR_MAPBOX_TOKEN'}); + * ``` + * + * The center and zoom will only be set if present in the Mapbox/MapLibre Style document, + * and if not already set on the OpenLayers map. + * + * Layers will be added to the OpenLayers map, without affecting any layers that + * might already be set on the map. + * + * Layers added by `apply()` will have two additional properties: + * + * * `mapbox-source`: The `id` of the Mapbox/MapLibre Style document's source that the + * OpenLayers layer was created from. Usually `apply()` creates one + * OpenLayers layer per Mapbox/MapLibre Style source, unless the layer stack has + * layers from different sources in between. + * * `mapbox-layers`: The `id`s of the Mapbox/MapLibre Style document's layers that are + * included in the OpenLayers layer. + * + * This function sets an additional `mapbox-style` property on the OpenLayers + * Map or LayerGroup instance, which holds the Mapbox/MapLibre Style object. + * + * @param {Map|HTMLElement|string|LayerGroup} mapOrGroupOrElement Either an existing + * OpenLayers Map instance, or a HTML element, or the id of a HTML element that will be + * the target of a new OpenLayers Map, or a layer group. If layer group, styles + * releated to the map and view will be ignored. + * @param {string|Object} style JSON style object or style url pointing to a + * Mapbox/MapLibre Style object. When using Mapbox APIs, the url is the `styleUrl` + * shown in Mapbox Studio's "share" panel. In addition, the `accessToken` option + * (see below) must be set. + * When passed as JSON style object, all OpenLayers layers created by `apply()` + * will be immediately available, but they may not have a source yet (i.e. when + * they are defined by a TileJSON url in the Mapbox/MapLibre Style document). When passed + * as style url, layers will be added to the map when the Mapbox/MapLibre Style document + * is loaded and parsed. + * @param {Options} options Options. + * @return {Promise} A promise that resolves after all layers have been added to + * the OpenLayers Map instance or LayerGroup, their sources set, and their styles applied. The + * `resolve` callback will be called with the OpenLayers Map instance or LayerGroup as + * argument. + */ +function apply(mapOrGroupOrElement, style, options = {}) { + let promise; + /** @type {Map|LayerGroup} */ + let mapOrGroup; + if (typeof mapOrGroupOrElement === 'string' || mapOrGroupOrElement instanceof HTMLElement) { + mapOrGroup = new Map({ target: mapOrGroupOrElement }); + } else { + mapOrGroup = mapOrGroupOrElement; + } + if (typeof style === 'string') { + const styleUrl = style.startsWith('data:') ? location.href : normalizeStyleUrl(style, options.accessToken); + options = completeOptions(styleUrl, options); + promise = new Promise(function (resolve, reject) { + getGlStyle(style, options).then(function (glStyle) { + processStyle(glStyle, mapOrGroup, styleUrl, options).then(function () { + resolve(mapOrGroup); + }).catch(reject); + }).catch(function (err) { + reject(new Error(`Could not load ${ style }: ${ err.message }`)); + }); + }); + } else { + promise = new Promise(function (resolve, reject) { + processStyle(style, mapOrGroup, !options.styleUrl || options.styleUrl.startsWith('data:') ? location.href : normalizeStyleUrl(options.styleUrl, options.accessToken), options).then(function () { + resolve(mapOrGroup); + }).catch(reject); + }); + } + return promise; +} +/** + * If layerIds is not empty, applies the style specified in glStyle to the layer, + * and adds the layer to the map. + * + * The layer may not yet have a source when the function is called. If so, the style + * is applied to the layer via a once listener on the 'change:source' event. + * + * @param {Layer} layer An OpenLayers layer instance. + * @param {Array} layerIds Array containing layer ids of already-processed layers. + * @param {Object} glStyle Style as a JSON object. + * @param {string|undefined} styleUrl The original style URL. Only required + * when a relative path is used with the `"sprite"` property of the style. + * @param {Map|LayerGroup} mapOrGroup OpenLayers Map. + * @param {Options} options Options. + * @return {Promise} Returns a promise that resolves after the source has + * been set on the specified layer, and the style has been applied. + */ +function finalizeLayer(layer, layerIds, glStyle, styleUrl, mapOrGroup, options = {}) { + let minZoom = 24; + let maxZoom = 0; + const glLayers = glStyle.layers; + for (let i = 0, ii = glLayers.length; i < ii; ++i) { + const glLayer = glLayers[i]; + if (layerIds.indexOf(glLayer.id) !== -1) { + minZoom = Math.min('minzoom' in glLayer ? glLayer.minzoom : 0, minZoom); + maxZoom = Math.max('maxzoom' in glLayer ? glLayer.maxzoom : 24, maxZoom); + } + } + return new Promise(function (resolve, reject) { + const setStyle = function () { + const source = layer.getSource(); + if (!source || source.getState() === 'error') { + reject(new Error('Error accessing data for source ' + layer.get('mapbox-source'))); + return; + } + if ('getTileGrid' in source) { + const tileGrid = /** @type {import("ol/source/Tile.js").default|import("ol/source/VectorTile.js").default} */ + source.getTileGrid(); + if (tileGrid) { + const sourceMinZoom = tileGrid.getMinZoom(); + if (minZoom > 0 || sourceMinZoom > 0) { + layer.setMaxResolution(Math.min(getResolutionForZoom(Math.max(0, minZoom - 1e-12), defaultResolutions), getResolutionForZoom(Math.max(0, sourceMinZoom - 1e-12), tileGrid.getResolutions()))); + } + if (maxZoom < 24) { + layer.setMinResolution(getResolutionForZoom(maxZoom, defaultResolutions)); + } + } + } else { + if (minZoom > 0) { + layer.setMaxResolution(getResolutionForZoom(Math.max(0, minZoom - 1e-12), defaultResolutions)); + } + } + if (source instanceof VectorSource || source instanceof VectorTileSource) { + applyStyle(layer, glStyle, layerIds, Object.assign({ styleUrl: styleUrl }, options)).then(function () { + manageVisibility(layer, mapOrGroup); + resolve(); + }).catch(reject); + } else { + resolve(); + } + }; + layer.set('mapbox-layers', layerIds); + const layers = mapOrGroup.getLayers(); + if (layers.getArray().indexOf(layer) === -1) { + layers.push(layer); + } + if (layer.getSource()) { + setStyle(); + } else { + layer.once('change:source', setStyle); + } + }); +} +/** + * Get the Mapbox Layer object for the provided `layerId`. + * @param {Map|LayerGroup} mapOrGroup Map or LayerGroup. + * @param {string} layerId Mapbox Layer id. + * @return {Object} Mapbox Layer object. + */ +function getMapboxLayer(mapOrGroup, layerId) { + const style = mapOrGroup.get('mapbox-style'); + const layerStyle = style.layers.find(function (layer) { + return layer.id === layerId; + }); + return layerStyle; +} +/** + * Add a new Mapbox Layer object to the style. The map will be re-rendered. + * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on. + * @param {Object} mapboxLayer Mapbox Layer object. + * @param {string} [beforeLayerId] Optional id of the Mapbox Layer before the new layer that will be added. + * @return {Promise} Resolves when the added layer is available. + */ +function addMapboxLayer(mapOrGroup, mapboxLayer, beforeLayerId) { + const glStyle = mapOrGroup.get('mapbox-style'); + const mapboxLayers = glStyle.layers; + let spliceIndex; + let sourceIndex = -1; + if (beforeLayerId !== undefined) { + const beforeMapboxLayer = getMapboxLayer(mapOrGroup, beforeLayerId); + if (beforeMapboxLayer === undefined) { + throw new Error(`Layer with id "${ beforeLayerId }" not found.`); + } + spliceIndex = mapboxLayers.indexOf(beforeMapboxLayer); + } else { + spliceIndex = mapboxLayers.length; + } + let sourceOffset; + if (spliceIndex > 0 && mapboxLayers[spliceIndex - 1].source === mapboxLayer.source) { + sourceIndex = spliceIndex - 1; + sourceOffset = -1; + } else if (spliceIndex < mapboxLayers.length && mapboxLayers[spliceIndex].source === mapboxLayer.source) { + sourceIndex = spliceIndex; + sourceOffset = 0; + } + if (sourceIndex === -1) { + const {options, styleUrl} = mapOrGroup.get('mapbox-metadata'); + const layer = setupLayer(glStyle, styleUrl, mapboxLayer, options); + if (beforeLayerId) { + const beforeLayer = getLayer(mapOrGroup, beforeLayerId); + const beforeLayerIndex = mapOrGroup.getLayers().getArray().indexOf(beforeLayer); + mapOrGroup.getLayers().insertAt(beforeLayerIndex, layer); + } + mapboxLayers.splice(spliceIndex, 0, mapboxLayer); + return finalizeLayer(layer, [mapboxLayer.id], glStyle, styleUrl, mapOrGroup, options); + } + if (mapboxLayers.some(layer => layer.id === mapboxLayer.id)) { + throw new Error(`Layer with id "${ mapboxLayer.id }" already exists.`); + } + const sourceLayerId = mapboxLayers[sourceIndex].id; + const args = styleFunctionArgs[getStyleFunctionKey(mapOrGroup.get('mapbox-style'), getLayer(mapOrGroup, sourceLayerId))]; + mapboxLayers.splice(spliceIndex, 0, mapboxLayer); + if (args) { + const [olLayer, glStyle, sourceOrLayers, resolutions, spriteData, spriteImageUrl, getFonts, getImage] = args; + if (Array.isArray(sourceOrLayers)) { + const layerIndex = sourceOrLayers.indexOf(sourceLayerId) + sourceOffset; + sourceOrLayers.splice(layerIndex, 0, mapboxLayer.id); + } + stylefunction(olLayer, glStyle, sourceOrLayers, resolutions, spriteData, spriteImageUrl, getFonts, getImage); + } else { + getLayer(mapOrGroup, mapboxLayers[sourceIndex].id).changed(); + } + return Promise.resolve(); +} +/** + * Update a Mapbox Layer object in the style. The map will be re-rendered with the new style. + * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on. + * @param {Object} mapboxLayer Updated Mapbox Layer object. + */ +function updateMapboxLayer(mapOrGroup, mapboxLayer) { + const glStyle = mapOrGroup.get('mapbox-style'); + const mapboxLayers = glStyle.layers; + const index = mapboxLayers.findIndex(function (layer) { + return layer.id === mapboxLayer.id; + }); + if (index === -1) { + throw new Error(`Layer with id "${ mapboxLayer.id }" not found.`); + } + const oldLayer = mapboxLayers[index]; + if (oldLayer.source !== mapboxLayer.source) { + throw new Error('Updated layer and previous version must use the same source.'); + } + delete getFunctionCache(glStyle)[mapboxLayer.id]; + delete getFilterCache(glStyle)[mapboxLayer.id]; + mapboxLayers[index] = mapboxLayer; + const args = styleFunctionArgs[getStyleFunctionKey(mapOrGroup.get('mapbox-style'), getLayer(mapOrGroup, mapboxLayer.id))]; + if (args) { + stylefunction.apply(undefined, args); + } else { + getLayer(mapOrGroup, mapboxLayer.id).changed(); + } +} +/** + * Updates a Mapbox source object in the style. The according OpenLayers source will be replaced + * and the map will be re-rendered. + * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on. + * @param {string} id Key of the source in the `sources` object literal. + * @param {Object} mapboxSource Mapbox source object. + * @return {Promise} Promise that resolves when the source has been updated. + */ +function updateMapboxSource(mapOrGroup, id, mapboxSource) { + const currentSource = getSource(mapOrGroup, id); + const layers = mapOrGroup.getLayers().getArray().filter(function (layer) { + return (layer instanceof VectorLayer || layer instanceof TileLayer || layer instanceof VectorTileLayer) && layer.getSource() === currentSource; + }); + const metadata = mapOrGroup.get('mapbox-metadata'); + let newSourcePromise; + switch (mapboxSource.type) { + case 'vector': + newSourcePromise = setupVectorSource(mapboxSource, metadata.styleUrl, metadata.options); + break; + case 'geojson': + newSourcePromise = Promise.resolve(setupGeoJSONSource(mapboxSource, metadata.styleUrl, metadata.options)); + break; + case 'raster': + case 'raster-dem': + newSourcePromise = setupRasterSource(mapboxSource, metadata.styleUrl, metadata.options); + break; + default: + return Promise.reject(new Error('Unsupported source type ' + mapboxSource.type)); + } + newSourcePromise.then(function (newSource) { + layers.forEach(function (layer) { + layer.setSource(newSource); + }); + }); + return newSourcePromise; +} +/** + * Remove a Mapbox Layer object from the style. The map will be re-rendered. + * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on. + * @param {string|Object} mapboxLayerIdOrLayer Mapbox Layer id or Mapbox Layer object. + */ +function removeMapboxLayer(mapOrGroup, mapboxLayerIdOrLayer) { + const mapboxLayerId = typeof mapboxLayerIdOrLayer === 'string' ? mapboxLayerIdOrLayer : mapboxLayerIdOrLayer.id; + const layer = getLayer(mapOrGroup, mapboxLayerId); + /** @type {Array} */ + const layerMapboxLayers = layer.get('mapbox-layers'); + if (layerMapboxLayers.length === 1) { + throw new Error('Cannot remove last Mapbox layer from an OpenLayers layer.'); + } + layerMapboxLayers.splice(layerMapboxLayers.indexOf(mapboxLayerId), 1); + const glStyle = mapOrGroup.get('mapbox-style'); + const layers = glStyle.layers; + layers.splice(layers.findIndex(layer => layer.id === mapboxLayerId), 1); + const args = styleFunctionArgs[getStyleFunctionKey(glStyle, layer)]; + if (args) { + const [olLayer, glStyle, sourceOrLayers, resolutions, spriteData, spriteImageUrl, getFonts, getImage] = args; + if (Array.isArray(sourceOrLayers)) { + sourceOrLayers.splice(sourceOrLayers.findIndex(layer => layer === mapboxLayerId), 1); + } + stylefunction(olLayer, glStyle, sourceOrLayers, resolutions, spriteData, spriteImageUrl, getFonts, getImage); + } else { + getLayer(mapOrGroup, mapboxLayerId).changed(); + } +} +/** + * Get the OpenLayers layer instance that contains the provided Mapbox/MapLibre Style + * `layer`. Note that multiple Mapbox/MapLibre Style layers are combined in a single + * OpenLayers layer instance when they use the same Mapbox/MapLibre Style `source`. + * @param {Map|LayerGroup} map OpenLayers Map or LayerGroup. + * @param {string} layerId Mapbox/MapLibre Style layer id. + * @return {Layer} OpenLayers layer instance. + */ +function getLayer(map, layerId) { + const layers = map.getLayers().getArray(); + for (let i = 0, ii = layers.length; i < ii; ++i) { + const mapboxLayers = layers[i].get('mapbox-layers'); + if (mapboxLayers && mapboxLayers.indexOf(layerId) !== -1) { + return layers[i]; + } + } + return undefined; +} +/** + * Get the OpenLayers layer instances for the provided Mapbox/MapLibre Style `source`. + * @param {Map|LayerGroup} map OpenLayers Map or LayerGroup. + * @param {string} sourceId Mapbox/MapLibre Style source id. + * @return {Array} OpenLayers layer instances. + */ +function getLayers(map, sourceId) { + const result = []; + const layers = map.getLayers().getArray(); + for (let i = 0, ii = layers.length; i < ii; ++i) { + if (layers[i].get('mapbox-source') === sourceId) { + result.push(layers[i]); + } + } + return result; +} +/** + * Get the OpenLayers source instance for the provided Mapbox/MapLibre Style `source`. + * @param {Map|LayerGroup} map OpenLayers Map or LayerGroup. + * @param {string} sourceId Mapbox/MapLibre Style source id. + * @return {Source} OpenLayers source instance. + */ +function getSource(map, sourceId) { + const layers = map.getLayers().getArray(); + for (let i = 0, ii = layers.length; i < ii; ++i) { + const source = /** @type {Layer} */ + layers[i].getSource(); + if (layers[i].get('mapbox-source') === sourceId) { + return source; + } + } + return undefined; +} +/** + * Sets or removes a feature state. The feature state is taken into account for styling, + * just like the feature's properties, and can be used e.g. to conditionally render selected + * features differently. + * + * The feature state will be stored on the OpenLayers layer matching the feature identifier, in the + * `mapbox-featurestate` property. + * @param {Map|VectorLayer|VectorTileLayer} mapOrLayer OpenLayers Map or layer to set the feature + * state on. + * @param {FeatureIdentifier} feature Feature identifier. + * @param {Object|null} state Feature state. Set to `null` to remove the feature state. + */ +function setFeatureState(mapOrLayer, feature, state) { + const layers = 'getLayers' in mapOrLayer ? getLayers(mapOrLayer, feature.source) : [mapOrLayer]; + for (let i = 0, ii = layers.length; i < ii; ++i) { + const featureState = layers[i].get('mapbox-featurestate'); + if (featureState) { + if (state) { + featureState[feature.id] = state; + } else { + delete featureState[feature.id]; + } + layers[i].changed(); + } else { + throw new Error(`Map or layer for source "${ feature.source }" not found.`); + } + } +} +/** + * Sets or removes a feature state. The feature state is taken into account for styling, + * just like the feature's properties, and can be used e.g. to conditionally render selected + * features differently. + * @param {Map|VectorLayer|VectorTileLayer} mapOrLayer Map or layer to set the feature state on. + * @param {FeatureIdentifier} feature Feature identifier. + * @return {Object|null} Feature state or `null` when no feature state is set for the given + * feature identifier. + */ +function getFeatureState(mapOrLayer, feature) { + const layers = 'getLayers' in mapOrLayer ? getLayers(mapOrLayer, feature.source) : [mapOrLayer]; + for (let i = 0, ii = layers.length; i < ii; ++i) { + const featureState = layers[i].get('mapbox-featurestate'); + if (featureState && featureState[feature.id]) { + return featureState[feature.id]; + } + } + return undefined; +} + +/** @typedef {import("ol/Map.js").default} Map */ +/** + * @classdesc + * Event emitted on configuration or loading error. + */ +class ErrorEvent extends BaseEvent { + /** + * @param {Error} error error object. + */ + constructor(error) { + super(EventType.ERROR); + /** + * @type {Error} + */ + this.error = error; + } +} +/** + * @typedef {Object} Options + * @property {string} styleUrl The URL of the Mapbox/MapLibre Style object to use for this layer. For a + * style created with Mapbox Studio and hosted on Mapbox, this will look like + * 'mapbox://styles/you/your-style'. + * @property {string} [accessToken] The access token for your Mapbox/MapLibre style. This has to be provided + * for `mapbox://` style urls. For `https://` and other urls, any access key must be the last query + * parameter of the style url. + * @property {string} [source] If your style uses more than one source, you need to use either the + * `source` property or the `layers` property to limit rendering to a single vector source. The + * `source` property corresponds to the id of a vector source in your Mapbox/MapLibre style. + * @property {Array} [layers] Limit rendering to the list of included layers. All layers + * must share the same vector source. If your style uses more than one source, you need to use + * either the `source` property or the `layers` property to limit rendering to a single vector + * source. + * @property {boolean} [declutter=true] Declutter images and text. Decluttering is applied to all + * image and text styles of all Vector and VectorTile layers that have set this to `true`. The priority + * is defined by the z-index of the layer, the `zIndex` of the style and the render order of features. + * Higher z-index means higher priority. Within the same z-index, a feature rendered before another has + * higher priority. + * + * As an optimization decluttered features from layers with the same `className` are rendered above + * the fill and stroke styles of all of those layers regardless of z-index. To opt out of this + * behavior and place declutterd features with their own layer configure the layer with a `className` + * other than `ol-layer`. + * @property {import("ol/layer/Base.js").BackgroundColor|false} [background] Background color for the layer. + * If not specified, the background from the Mapbox/MapLibre Style object will be used. Set to `false` to prevent + * the Mapbox/MapLibre style's background from being used. + * @property {string} [className='ol-layer'] A CSS class name to set to the layer element. + * @property {number} [opacity=1] Opacity (0, 1). + * @property {boolean} [visible=true] Visibility. + * @property {import("ol/extent.js").Extent} [extent] The bounding extent for layer rendering. The layer will not be + * rendered outside of this extent. + * @property {number} [zIndex] The z-index for layer rendering. At rendering time, the layers + * will be ordered, first by Z-index and then by position. When `undefined`, a `zIndex` of 0 is assumed + * for layers that are added to the map's `layers` collection, or `Infinity` when the layer's `setMap()` + * method was used. + * @property {number} [minResolution] The minimum resolution (inclusive) at which this layer will be + * visible. + * @property {number} [maxResolution] The maximum resolution (exclusive) below which this layer will + * be visible. If neither `maxResolution` nor `minZoom` are defined, the layer's `maxResolution` will + * match the style source's `minzoom`. + * @property {number} [minZoom] The minimum view zoom level (exclusive) above which this layer will + * be visible. If neither `maxResolution` nor `minZoom` are defined, the layer's `minZoom` will match + * the style source's `minzoom`. + * @property {number} [maxZoom] The maximum view zoom level (inclusive) at which this layer will + * be visible. + * @property {import("ol/render.js").OrderFunction} [renderOrder] Render order. Function to be used when sorting + * features before rendering. By default features are drawn in the order that they are created. Use + * `null` to avoid the sort, but get an undefined draw order. + * @property {number} [renderBuffer=100] The buffer in pixels around the tile extent used by the + * renderer when getting features from the vector tile for the rendering or hit-detection. + * Recommended value: Vector tiles are usually generated with a buffer, so this value should match + * the largest possible buffer of the used tiles. It should be at least the size of the largest + * point symbol or line width. + * @property {import("ol/layer/VectorTile.js").VectorTileRenderType} [renderMode='hybrid'] Render mode for vector tiles: + * * `'hybrid'`: Polygon and line elements are rendered as images, so pixels are scaled during zoom + * animations. Point symbols and texts are accurately rendered as vectors and can stay upright on + * rotated views. + * * `'vector'`: Everything is rendered as vectors. Use this mode for improved performance on vector + * tile layers with only a few rendered features (e.g. for highlighting a subset of features of + * another layer with the same source). + * @property {import("ol/Map.js").default} [map] Sets the layer as overlay on a map. The map will not manage + * this layer in its layers collection, and the layer will be rendered on top. This is useful for + * temporary layers. The standard way to add a layer to a map and have it managed by the map is to + * use `map.addLayer()`. + * @property {boolean} [updateWhileAnimating=false] When set to `true`, feature batches will be + * recreated during animations. This means that no vectors will be shown clipped, but the setting + * will have a performance impact for large amounts of vector data. When set to `false`, batches + * will be recreated when no animation is active. + * @property {boolean} [updateWhileInteracting=false] When set to `true`, feature batches will be + * recreated during interactions. See also `updateWhileAnimating`. + * @property {number} [preload=0] Preload. Load low-resolution tiles up to `preload` levels. `0` + * means no preloading. + * @property {boolean} [useInterimTilesOnError=true] Use interim tiles on error. + * @property {Object} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`. + */ +/** + * @classdesc + * ```js + * import {MapboxVectorLayer} from 'ol-mapbox-style'; + * ``` + * A vector tile layer based on a Mapbox/MapLibre style that uses a single vector source. Configure + * the layer with the `styleUrl` and `accessToken` shown in Mapbox Studio's share panel. + * If the style uses more than one source, use the `source` property to choose a single + * vector source. If you want to render a subset of the layers in the style, use the `layers` + * property (all layers must share the same vector source). See the constructor options for + * more detail. + * + * const map = new Map({ + * view: new View({ + * center: [0, 0], + * zoom: 1, + * }), + * layers: [ + * new MapboxVectorLayer({ + * styleUrl: 'mapbox://styles/mapbox/bright-v9', + * accessToken: 'your-mapbox-access-token-here', + * }), + * ], + * target: 'map', + * }); + * + * On configuration or loading error, the layer will trigger an `'error'` event. Listeners + * will receive an object with an `error` property that can be used to diagnose the problem. + * + * **Note for users of the full build**: The `MapboxVectorLayer` requires the + * [ol-mapbox-style](https://github.com/openlayers/ol-mapbox-style) library to be loaded as well. + * + * @param {Options} options Options. + * @extends {VectorTileLayer} + * @fires module:ol/events/Event~BaseEvent#event:error + * @api + */ +class MapboxVectorLayer extends VectorTileLayer { + /** + * @param {Options} options Layer options. At a minimum, `styleUrl` and `accessToken` + * must be provided. + */ + constructor(options) { + const declutter = 'declutter' in options ? options.declutter : true; + const source = new VectorTileSource({ + state: 'loading', + format: new MVT() + }); + super({ + source: source, + background: options.background === false ? null : options.background, + declutter: declutter, + className: options.className, + opacity: options.opacity, + visible: options.visible, + zIndex: options.zIndex, + minResolution: options.minResolution, + maxResolution: options.maxResolution, + minZoom: options.minZoom, + maxZoom: options.maxZoom, + renderOrder: options.renderOrder, + renderBuffer: options.renderBuffer, + renderMode: options.renderMode, + map: options.map, + updateWhileAnimating: options.updateWhileAnimating, + updateWhileInteracting: options.updateWhileInteracting, + preload: options.preload, + useInterimTilesOnError: options.useInterimTilesOnError, + properties: options.properties + }); + if (options.accessToken) { + this.accessToken = options.accessToken; + } + const url = options.styleUrl; + const promises = [applyStyle(this, url, options.layers || options.source, { accessToken: this.accessToken })]; + if (this.getBackground() === undefined) { + promises.push(applyBackground(this, options.styleUrl, { accessToken: this.accessToken })); + } + Promise.all(promises).then(() => { + source.setState('ready'); + }).catch(error => { + this.dispatchEvent(new ErrorEvent(error)); + const source = this.getSource(); + source.setState('error'); + }); + } +} + +export { MapboxVectorLayer, addMapboxLayer, apply, applyBackground, applyStyle, apply as default, getFeatureState, getLayer, getLayers, getMapboxLayer, getSource, getStyleForLayer, recordStyleLayer, removeMapboxLayer, renderTransparent, setFeatureState, stylefunction, updateMapboxLayer, updateMapboxSource }; +//# sourceMappingURL=index.js.map diff --git a/dist/index.js.map b/dist/index.js.map new file mode 100644 index 00000000..f338db69 --- /dev/null +++ b/dist/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sources":["../node_modules/csscolorparser/csscolorparser.js","../node_modules/@mapbox/mapbox-gl-style-spec/util/color.js","../node_modules/@mapbox/mapbox-gl-style-spec/function/convert.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/parsing_error.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/scope.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/types.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/types/collator.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/types/formatted.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/types/resolved_image.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/values.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/literal.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/runtime_error.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/assertion.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/format.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/image.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/coercion.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/evaluation_context.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/compound_expression.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/collator.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/within.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/is_constant.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/var.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/parsing_context.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/stops.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/step.js","../node_modules/@mapbox/unitbezier/index.js","../node_modules/@mapbox/mapbox-gl-style-spec/util/interpolate.js","../node_modules/@mapbox/mapbox-gl-style-spec/util/color_spaces.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/interpolate.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/coalesce.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/let.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/at.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/in.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/index_of.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/match.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/case.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/slice.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/comparison.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/number_format.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/length.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/definitions/index.js","../node_modules/@mapbox/mapbox-gl-style-spec/util/result.js","../node_modules/@mapbox/mapbox-gl-style-spec/util/properties.js","../node_modules/@mapbox/mapbox-gl-style-spec/function/index.js","../node_modules/@mapbox/mapbox-gl-style-spec/expression/index.js","../node_modules/@mapbox/mapbox-gl-style-spec/util/unbundle_jsonlint.js","../node_modules/@mapbox/mapbox-gl-style-spec/reference/v8.json","../node_modules/@mapbox/mapbox-gl-style-spec/feature_filter/index.js","../node_modules/@mapbox/mapbox-gl-style-spec/util/ref_properties.js","../node_modules/@mapbox/mapbox-gl-style-spec/deref.js","../node_modules/mapbox-to-css-font/index.js","../src/mapbox.js","../src/util.js","../src/text.js","../src/stylefunction.js","../src/shaders.js","../src/apply.js","../src/MapboxVectorLayer.js"],"sourcesContent":["// (c) Dean McNamee , 2012.\n//\n// https://github.com/deanm/css-color-parser-js\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS\n// IN THE SOFTWARE.\n\n// http://www.w3.org/TR/css3-color/\nvar kCSSColorTable = {\n \"transparent\": [0,0,0,0], \"aliceblue\": [240,248,255,1],\n \"antiquewhite\": [250,235,215,1], \"aqua\": [0,255,255,1],\n \"aquamarine\": [127,255,212,1], \"azure\": [240,255,255,1],\n \"beige\": [245,245,220,1], \"bisque\": [255,228,196,1],\n \"black\": [0,0,0,1], \"blanchedalmond\": [255,235,205,1],\n \"blue\": [0,0,255,1], \"blueviolet\": [138,43,226,1],\n \"brown\": [165,42,42,1], \"burlywood\": [222,184,135,1],\n \"cadetblue\": [95,158,160,1], \"chartreuse\": [127,255,0,1],\n \"chocolate\": [210,105,30,1], \"coral\": [255,127,80,1],\n \"cornflowerblue\": [100,149,237,1], \"cornsilk\": [255,248,220,1],\n \"crimson\": [220,20,60,1], \"cyan\": [0,255,255,1],\n \"darkblue\": [0,0,139,1], \"darkcyan\": [0,139,139,1],\n \"darkgoldenrod\": [184,134,11,1], \"darkgray\": [169,169,169,1],\n \"darkgreen\": [0,100,0,1], \"darkgrey\": [169,169,169,1],\n \"darkkhaki\": [189,183,107,1], \"darkmagenta\": [139,0,139,1],\n \"darkolivegreen\": [85,107,47,1], \"darkorange\": [255,140,0,1],\n \"darkorchid\": [153,50,204,1], \"darkred\": [139,0,0,1],\n \"darksalmon\": [233,150,122,1], \"darkseagreen\": [143,188,143,1],\n \"darkslateblue\": [72,61,139,1], \"darkslategray\": [47,79,79,1],\n \"darkslategrey\": [47,79,79,1], \"darkturquoise\": [0,206,209,1],\n \"darkviolet\": [148,0,211,1], \"deeppink\": [255,20,147,1],\n \"deepskyblue\": [0,191,255,1], \"dimgray\": [105,105,105,1],\n \"dimgrey\": [105,105,105,1], \"dodgerblue\": [30,144,255,1],\n \"firebrick\": [178,34,34,1], \"floralwhite\": [255,250,240,1],\n \"forestgreen\": [34,139,34,1], \"fuchsia\": [255,0,255,1],\n \"gainsboro\": [220,220,220,1], \"ghostwhite\": [248,248,255,1],\n \"gold\": [255,215,0,1], \"goldenrod\": [218,165,32,1],\n \"gray\": [128,128,128,1], \"green\": [0,128,0,1],\n \"greenyellow\": [173,255,47,1], \"grey\": [128,128,128,1],\n \"honeydew\": [240,255,240,1], \"hotpink\": [255,105,180,1],\n \"indianred\": [205,92,92,1], \"indigo\": [75,0,130,1],\n \"ivory\": [255,255,240,1], \"khaki\": [240,230,140,1],\n \"lavender\": [230,230,250,1], \"lavenderblush\": [255,240,245,1],\n \"lawngreen\": [124,252,0,1], \"lemonchiffon\": [255,250,205,1],\n \"lightblue\": [173,216,230,1], \"lightcoral\": [240,128,128,1],\n \"lightcyan\": [224,255,255,1], \"lightgoldenrodyellow\": [250,250,210,1],\n \"lightgray\": [211,211,211,1], \"lightgreen\": [144,238,144,1],\n \"lightgrey\": [211,211,211,1], \"lightpink\": [255,182,193,1],\n \"lightsalmon\": [255,160,122,1], \"lightseagreen\": [32,178,170,1],\n \"lightskyblue\": [135,206,250,1], \"lightslategray\": [119,136,153,1],\n \"lightslategrey\": [119,136,153,1], \"lightsteelblue\": [176,196,222,1],\n \"lightyellow\": [255,255,224,1], \"lime\": [0,255,0,1],\n \"limegreen\": [50,205,50,1], \"linen\": [250,240,230,1],\n \"magenta\": [255,0,255,1], \"maroon\": [128,0,0,1],\n \"mediumaquamarine\": [102,205,170,1], \"mediumblue\": [0,0,205,1],\n \"mediumorchid\": [186,85,211,1], \"mediumpurple\": [147,112,219,1],\n \"mediumseagreen\": [60,179,113,1], \"mediumslateblue\": [123,104,238,1],\n \"mediumspringgreen\": [0,250,154,1], \"mediumturquoise\": [72,209,204,1],\n \"mediumvioletred\": [199,21,133,1], \"midnightblue\": [25,25,112,1],\n \"mintcream\": [245,255,250,1], \"mistyrose\": [255,228,225,1],\n \"moccasin\": [255,228,181,1], \"navajowhite\": [255,222,173,1],\n \"navy\": [0,0,128,1], \"oldlace\": [253,245,230,1],\n \"olive\": [128,128,0,1], \"olivedrab\": [107,142,35,1],\n \"orange\": [255,165,0,1], \"orangered\": [255,69,0,1],\n \"orchid\": [218,112,214,1], \"palegoldenrod\": [238,232,170,1],\n \"palegreen\": [152,251,152,1], \"paleturquoise\": [175,238,238,1],\n \"palevioletred\": [219,112,147,1], \"papayawhip\": [255,239,213,1],\n \"peachpuff\": [255,218,185,1], \"peru\": [205,133,63,1],\n \"pink\": [255,192,203,1], \"plum\": [221,160,221,1],\n \"powderblue\": [176,224,230,1], \"purple\": [128,0,128,1],\n \"rebeccapurple\": [102,51,153,1],\n \"red\": [255,0,0,1], \"rosybrown\": [188,143,143,1],\n \"royalblue\": [65,105,225,1], \"saddlebrown\": [139,69,19,1],\n \"salmon\": [250,128,114,1], \"sandybrown\": [244,164,96,1],\n \"seagreen\": [46,139,87,1], \"seashell\": [255,245,238,1],\n \"sienna\": [160,82,45,1], \"silver\": [192,192,192,1],\n \"skyblue\": [135,206,235,1], \"slateblue\": [106,90,205,1],\n \"slategray\": [112,128,144,1], \"slategrey\": [112,128,144,1],\n \"snow\": [255,250,250,1], \"springgreen\": [0,255,127,1],\n \"steelblue\": [70,130,180,1], \"tan\": [210,180,140,1],\n \"teal\": [0,128,128,1], \"thistle\": [216,191,216,1],\n \"tomato\": [255,99,71,1], \"turquoise\": [64,224,208,1],\n \"violet\": [238,130,238,1], \"wheat\": [245,222,179,1],\n \"white\": [255,255,255,1], \"whitesmoke\": [245,245,245,1],\n \"yellow\": [255,255,0,1], \"yellowgreen\": [154,205,50,1]}\n\nfunction clamp_css_byte(i) { // Clamp to integer 0 .. 255.\n i = Math.round(i); // Seems to be what Chrome does (vs truncation).\n return i < 0 ? 0 : i > 255 ? 255 : i;\n}\n\nfunction clamp_css_float(f) { // Clamp to float 0.0 .. 1.0.\n return f < 0 ? 0 : f > 1 ? 1 : f;\n}\n\nfunction parse_css_int(str) { // int or percentage.\n if (str[str.length - 1] === '%')\n return clamp_css_byte(parseFloat(str) / 100 * 255);\n return clamp_css_byte(parseInt(str));\n}\n\nfunction parse_css_float(str) { // float or percentage.\n if (str[str.length - 1] === '%')\n return clamp_css_float(parseFloat(str) / 100);\n return clamp_css_float(parseFloat(str));\n}\n\nfunction css_hue_to_rgb(m1, m2, h) {\n if (h < 0) h += 1;\n else if (h > 1) h -= 1;\n\n if (h * 6 < 1) return m1 + (m2 - m1) * h * 6;\n if (h * 2 < 1) return m2;\n if (h * 3 < 2) return m1 + (m2 - m1) * (2/3 - h) * 6;\n return m1;\n}\n\nfunction parseCSSColor(css_str) {\n // Remove all whitespace, not compliant, but should just be more accepting.\n var str = css_str.replace(/ /g, '').toLowerCase();\n\n // Color keywords (and transparent) lookup.\n if (str in kCSSColorTable) return kCSSColorTable[str].slice(); // dup.\n\n // #abc and #abc123 syntax.\n if (str[0] === '#') {\n if (str.length === 4) {\n var iv = parseInt(str.substr(1), 16); // TODO(deanm): Stricter parsing.\n if (!(iv >= 0 && iv <= 0xfff)) return null; // Covers NaN.\n return [((iv & 0xf00) >> 4) | ((iv & 0xf00) >> 8),\n (iv & 0xf0) | ((iv & 0xf0) >> 4),\n (iv & 0xf) | ((iv & 0xf) << 4),\n 1];\n } else if (str.length === 7) {\n var iv = parseInt(str.substr(1), 16); // TODO(deanm): Stricter parsing.\n if (!(iv >= 0 && iv <= 0xffffff)) return null; // Covers NaN.\n return [(iv & 0xff0000) >> 16,\n (iv & 0xff00) >> 8,\n iv & 0xff,\n 1];\n }\n\n return null;\n }\n\n var op = str.indexOf('('), ep = str.indexOf(')');\n if (op !== -1 && ep + 1 === str.length) {\n var fname = str.substr(0, op);\n var params = str.substr(op+1, ep-(op+1)).split(',');\n var alpha = 1; // To allow case fallthrough.\n switch (fname) {\n case 'rgba':\n if (params.length !== 4) return null;\n alpha = parse_css_float(params.pop());\n // Fall through.\n case 'rgb':\n if (params.length !== 3) return null;\n return [parse_css_int(params[0]),\n parse_css_int(params[1]),\n parse_css_int(params[2]),\n alpha];\n case 'hsla':\n if (params.length !== 4) return null;\n alpha = parse_css_float(params.pop());\n // Fall through.\n case 'hsl':\n if (params.length !== 3) return null;\n var h = (((parseFloat(params[0]) % 360) + 360) % 360) / 360; // 0 .. 1\n // NOTE(deanm): According to the CSS spec s/l should only be\n // percentages, but we don't bother and let float or percentage.\n var s = parse_css_float(params[1]);\n var l = parse_css_float(params[2]);\n var m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n var m1 = l * 2 - m2;\n return [clamp_css_byte(css_hue_to_rgb(m1, m2, h+1/3) * 255),\n clamp_css_byte(css_hue_to_rgb(m1, m2, h) * 255),\n clamp_css_byte(css_hue_to_rgb(m1, m2, h-1/3) * 255),\n alpha];\n default:\n return null;\n }\n }\n\n return null;\n}\n\ntry { exports.parseCSSColor = parseCSSColor } catch(e) { }\n","// @flow\n\nimport {parseCSSColor} from 'csscolorparser';\n\n/**\n * An RGBA color value. Create instances from color strings using the static\n * method `Color.parse`. The constructor accepts RGB channel values in the range\n * `[0, 1]`, premultiplied by A.\n *\n * @param {number} r The red channel.\n * @param {number} g The green channel.\n * @param {number} b The blue channel.\n * @param {number} a The alpha channel.\n * @private\n */\nclass Color {\n r: number;\n g: number;\n b: number;\n a: number;\n\n constructor(r: number, g: number, b: number, a: number = 1) {\n this.r = r;\n this.g = g;\n this.b = b;\n this.a = a;\n }\n\n static black: Color;\n static white: Color;\n static transparent: Color;\n static red: Color;\n static blue: Color;\n\n /**\n * Parses valid CSS color strings and returns a `Color` instance.\n * @returns A `Color` instance, or `undefined` if the input is not a valid color string.\n */\n static parse(input?: string | Color | null): Color | void {\n if (!input) {\n return undefined;\n }\n\n if (input instanceof Color) {\n return input;\n }\n\n if (typeof input !== 'string') {\n return undefined;\n }\n\n const rgba = parseCSSColor(input);\n if (!rgba) {\n return undefined;\n }\n\n return new Color(\n rgba[0] / 255 * rgba[3],\n rgba[1] / 255 * rgba[3],\n rgba[2] / 255 * rgba[3],\n rgba[3]\n );\n }\n\n /**\n * Returns an RGBA string representing the color value.\n *\n * @returns An RGBA string.\n * @example\n * var purple = new Color.parse('purple');\n * purple.toString; // = \"rgba(128,0,128,1)\"\n * var translucentGreen = new Color.parse('rgba(26, 207, 26, .73)');\n * translucentGreen.toString(); // = \"rgba(26,207,26,0.73)\"\n */\n toString(): string {\n const [r, g, b, a] = this.toArray();\n return `rgba(${Math.round(r)},${Math.round(g)},${Math.round(b)},${a})`;\n }\n\n /**\n * Returns an RGBA array of values representing the color, unpremultiplied by A.\n *\n * @returns An array of RGBA color values in the range [0, 255].\n */\n toArray(): [number, number, number, number] {\n const {r, g, b, a} = this;\n return a === 0 ? [0, 0, 0, 0] : [\n r * 255 / a,\n g * 255 / a,\n b * 255 / a,\n a\n ];\n }\n\n /**\n * Returns a RGBA array of float values representing the color, unpremultiplied by A.\n *\n * @returns An array of RGBA color values in the range [0, 1].\n */\n toArray01(): [number, number, number, number] {\n const {r, g, b, a} = this;\n return a === 0 ? [0, 0, 0, 0] : [\n r / a,\n g / a,\n b / a,\n a\n ];\n }\n\n /**\n * Returns an RGBA array of values representing the color, premultiplied by A.\n *\n * @returns An array of RGBA color values in the range [0, 1].\n */\n toArray01PremultipliedAlpha(): [number, number, number, number] {\n const {r, g, b, a} = this;\n return [\n r,\n g,\n b,\n a\n ];\n }\n}\n\nColor.black = new Color(0, 0, 0, 1);\nColor.white = new Color(1, 1, 1, 1);\nColor.transparent = new Color(0, 0, 0, 0);\nColor.red = new Color(1, 0, 0, 1);\nColor.blue = new Color(0, 0, 1, 1);\n\nexport default Color;\n","// @flow\n\nimport assert from 'assert';\n\nimport type {StylePropertySpecification} from '../style-spec.js';\nimport type {ExpressionSpecification} from '../types.js';\n\nfunction convertLiteral(value) {\n return typeof value === 'object' ? ['literal', value] : value;\n}\n\nexport default function convertFunction(parameters: any, propertySpec: StylePropertySpecification): ExpressionSpecification {\n let stops = parameters.stops;\n if (!stops) {\n // identity function\n return convertIdentityFunction(parameters, propertySpec);\n }\n\n const zoomAndFeatureDependent = stops && typeof stops[0][0] === 'object';\n const featureDependent = zoomAndFeatureDependent || parameters.property !== undefined;\n const zoomDependent = zoomAndFeatureDependent || !featureDependent;\n\n stops = stops.map((stop) => {\n if (!featureDependent && propertySpec.tokens && typeof stop[1] === 'string') {\n return [stop[0], convertTokenString(stop[1])];\n }\n return [stop[0], convertLiteral(stop[1])];\n });\n\n if (zoomAndFeatureDependent) {\n return convertZoomAndPropertyFunction(parameters, propertySpec, stops);\n } else if (zoomDependent) {\n return convertZoomFunction(parameters, propertySpec, stops);\n } else {\n return convertPropertyFunction(parameters, propertySpec, stops);\n }\n}\n\nfunction convertIdentityFunction(parameters, propertySpec): Array {\n const get = ['get', parameters.property];\n\n if (parameters.default === undefined) {\n // By default, expressions for string-valued properties get coerced. To preserve\n // legacy function semantics, insert an explicit assertion instead.\n return propertySpec.type === 'string' ? ['string', get] : get;\n } else if (propertySpec.type === 'enum') {\n return [\n 'match',\n get,\n Object.keys(propertySpec.values),\n get,\n parameters.default\n ];\n } else {\n const expression = [propertySpec.type === 'color' ? 'to-color' : propertySpec.type, get, convertLiteral(parameters.default)];\n if (propertySpec.type === 'array') {\n expression.splice(1, 0, propertySpec.value, propertySpec.length || null);\n }\n return expression;\n }\n}\n\nfunction getInterpolateOperator(parameters) {\n switch (parameters.colorSpace) {\n case 'hcl': return 'interpolate-hcl';\n case 'lab': return 'interpolate-lab';\n default: return 'interpolate';\n }\n}\n\nfunction convertZoomAndPropertyFunction(parameters, propertySpec, stops) {\n const featureFunctionParameters = {};\n const featureFunctionStops = {};\n const zoomStops = [];\n for (let s = 0; s < stops.length; s++) {\n const stop = stops[s];\n const zoom = stop[0].zoom;\n if (featureFunctionParameters[zoom] === undefined) {\n featureFunctionParameters[zoom] = {\n zoom,\n type: parameters.type,\n property: parameters.property,\n default: parameters.default,\n };\n featureFunctionStops[zoom] = [];\n zoomStops.push(zoom);\n }\n featureFunctionStops[zoom].push([stop[0].value, stop[1]]);\n }\n\n // the interpolation type for the zoom dimension of a zoom-and-property\n // function is determined directly from the style property specification\n // for which it's being used: linear for interpolatable properties, step\n // otherwise.\n const functionType = getFunctionType({}, propertySpec);\n if (functionType === 'exponential') {\n const expression = [getInterpolateOperator(parameters), ['linear'], ['zoom']];\n\n for (const z of zoomStops) {\n const output = convertPropertyFunction(featureFunctionParameters[z], propertySpec, featureFunctionStops[z]);\n appendStopPair(expression, z, output, false);\n }\n\n return expression;\n } else {\n const expression = ['step', ['zoom']];\n\n for (const z of zoomStops) {\n const output = convertPropertyFunction(featureFunctionParameters[z], propertySpec, featureFunctionStops[z]);\n appendStopPair(expression, z, output, true);\n }\n\n fixupDegenerateStepCurve(expression);\n\n return expression;\n }\n}\n\nfunction coalesce(a, b) {\n if (a !== undefined) return a;\n if (b !== undefined) return b;\n}\n\nfunction getFallback(parameters, propertySpec) {\n const defaultValue = convertLiteral(coalesce(parameters.default, propertySpec.default));\n\n /*\n * Some fields with type: resolvedImage have an undefined default.\n * Because undefined is an invalid value for resolvedImage, set fallback to\n * an empty string instead of undefined to ensure output\n * passes validation.\n */\n if (defaultValue === undefined && propertySpec.type === 'resolvedImage') {\n return '';\n }\n return defaultValue;\n}\n\nfunction convertPropertyFunction(parameters, propertySpec, stops) {\n const type = getFunctionType(parameters, propertySpec);\n const get = ['get', parameters.property];\n if (type === 'categorical' && typeof stops[0][0] === 'boolean') {\n assert(parameters.stops.length > 0 && parameters.stops.length <= 2);\n const expression = ['case'];\n for (const stop of stops) {\n expression.push(['==', get, stop[0]], stop[1]);\n }\n\n expression.push(getFallback(parameters, propertySpec));\n return expression;\n } else if (type === 'categorical') {\n const expression = ['match', get];\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], false);\n }\n expression.push(getFallback(parameters, propertySpec));\n return expression;\n } else if (type === 'interval') {\n const expression = ['step', ['number', get]];\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], true);\n }\n fixupDegenerateStepCurve(expression);\n return parameters.default === undefined ? expression : [\n 'case',\n ['==', ['typeof', get], 'number'],\n expression,\n convertLiteral(parameters.default)\n ];\n } else if (type === 'exponential') {\n const base = parameters.base !== undefined ? parameters.base : 1;\n const expression = [\n getInterpolateOperator(parameters),\n base === 1 ? [\"linear\"] : [\"exponential\", base],\n [\"number\", get]\n ];\n\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], false);\n }\n return parameters.default === undefined ? expression : [\n 'case',\n ['==', ['typeof', get], 'number'],\n expression,\n convertLiteral(parameters.default)\n ];\n } else {\n throw new Error(`Unknown property function type ${type}`);\n }\n}\n\nfunction convertZoomFunction(parameters, propertySpec, stops, input = ['zoom']) {\n const type = getFunctionType(parameters, propertySpec);\n let expression;\n let isStep = false;\n if (type === 'interval') {\n expression = ['step', input];\n isStep = true;\n } else if (type === 'exponential') {\n const base = parameters.base !== undefined ? parameters.base : 1;\n expression = [getInterpolateOperator(parameters), base === 1 ? [\"linear\"] : [\"exponential\", base], input];\n\n } else {\n throw new Error(`Unknown zoom function type \"${type}\"`);\n }\n\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], isStep);\n }\n\n fixupDegenerateStepCurve(expression);\n\n return expression;\n}\n\nfunction fixupDegenerateStepCurve(expression) {\n // degenerate step curve (i.e. a constant function): add a noop stop\n if (expression[0] === 'step' && expression.length === 3) {\n expression.push(0);\n expression.push(expression[3]);\n }\n}\n\nfunction appendStopPair(curve, input, output, isStep) {\n // Skip duplicate stop values. They were not validated for functions, but they are for expressions.\n // https://github.com/mapbox/mapbox-gl-js/issues/4107\n if (curve.length > 3 && input === curve[curve.length - 2]) {\n return;\n }\n // step curves don't get the first input value, as it is redundant.\n if (!(isStep && curve.length === 2)) {\n curve.push(input);\n }\n curve.push(output);\n}\n\nfunction getFunctionType(parameters, propertySpec) {\n if (parameters.type) {\n return parameters.type;\n } else {\n assert(propertySpec.expression);\n return (propertySpec.expression: any).interpolated ? 'exponential' : 'interval';\n }\n}\n\n// \"String with {name} token\" => [\"concat\", \"String with \", [\"get\", \"name\"], \" token\"]\nexport function convertTokenString(s: string): string | ExpressionSpecification {\n const result = ['concat'];\n const re = /{([^{}]+)}/g;\n let pos = 0;\n for (let match = re.exec(s); match !== null; match = re.exec(s)) {\n const literal = s.slice(pos, re.lastIndex - match[0].length);\n pos = re.lastIndex;\n if (literal.length > 0) result.push(literal);\n result.push(['get', match[1]]);\n }\n\n if (result.length === 1) {\n return s;\n }\n\n if (pos < s.length) {\n result.push(s.slice(pos));\n } else if (result.length === 2) {\n return ['to-string', result[1]];\n }\n\n return result;\n}\n\n","// @flow\n\nclass ParsingError extends Error {\n key: string;\n message: string;\n constructor(key: string, message: string) {\n super(message);\n this.message = message;\n this.key = key;\n }\n}\n\nexport default ParsingError;\n","// @flow\n\nimport type {Expression} from './expression.js';\n\n/**\n * Tracks `let` bindings during expression parsing.\n * @private\n */\nclass Scope {\n parent: ?Scope;\n bindings: {[_: string]: Expression};\n constructor(parent?: Scope, bindings: Array<[string, Expression]> = []) {\n this.parent = parent;\n this.bindings = {};\n for (const [name, expression] of bindings) {\n this.bindings[name] = expression;\n }\n }\n\n concat(bindings: Array<[string, Expression]>): Scope {\n return new Scope(this, bindings);\n }\n\n get(name: string): Expression {\n if (this.bindings[name]) { return this.bindings[name]; }\n if (this.parent) { return this.parent.get(name); }\n throw new Error(`${name} not found in scope.`);\n }\n\n has(name: string): boolean {\n if (this.bindings[name]) return true;\n return this.parent ? this.parent.has(name) : false;\n }\n}\n\nexport default Scope;\n","// @flow\n\nexport type NullTypeT = { kind: 'null' };\nexport type NumberTypeT = { kind: 'number' };\nexport type StringTypeT = { kind: 'string' };\nexport type BooleanTypeT = { kind: 'boolean' };\nexport type ColorTypeT = { kind: 'color' };\nexport type ObjectTypeT = { kind: 'object' };\nexport type ValueTypeT = { kind: 'value' };\nexport type ErrorTypeT = { kind: 'error' };\nexport type CollatorTypeT = { kind: 'collator' };\nexport type FormattedTypeT = { kind: 'formatted' };\nexport type ResolvedImageTypeT = { kind: 'resolvedImage' };\n\nexport type EvaluationKind = 'constant' | 'source' | 'camera' | 'composite';\n\nexport type Type =\n NullTypeT |\n NumberTypeT |\n StringTypeT |\n BooleanTypeT |\n ColorTypeT |\n ObjectTypeT |\n ValueTypeT |\n ArrayType | // eslint-disable-line no-use-before-define\n ErrorTypeT |\n CollatorTypeT |\n FormattedTypeT |\n ResolvedImageTypeT\n\nexport type ArrayType = {\n kind: 'array',\n itemType: Type,\n N: ?number\n}\n\nexport type NativeType = 'number' | 'string' | 'boolean' | 'null' | 'array' | 'object'\n\nexport const NullType = {kind: 'null'};\nexport const NumberType = {kind: 'number'};\nexport const StringType = {kind: 'string'};\nexport const BooleanType = {kind: 'boolean'};\nexport const ColorType = {kind: 'color'};\nexport const ObjectType = {kind: 'object'};\nexport const ValueType = {kind: 'value'};\nexport const ErrorType = {kind: 'error'};\nexport const CollatorType = {kind: 'collator'};\nexport const FormattedType = {kind: 'formatted'};\nexport const ResolvedImageType = {kind: 'resolvedImage'};\n\nexport function array(itemType: Type, N: ?number): ArrayType {\n return {\n kind: 'array',\n itemType,\n N\n };\n}\n\nexport function toString(type: Type): string {\n if (type.kind === 'array') {\n const itemType = toString(type.itemType);\n return typeof type.N === 'number' ?\n `array<${itemType}, ${type.N}>` :\n type.itemType.kind === 'value' ? 'array' : `array<${itemType}>`;\n } else {\n return type.kind;\n }\n}\n\nconst valueMemberTypes = [\n NullType,\n NumberType,\n StringType,\n BooleanType,\n ColorType,\n FormattedType,\n ObjectType,\n array(ValueType),\n ResolvedImageType\n];\n\n/**\n * Returns null if `t` is a subtype of `expected`; otherwise returns an\n * error message.\n * @private\n */\nexport function checkSubtype(expected: Type, t: Type): ?string {\n if (t.kind === 'error') {\n // Error is a subtype of every type\n return null;\n } else if (expected.kind === 'array') {\n if (t.kind === 'array' &&\n ((t.N === 0 && t.itemType.kind === 'value') || !checkSubtype(expected.itemType, t.itemType)) &&\n (typeof expected.N !== 'number' || expected.N === t.N)) {\n return null;\n }\n } else if (expected.kind === t.kind) {\n return null;\n } else if (expected.kind === 'value') {\n for (const memberType of valueMemberTypes) {\n if (!checkSubtype(memberType, t)) {\n return null;\n }\n }\n }\n\n return `Expected ${toString(expected)} but found ${toString(t)} instead.`;\n}\n\nexport function isValidType(provided: Type, allowedTypes: Array): boolean {\n return allowedTypes.some(t => t.kind === provided.kind);\n}\n\nexport function isValidNativeType(provided: any, allowedTypes: Array): boolean {\n return allowedTypes.some(t => {\n if (t === 'null') {\n return provided === null;\n } else if (t === 'array') {\n return Array.isArray(provided);\n } else if (t === 'object') {\n return provided && !Array.isArray(provided) && typeof provided === 'object';\n } else {\n return t === typeof provided;\n }\n });\n}\n","// @flow\n\n// Flow type declarations for Intl cribbed from\n// https://github.com/facebook/flow/issues/1270\n\ndeclare var Intl: {\n Collator: Class\n};\n\ndeclare class Intl$Collator {\n constructor (\n locales?: string | string[],\n options?: CollatorOptions\n ): Intl$Collator;\n\n static (\n locales?: string | string[],\n options?: CollatorOptions\n ): Intl$Collator;\n\n compare (a: string, b: string): number;\n\n resolvedOptions(): any;\n}\n\ntype CollatorOptions = {\n localeMatcher?: 'lookup' | 'best fit',\n usage?: 'sort' | 'search',\n sensitivity?: 'base' | 'accent' | 'case' | 'variant',\n ignorePunctuation?: boolean,\n numeric?: boolean,\n caseFirst?: 'upper' | 'lower' | 'false'\n}\n\nexport default class Collator {\n locale: string | null;\n sensitivity: 'base' | 'accent' | 'case' | 'variant';\n collator: Intl$Collator;\n\n constructor(caseSensitive: boolean, diacriticSensitive: boolean, locale: string | null) {\n if (caseSensitive)\n this.sensitivity = diacriticSensitive ? 'variant' : 'case';\n else\n this.sensitivity = diacriticSensitive ? 'accent' : 'base';\n\n this.locale = locale;\n this.collator = new Intl.Collator(this.locale ? this.locale : [],\n {sensitivity: this.sensitivity, usage: 'search'});\n }\n\n compare(lhs: string, rhs: string): number {\n return this.collator.compare(lhs, rhs);\n }\n\n resolvedLocale(): string {\n // We create a Collator without \"usage: search\" because we don't want\n // the search options encoded in our result (e.g. \"en-u-co-search\")\n return new Intl.Collator(this.locale ? this.locale : [])\n .resolvedOptions().locale;\n }\n}\n","// @flow\nimport type Color from '../../util/color.js';\nimport type ResolvedImage from '../types/resolved_image.js';\n\nexport class FormattedSection {\n text: string;\n image: ResolvedImage | null;\n scale: number | null;\n fontStack: string | null;\n textColor: Color | null;\n\n constructor(text: string, image: ResolvedImage | null, scale: number | null, fontStack: string | null, textColor: Color | null) {\n // combine characters so that diacritic marks are not separate code points\n this.text = text.normalize ? text.normalize() : text;\n this.image = image;\n this.scale = scale;\n this.fontStack = fontStack;\n this.textColor = textColor;\n }\n}\n\nexport default class Formatted {\n sections: Array;\n\n constructor(sections: Array) {\n this.sections = sections;\n }\n\n static fromString(unformatted: string): Formatted {\n return new Formatted([new FormattedSection(unformatted, null, null, null, null)]);\n }\n\n isEmpty(): boolean {\n if (this.sections.length === 0) return true;\n return !this.sections.some(section => section.text.length !== 0 ||\n (section.image && section.image.name.length !== 0));\n }\n\n static factory(text: Formatted | string): Formatted {\n if (text instanceof Formatted) {\n return text;\n } else {\n return Formatted.fromString(text);\n }\n }\n\n toString(): string {\n if (this.sections.length === 0) return '';\n return this.sections.map(section => section.text).join('');\n }\n\n serialize(): Array {\n const serialized: Array = [\"format\"];\n for (const section of this.sections) {\n if (section.image) {\n serialized.push([\"image\", section.image.name]);\n continue;\n }\n serialized.push(section.text);\n const options: { [key: string]: mixed } = {};\n if (section.fontStack) {\n options[\"text-font\"] = [\"literal\", section.fontStack.split(',')];\n }\n if (section.scale) {\n options[\"font-scale\"] = section.scale;\n }\n if (section.textColor) {\n options[\"text-color\"] = ([\"rgba\"]: Array).concat(section.textColor.toArray());\n }\n serialized.push(options);\n }\n return serialized;\n }\n}\n","// @flow\n\nexport type ResolvedImageOptions = {\n name: string,\n available: boolean\n};\n\nexport default class ResolvedImage {\n name: string;\n available: boolean;\n\n constructor(options: ResolvedImageOptions) {\n this.name = options.name;\n this.available = options.available;\n }\n\n toString(): string {\n return this.name;\n }\n\n static fromString(name: string): ResolvedImage | null {\n if (!name) return null; // treat empty values as no image\n return new ResolvedImage({name, available: false});\n }\n\n serialize(): Array {\n return [\"image\", this.name];\n }\n}\n","// @flow\n\nimport assert from 'assert';\n\nimport Color from '../util/color.js';\nimport Collator from './types/collator.js';\nimport Formatted from './types/formatted.js';\nimport ResolvedImage from './types/resolved_image.js';\nimport {NullType, NumberType, StringType, BooleanType, ColorType, ObjectType, ValueType, CollatorType, FormattedType, ResolvedImageType, array} from './types.js';\n\nimport type {Type} from './types.js';\n\nexport function validateRGBA(r: mixed, g: mixed, b: mixed, a?: mixed): string | null {\n if (!(\n typeof r === 'number' && r >= 0 && r <= 255 &&\n typeof g === 'number' && g >= 0 && g <= 255 &&\n typeof b === 'number' && b >= 0 && b <= 255\n )) {\n const value = typeof a === 'number' ? [r, g, b, a] : [r, g, b];\n return `Invalid rgba value [${value.join(', ')}]: 'r', 'g', and 'b' must be between 0 and 255.`;\n }\n\n if (!(\n typeof a === 'undefined' || (typeof a === 'number' && a >= 0 && a <= 1)\n )) {\n return `Invalid rgba value [${[r, g, b, a].join(', ')}]: 'a' must be between 0 and 1.`;\n }\n\n return null;\n}\n\nexport type Value = null | string | boolean | number | Color | Collator | Formatted | ResolvedImage | $ReadOnlyArray | { +[string]: Value }\n\nexport function isValue(mixed: mixed): boolean {\n if (mixed === null) {\n return true;\n } else if (typeof mixed === 'string') {\n return true;\n } else if (typeof mixed === 'boolean') {\n return true;\n } else if (typeof mixed === 'number') {\n return true;\n } else if (mixed instanceof Color) {\n return true;\n } else if (mixed instanceof Collator) {\n return true;\n } else if (mixed instanceof Formatted) {\n return true;\n } else if (mixed instanceof ResolvedImage) {\n return true;\n } else if (Array.isArray(mixed)) {\n for (const item of mixed) {\n if (!isValue(item)) {\n return false;\n }\n }\n return true;\n } else if (typeof mixed === 'object') {\n for (const key in mixed) {\n if (!isValue(mixed[key])) {\n return false;\n }\n }\n return true;\n } else {\n return false;\n }\n}\n\nexport function typeOf(value: Value): Type {\n if (value === null) {\n return NullType;\n } else if (typeof value === 'string') {\n return StringType;\n } else if (typeof value === 'boolean') {\n return BooleanType;\n } else if (typeof value === 'number') {\n return NumberType;\n } else if (value instanceof Color) {\n return ColorType;\n } else if (value instanceof Collator) {\n return CollatorType;\n } else if (value instanceof Formatted) {\n return FormattedType;\n } else if (value instanceof ResolvedImage) {\n return ResolvedImageType;\n } else if (Array.isArray(value)) {\n const length = value.length;\n let itemType: Type | typeof undefined;\n\n for (const item of value) {\n const t = typeOf(item);\n if (!itemType) {\n itemType = t;\n } else if (itemType === t) {\n continue;\n } else {\n itemType = ValueType;\n break;\n }\n }\n\n return array(itemType || ValueType, length);\n } else {\n assert(typeof value === 'object');\n return ObjectType;\n }\n}\n\nexport function toString(value: Value): string {\n const type = typeof value;\n if (value === null) {\n return '';\n } else if (type === 'string' || type === 'number' || type === 'boolean') {\n return String(value);\n } else if (value instanceof Color || value instanceof Formatted || value instanceof ResolvedImage) {\n return value.toString();\n } else {\n return JSON.stringify(value);\n }\n}\n\nexport {Color, Collator};\n","// @flow\n\nimport assert from 'assert';\nimport {isValue, typeOf, Color} from '../values.js';\nimport Formatted from '../types/formatted.js';\n\nimport type {Type} from '../types.js';\nimport type {Value} from '../values.js';\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\n\nclass Literal implements Expression {\n type: Type;\n value: Value;\n\n constructor(type: Type, value: Value) {\n this.type = type;\n this.value = value;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): void | Literal {\n if (args.length !== 2)\n return context.error(`'literal' expression requires exactly one argument, but found ${args.length - 1} instead.`);\n\n if (!isValue(args[1]))\n return context.error(`invalid value`);\n\n const value = (args[1]: any);\n let type = typeOf(value);\n\n // special case: infer the item type if possible for zero-length arrays\n const expected = context.expectedType;\n if (\n type.kind === 'array' &&\n type.N === 0 &&\n expected &&\n expected.kind === 'array' &&\n (typeof expected.N !== 'number' || expected.N === 0)\n ) {\n type = expected;\n }\n\n return new Literal(type, value);\n }\n\n evaluate(): Value {\n return this.value;\n }\n\n eachChild() {}\n\n outputDefined(): boolean {\n return true;\n }\n\n serialize(): SerializedExpression {\n if (this.type.kind === 'array' || this.type.kind === 'object') {\n return [\"literal\", this.value];\n } else if (this.value instanceof Color) {\n // Constant-folding can generate Literal expressions that you\n // couldn't actually generate with a \"literal\" expression,\n // so we have to implement an equivalent serialization here\n return [\"rgba\"].concat(this.value.toArray());\n } else if (this.value instanceof Formatted) {\n // Same as Color\n return this.value.serialize();\n } else {\n assert(this.value === null ||\n typeof this.value === 'string' ||\n typeof this.value === 'number' ||\n typeof this.value === 'boolean');\n return (this.value: any);\n }\n }\n}\n\nexport default Literal;\n","// @flow\n\nclass RuntimeError {\n name: string;\n message: string;\n\n constructor(message: string) {\n this.name = 'ExpressionEvaluationError';\n this.message = message;\n }\n\n toJSON(): string {\n return this.message;\n }\n}\n\nexport default RuntimeError;\n","// @flow\n\nimport assert from 'assert';\n\nimport {\n ObjectType,\n ValueType,\n StringType,\n NumberType,\n BooleanType,\n checkSubtype,\n toString,\n array\n} from '../types.js';\nimport RuntimeError from '../runtime_error.js';\nimport {typeOf} from '../values.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nconst types = {\n string: StringType,\n number: NumberType,\n boolean: BooleanType,\n object: ObjectType\n};\n\nclass Assertion implements Expression {\n type: Type;\n args: Array;\n\n constructor(type: Type, args: Array) {\n this.type = type;\n this.args = args;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n if (args.length < 2)\n return context.error(`Expected at least one argument.`);\n\n let i = 1;\n let type;\n\n const name: string = (args[0]: any);\n if (name === 'array') {\n let itemType;\n if (args.length > 2) {\n const type = args[1];\n if (typeof type !== 'string' || !(type in types) || type === 'object')\n return context.error('The item type argument of \"array\" must be one of string, number, boolean', 1);\n itemType = types[type];\n i++;\n } else {\n itemType = ValueType;\n }\n\n let N;\n if (args.length > 3) {\n if (args[2] !== null &&\n (typeof args[2] !== 'number' ||\n args[2] < 0 ||\n args[2] !== Math.floor(args[2]))\n ) {\n return context.error('The length argument to \"array\" must be a positive integer literal', 2);\n }\n N = args[2];\n i++;\n }\n\n type = array(itemType, N);\n } else {\n assert(types[name], name);\n type = types[name];\n }\n\n const parsed = [];\n for (; i < args.length; i++) {\n const input = context.parse(args[i], i, ValueType);\n if (!input) return null;\n parsed.push(input);\n }\n\n return new Assertion(type, parsed);\n }\n\n evaluate(ctx: EvaluationContext): any | null {\n for (let i = 0; i < this.args.length; i++) {\n const value = this.args[i].evaluate(ctx);\n const error = checkSubtype(this.type, typeOf(value));\n if (!error) {\n return value;\n } else if (i === this.args.length - 1) {\n throw new RuntimeError(`Expected value to be of type ${toString(this.type)}, but found ${toString(typeOf(value))} instead.`);\n }\n }\n\n assert(false);\n return null;\n }\n\n eachChild(fn: (_: Expression) => void) {\n this.args.forEach(fn);\n }\n\n outputDefined(): boolean {\n return this.args.every(arg => arg.outputDefined());\n }\n\n serialize(): SerializedExpression {\n const type = this.type;\n const serialized = [type.kind];\n if (type.kind === 'array') {\n const itemType = type.itemType;\n if (itemType.kind === 'string' ||\n itemType.kind === 'number' ||\n itemType.kind === 'boolean') {\n serialized.push(itemType.kind);\n const N = type.N;\n if (typeof N === 'number' || this.args.length > 1) {\n serialized.push(N);\n }\n }\n }\n return serialized.concat(this.args.map(arg => arg.serialize()));\n }\n}\n\nexport default Assertion;\n","// @flow\n\nimport {NumberType, ValueType, FormattedType, array, StringType, ColorType, ResolvedImageType} from '../types.js';\nimport Formatted, {FormattedSection} from '../types/formatted.js';\nimport {toString, typeOf} from '../values.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type {Type} from '../types.js';\n\ntype FormattedSectionExpression = {\n // Content of a section may be Image expression or other\n // type of expression that is coercable to 'string'.\n content: Expression,\n scale: Expression | null;\n font: Expression | null;\n textColor: Expression | null;\n}\n\nexport default class FormatExpression implements Expression {\n type: Type;\n sections: Array;\n\n constructor(sections: Array) {\n this.type = FormattedType;\n this.sections = sections;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n if (args.length < 2) {\n return context.error(`Expected at least one argument.`);\n }\n\n const firstArg = args[1];\n if (!Array.isArray(firstArg) && typeof firstArg === 'object') {\n return context.error(`First argument must be an image or text section.`);\n }\n\n const sections: Array = [];\n let nextTokenMayBeObject = false;\n for (let i = 1; i <= args.length - 1; ++i) {\n const arg = (args[i]: any);\n\n if (nextTokenMayBeObject && typeof arg === \"object\" && !Array.isArray(arg)) {\n nextTokenMayBeObject = false;\n\n let scale = null;\n if (arg['font-scale']) {\n scale = context.parse(arg['font-scale'], 1, NumberType);\n if (!scale) return null;\n }\n\n let font = null;\n if (arg['text-font']) {\n font = context.parse(arg['text-font'], 1, array(StringType));\n if (!font) return null;\n }\n\n let textColor = null;\n if (arg['text-color']) {\n textColor = context.parse(arg['text-color'], 1, ColorType);\n if (!textColor) return null;\n }\n\n const lastExpression = sections[sections.length - 1];\n lastExpression.scale = scale;\n lastExpression.font = font;\n lastExpression.textColor = textColor;\n } else {\n const content = context.parse(args[i], 1, ValueType);\n if (!content) return null;\n\n const kind = content.type.kind;\n if (kind !== 'string' && kind !== 'value' && kind !== 'null' && kind !== 'resolvedImage')\n return context.error(`Formatted text type must be 'string', 'value', 'image' or 'null'.`);\n\n nextTokenMayBeObject = true;\n sections.push({content, scale: null, font: null, textColor: null});\n }\n }\n\n return new FormatExpression(sections);\n }\n\n evaluate(ctx: EvaluationContext): Formatted {\n const evaluateSection = section => {\n const evaluatedContent = section.content.evaluate(ctx);\n if (typeOf(evaluatedContent) === ResolvedImageType) {\n return new FormattedSection('', evaluatedContent, null, null, null);\n }\n\n return new FormattedSection(\n toString(evaluatedContent),\n null,\n section.scale ? section.scale.evaluate(ctx) : null,\n section.font ? section.font.evaluate(ctx).join(',') : null,\n section.textColor ? section.textColor.evaluate(ctx) : null\n );\n };\n\n return new Formatted(this.sections.map(evaluateSection));\n }\n\n eachChild(fn: (_: Expression) => void) {\n for (const section of this.sections) {\n fn(section.content);\n if (section.scale) {\n fn(section.scale);\n }\n if (section.font) {\n fn(section.font);\n }\n if (section.textColor) {\n fn(section.textColor);\n }\n }\n }\n\n outputDefined(): boolean {\n // Technically the combinatoric set of all children\n // Usually, this.text will be undefined anyway\n return false;\n }\n\n serialize(): SerializedExpression {\n const serialized = [\"format\"];\n for (const section of this.sections) {\n serialized.push(section.content.serialize());\n const options = {};\n if (section.scale) {\n options['font-scale'] = section.scale.serialize();\n }\n if (section.font) {\n options['text-font'] = section.font.serialize();\n }\n if (section.textColor) {\n options['text-color'] = section.textColor.serialize();\n }\n serialized.push(options);\n }\n return serialized;\n }\n}\n","// @flow\n\nimport {ResolvedImageType, StringType} from '../types.js';\nimport ResolvedImage from '../types/resolved_image.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type {Type} from '../types.js';\n\nexport default class ImageExpression implements Expression {\n type: Type;\n input: Expression;\n\n constructor(input: Expression) {\n this.type = ResolvedImageType;\n this.input = input;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n if (args.length !== 2) {\n return context.error(`Expected two arguments.`);\n }\n\n const name = context.parse(args[1], 1, StringType);\n if (!name) return context.error(`No image name provided.`);\n\n return new ImageExpression(name);\n }\n\n evaluate(ctx: EvaluationContext): null | ResolvedImage {\n const evaluatedImageName = this.input.evaluate(ctx);\n\n const value = ResolvedImage.fromString(evaluatedImageName);\n if (value && ctx.availableImages) value.available = ctx.availableImages.indexOf(evaluatedImageName) > -1;\n\n return value;\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.input);\n }\n\n outputDefined(): boolean {\n // The output of image is determined by the list of available images in the evaluation context\n return false;\n }\n\n serialize(): SerializedExpression {\n return [\"image\", this.input.serialize()];\n }\n}\n","// @flow\n\nimport assert from 'assert';\n\nimport {BooleanType, ColorType, NumberType, StringType, ValueType} from '../types.js';\nimport {Color, toString as valueToString, validateRGBA} from '../values.js';\nimport RuntimeError from '../runtime_error.js';\nimport Formatted from '../types/formatted.js';\nimport FormatExpression from '../definitions/format.js';\nimport ImageExpression from '../definitions/image.js';\nimport ResolvedImage from '../types/resolved_image.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nconst types = {\n 'to-boolean': BooleanType,\n 'to-color': ColorType,\n 'to-number': NumberType,\n 'to-string': StringType\n};\n\n/**\n * Special form for error-coalescing coercion expressions \"to-number\",\n * \"to-color\". Since these coercions can fail at runtime, they accept multiple\n * arguments, only evaluating one at a time until one succeeds.\n *\n * @private\n */\nclass Coercion implements Expression {\n type: Type;\n args: Array;\n\n constructor(type: Type, args: Array) {\n this.type = type;\n this.args = args;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n if (args.length < 2)\n return context.error(`Expected at least one argument.`);\n\n const name: string = (args[0]: any);\n assert(types[name], name);\n\n if ((name === 'to-boolean' || name === 'to-string') && args.length !== 2)\n return context.error(`Expected one argument.`);\n\n const type = types[name];\n\n const parsed = [];\n for (let i = 1; i < args.length; i++) {\n const input = context.parse(args[i], i, ValueType);\n if (!input) return null;\n parsed.push(input);\n }\n\n return new Coercion(type, parsed);\n }\n\n evaluate(ctx: EvaluationContext): null | boolean | number | string | Color | Formatted | ResolvedImage {\n if (this.type.kind === 'boolean') {\n return Boolean(this.args[0].evaluate(ctx));\n } else if (this.type.kind === 'color') {\n let input;\n let error;\n for (const arg of this.args) {\n input = arg.evaluate(ctx);\n error = null;\n if (input instanceof Color) {\n return input;\n } else if (typeof input === 'string') {\n const c = ctx.parseColor(input);\n if (c) return c;\n } else if (Array.isArray(input)) {\n if (input.length < 3 || input.length > 4) {\n error = `Invalid rbga value ${JSON.stringify(input)}: expected an array containing either three or four numeric values.`;\n } else {\n error = validateRGBA(input[0], input[1], input[2], input[3]);\n }\n if (!error) {\n return new Color((input[0]: any) / 255, (input[1]: any) / 255, (input[2]: any) / 255, (input[3]: any));\n }\n }\n }\n throw new RuntimeError(error || `Could not parse color from value '${typeof input === 'string' ? input : String(JSON.stringify(input))}'`);\n } else if (this.type.kind === 'number') {\n let value = null;\n for (const arg of this.args) {\n value = arg.evaluate(ctx);\n if (value === null) return 0;\n const num = Number(value);\n if (isNaN(num)) continue;\n return num;\n }\n throw new RuntimeError(`Could not convert ${JSON.stringify(value)} to number.`);\n } else if (this.type.kind === 'formatted') {\n // There is no explicit 'to-formatted' but this coercion can be implicitly\n // created by properties that expect the 'formatted' type.\n return Formatted.fromString(valueToString(this.args[0].evaluate(ctx)));\n } else if (this.type.kind === 'resolvedImage') {\n return ResolvedImage.fromString(valueToString(this.args[0].evaluate(ctx)));\n } else {\n return valueToString(this.args[0].evaluate(ctx));\n }\n }\n\n eachChild(fn: (_: Expression) => void) {\n this.args.forEach(fn);\n }\n\n outputDefined(): boolean {\n return this.args.every(arg => arg.outputDefined());\n }\n\n serialize(): SerializedExpression {\n if (this.type.kind === 'formatted') {\n return new FormatExpression([{content: this.args[0], scale: null, font: null, textColor: null}]).serialize();\n }\n\n if (this.type.kind === 'resolvedImage') {\n return new ImageExpression(this.args[0]).serialize();\n }\n\n const serialized = [`to-${this.type.kind}`];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n}\n\nexport default Coercion;\n","// @flow\n\nimport {Color} from './values.js';\n\nimport type Point from '@mapbox/point-geometry';\nimport type {FormattedSection} from './types/formatted.js';\nimport type {GlobalProperties, Feature, FeatureState} from './index.js';\nimport type {CanonicalTileID} from '../../source/tile_id.js';\nimport type {FeatureDistanceData} from '../feature_filter/index.js';\n\nconst geometryTypes = ['Unknown', 'Point', 'LineString', 'Polygon'];\n\nclass EvaluationContext {\n globals: GlobalProperties;\n feature: ?Feature;\n featureState: ?FeatureState;\n formattedSection: ?FormattedSection;\n availableImages: ?Array;\n canonical: null | CanonicalTileID;\n featureTileCoord: ?Point;\n featureDistanceData: ?FeatureDistanceData;\n\n _parseColorCache: {[_: string]: ?Color};\n\n constructor() {\n this.globals = (null: any);\n this.feature = null;\n this.featureState = null;\n this.formattedSection = null;\n this._parseColorCache = {};\n this.availableImages = null;\n this.canonical = null;\n this.featureTileCoord = null;\n this.featureDistanceData = null;\n }\n\n id(): number | null {\n return this.feature && this.feature.id !== undefined ? this.feature.id : null;\n }\n\n geometryType(): null | string {\n return this.feature ? typeof this.feature.type === 'number' ? geometryTypes[this.feature.type] : this.feature.type : null;\n }\n\n geometry(): ?Array> {\n return this.feature && 'geometry' in this.feature ? this.feature.geometry : null;\n }\n\n canonicalID(): null | CanonicalTileID {\n return this.canonical;\n }\n\n properties(): {[string]: any} {\n return (this.feature && this.feature.properties) || {};\n }\n\n distanceFromCenter(): number {\n if (this.featureTileCoord && this.featureDistanceData) {\n\n const c = this.featureDistanceData.center;\n const scale = this.featureDistanceData.scale;\n const {x, y} = this.featureTileCoord;\n\n // Calculate the distance vector `d` (left handed)\n const dX = x * scale - c[0];\n const dY = y * scale - c[1];\n\n // The bearing vector `b` (left handed)\n const bX = this.featureDistanceData.bearing[0];\n const bY = this.featureDistanceData.bearing[1];\n\n // Distance is calculated as `dot(d, v)`\n const dist = (bX * dX + bY * dY);\n return dist;\n }\n\n return 0;\n }\n\n parseColor(input: string): ?Color {\n let cached = this._parseColorCache[input];\n if (!cached) {\n cached = this._parseColorCache[input] = Color.parse(input);\n }\n return cached;\n }\n}\n\nexport default EvaluationContext;\n","// @flow\n\nimport {toString} from './types.js';\n\nimport ParsingContext from './parsing_context.js';\nimport EvaluationContext from './evaluation_context.js';\nimport assert from 'assert';\n\nimport type {Expression, ExpressionRegistry} from './expression.js';\nimport type {Type} from './types.js';\nimport type {Value} from './values.js';\n\nexport type Varargs = {| type: Type |};\ntype Signature = Array | Varargs;\ntype Evaluate = (EvaluationContext, Array) => Value;\ntype Definition = [Type, Signature, Evaluate] |\n {|type: Type, overloads: Array<[Signature, Evaluate]>|};\n\nclass CompoundExpression implements Expression {\n name: string;\n type: Type;\n _evaluate: Evaluate;\n args: Array;\n\n static definitions: {[_: string]: Definition };\n\n constructor(name: string, type: Type, evaluate: Evaluate, args: Array) {\n this.name = name;\n this.type = type;\n this._evaluate = evaluate;\n this.args = args;\n }\n\n evaluate(ctx: EvaluationContext): Value {\n return this._evaluate(ctx, this.args);\n }\n\n eachChild(fn: (_: Expression) => void) {\n this.args.forEach(fn);\n }\n\n outputDefined(): boolean {\n return false;\n }\n\n serialize(): Array {\n return [this.name].concat(this.args.map(arg => arg.serialize()));\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n const op: string = (args[0]: any);\n const definition = CompoundExpression.definitions[op];\n if (!definition) {\n return context.error(`Unknown expression \"${op}\". If you wanted a literal array, use [\"literal\", [...]].`, 0);\n }\n\n // Now check argument types against each signature\n const type = Array.isArray(definition) ?\n definition[0] : definition.type;\n\n const availableOverloads = Array.isArray(definition) ?\n [[definition[1], definition[2]]] :\n definition.overloads;\n\n const overloads = availableOverloads.filter(([signature]) => (\n !Array.isArray(signature) || // varags\n signature.length === args.length - 1 // correct param count\n ));\n\n let signatureContext: ParsingContext = (null: any);\n\n for (const [params, evaluate] of overloads) {\n // Use a fresh context for each attempted signature so that, if\n // we eventually succeed, we haven't polluted `context.errors`.\n signatureContext = new ParsingContext(context.registry, context.path, null, context.scope);\n\n // First parse all the args, potentially coercing to the\n // types expected by this overload.\n const parsedArgs: Array = [];\n let argParseFailed = false;\n for (let i = 1; i < args.length; i++) {\n const arg = args[i];\n const expectedType = Array.isArray(params) ?\n params[i - 1] :\n params.type;\n\n const parsed = signatureContext.parse(arg, 1 + parsedArgs.length, expectedType);\n if (!parsed) {\n argParseFailed = true;\n break;\n }\n parsedArgs.push(parsed);\n }\n if (argParseFailed) {\n // Couldn't coerce args of this overload to expected type, move\n // on to next one.\n continue;\n }\n\n if (Array.isArray(params)) {\n if (params.length !== parsedArgs.length) {\n signatureContext.error(`Expected ${params.length} arguments, but found ${parsedArgs.length} instead.`);\n continue;\n }\n }\n\n for (let i = 0; i < parsedArgs.length; i++) {\n const expected = Array.isArray(params) ? params[i] : params.type;\n const arg = parsedArgs[i];\n signatureContext.concat(i + 1).checkSubtype(expected, arg.type);\n }\n\n if (signatureContext.errors.length === 0) {\n return new CompoundExpression(op, type, evaluate, parsedArgs);\n }\n }\n\n assert(!signatureContext || signatureContext.errors.length > 0);\n\n if (overloads.length === 1) {\n context.errors.push(...signatureContext.errors);\n } else {\n const expected = overloads.length ? overloads : availableOverloads;\n const signatures = expected\n .map(([params]) => stringifySignature(params))\n .join(' | ');\n\n const actualTypes = [];\n // For error message, re-parse arguments without trying to\n // apply any coercions\n for (let i = 1; i < args.length; i++) {\n const parsed = context.parse(args[i], 1 + actualTypes.length);\n if (!parsed) return null;\n actualTypes.push(toString(parsed.type));\n }\n context.error(`Expected arguments of type ${signatures}, but found (${actualTypes.join(', ')}) instead.`);\n }\n\n return null;\n }\n\n static register(\n registry: ExpressionRegistry,\n definitions: {[_: string]: Definition }\n ) {\n assert(!CompoundExpression.definitions);\n CompoundExpression.definitions = definitions;\n for (const name in definitions) {\n registry[name] = CompoundExpression;\n }\n }\n}\n\nfunction stringifySignature(signature: Signature): string {\n if (Array.isArray(signature)) {\n return `(${signature.map(toString).join(', ')})`;\n } else {\n return `(${toString(signature.type)}...)`;\n }\n}\n\nexport default CompoundExpression;\n","// @flow\n\nimport {StringType, BooleanType, CollatorType} from '../types.js';\nimport Collator from '../types/collator.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type {Type} from '../types.js';\n\nexport default class CollatorExpression implements Expression {\n type: Type;\n caseSensitive: Expression;\n diacriticSensitive: Expression;\n locale: Expression | null;\n\n constructor(caseSensitive: Expression, diacriticSensitive: Expression, locale: Expression | null) {\n this.type = CollatorType;\n this.locale = locale;\n this.caseSensitive = caseSensitive;\n this.diacriticSensitive = diacriticSensitive;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n if (args.length !== 2)\n return context.error(`Expected one argument.`);\n\n const options = (args[1]: any);\n if (typeof options !== \"object\" || Array.isArray(options))\n return context.error(`Collator options argument must be an object.`);\n\n const caseSensitive = context.parse(\n options['case-sensitive'] === undefined ? false : options['case-sensitive'], 1, BooleanType);\n if (!caseSensitive) return null;\n\n const diacriticSensitive = context.parse(\n options['diacritic-sensitive'] === undefined ? false : options['diacritic-sensitive'], 1, BooleanType);\n if (!diacriticSensitive) return null;\n\n let locale = null;\n if (options['locale']) {\n locale = context.parse(options['locale'], 1, StringType);\n if (!locale) return null;\n }\n\n return new CollatorExpression(caseSensitive, diacriticSensitive, locale);\n }\n\n evaluate(ctx: EvaluationContext): Collator {\n return new Collator(this.caseSensitive.evaluate(ctx), this.diacriticSensitive.evaluate(ctx), this.locale ? this.locale.evaluate(ctx) : null);\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.caseSensitive);\n fn(this.diacriticSensitive);\n if (this.locale) {\n fn(this.locale);\n }\n }\n\n outputDefined(): boolean {\n // Technically the set of possible outputs is the combinatoric set of Collators produced\n // by all possible outputs of locale/caseSensitive/diacriticSensitive\n // But for the primary use of Collators in comparison operators, we ignore the Collator's\n // possible outputs anyway, so we can get away with leaving this false for now.\n return false;\n }\n\n serialize(): SerializedExpression {\n const options = {};\n options['case-sensitive'] = this.caseSensitive.serialize();\n options['diacritic-sensitive'] = this.diacriticSensitive.serialize();\n if (this.locale) {\n options['locale'] = this.locale.serialize();\n }\n return [\"collator\", options];\n }\n}\n","// @flow\n\nimport {isValue} from '../values.js';\nimport type {Type} from '../types.js';\nimport {BooleanType} from '../types.js';\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {GeoJSON, GeoJSONPolygon, GeoJSONMultiPolygon} from '@mapbox/geojson-types';\nimport type {CanonicalTileID} from '../../../source/tile_id.js';\n\ntype GeoJSONPolygons =| GeoJSONPolygon | GeoJSONMultiPolygon;\n\n// minX, minY, maxX, maxY\ntype BBox = [number, number, number, number];\nconst EXTENT = 8192;\n\nfunction updateBBox(bbox: BBox, coord: [number, number]) {\n bbox[0] = Math.min(bbox[0], coord[0]);\n bbox[1] = Math.min(bbox[1], coord[1]);\n bbox[2] = Math.max(bbox[2], coord[0]);\n bbox[3] = Math.max(bbox[3], coord[1]);\n}\n\nfunction mercatorXfromLng(lng: number) {\n return (180 + lng) / 360;\n}\n\nfunction mercatorYfromLat(lat: number) {\n return (180 - (180 / Math.PI * Math.log(Math.tan(Math.PI / 4 + lat * Math.PI / 360)))) / 360;\n}\n\nfunction boxWithinBox(bbox1: BBox, bbox2: BBox) {\n if (bbox1[0] <= bbox2[0]) return false;\n if (bbox1[2] >= bbox2[2]) return false;\n if (bbox1[1] <= bbox2[1]) return false;\n if (bbox1[3] >= bbox2[3]) return false;\n return true;\n}\n\nfunction getTileCoordinates(p, canonical: CanonicalTileID) {\n const x = mercatorXfromLng(p[0]);\n const y = mercatorYfromLat(p[1]);\n const tilesAtZoom = Math.pow(2, canonical.z);\n return [Math.round(x * tilesAtZoom * EXTENT), Math.round(y * tilesAtZoom * EXTENT)];\n}\n\nfunction onBoundary(p, p1, p2) {\n const x1 = p[0] - p1[0];\n const y1 = p[1] - p1[1];\n const x2 = p[0] - p2[0];\n const y2 = p[1] - p2[1];\n return (x1 * y2 - x2 * y1 === 0) && (x1 * x2 <= 0) && (y1 * y2 <= 0);\n}\n\nfunction rayIntersect(p, p1, p2) {\n return ((p1[1] > p[1]) !== (p2[1] > p[1])) && (p[0] < (p2[0] - p1[0]) * (p[1] - p1[1]) / (p2[1] - p1[1]) + p1[0]);\n}\n\n// ray casting algorithm for detecting if point is in polygon\nfunction pointWithinPolygon(point, rings) {\n let inside = false;\n for (let i = 0, len = rings.length; i < len; i++) {\n const ring = rings[i];\n for (let j = 0, len2 = ring.length; j < len2 - 1; j++) {\n if (onBoundary(point, ring[j], ring[j + 1])) return false;\n if (rayIntersect(point, ring[j], ring[j + 1])) inside = !inside;\n }\n }\n return inside;\n}\n\nfunction pointWithinPolygons(point, polygons) {\n for (let i = 0; i < polygons.length; i++) {\n if (pointWithinPolygon(point, polygons[i])) return true;\n }\n return false;\n}\n\nfunction perp(v1, v2) {\n return (v1[0] * v2[1] - v1[1] * v2[0]);\n}\n\n// check if p1 and p2 are in different sides of line segment q1->q2\nfunction twoSided(p1, p2, q1, q2) {\n // q1->p1 (x1, y1), q1->p2 (x2, y2), q1->q2 (x3, y3)\n const x1 = p1[0] - q1[0];\n const y1 = p1[1] - q1[1];\n const x2 = p2[0] - q1[0];\n const y2 = p2[1] - q1[1];\n const x3 = q2[0] - q1[0];\n const y3 = q2[1] - q1[1];\n const det1 = (x1 * y3 - x3 * y1);\n const det2 = (x2 * y3 - x3 * y2);\n if ((det1 > 0 && det2 < 0) || (det1 < 0 && det2 > 0)) return true;\n return false;\n}\n// a, b are end points for line segment1, c and d are end points for line segment2\nfunction lineIntersectLine(a, b, c, d) {\n // check if two segments are parallel or not\n // precondition is end point a, b is inside polygon, if line a->b is\n // parallel to polygon edge c->d, then a->b won't intersect with c->d\n const vectorP = [b[0] - a[0], b[1] - a[1]];\n const vectorQ = [d[0] - c[0], d[1] - c[1]];\n if (perp(vectorQ, vectorP) === 0) return false;\n\n // If lines are intersecting with each other, the relative location should be:\n // a and b lie in different sides of segment c->d\n // c and d lie in different sides of segment a->b\n if (twoSided(a, b, c, d) && twoSided(c, d, a, b)) return true;\n return false;\n}\n\nfunction lineIntersectPolygon(p1, p2, polygon) {\n for (const ring of polygon) {\n // loop through every edge of the ring\n for (let j = 0; j < ring.length - 1; ++j) {\n if (lineIntersectLine(p1, p2, ring[j], ring[j + 1])) {\n return true;\n }\n }\n }\n return false;\n}\n\nfunction lineStringWithinPolygon(line, polygon) {\n // First, check if geometry points of line segments are all inside polygon\n for (let i = 0; i < line.length; ++i) {\n if (!pointWithinPolygon(line[i], polygon)) {\n return false;\n }\n }\n\n // Second, check if there is line segment intersecting polygon edge\n for (let i = 0; i < line.length - 1; ++i) {\n if (lineIntersectPolygon(line[i], line[i + 1], polygon)) {\n return false;\n }\n }\n return true;\n}\n\nfunction lineStringWithinPolygons(line, polygons) {\n for (let i = 0; i < polygons.length; i++) {\n if (lineStringWithinPolygon(line, polygons[i])) return true;\n }\n return false;\n}\n\nfunction getTilePolygon(coordinates, bbox: BBox, canonical: CanonicalTileID) {\n const polygon = [];\n for (let i = 0; i < coordinates.length; i++) {\n const ring = [];\n for (let j = 0; j < coordinates[i].length; j++) {\n const coord = getTileCoordinates(coordinates[i][j], canonical);\n updateBBox(bbox, coord);\n ring.push(coord);\n }\n polygon.push(ring);\n }\n return polygon;\n}\n\nfunction getTilePolygons(coordinates, bbox, canonical: CanonicalTileID) {\n const polygons = [];\n for (let i = 0; i < coordinates.length; i++) {\n const polygon = getTilePolygon(coordinates[i], bbox, canonical);\n polygons.push(polygon);\n }\n return polygons;\n}\n\nfunction updatePoint(p, bbox, polyBBox, worldSize) {\n if (p[0] < polyBBox[0] || p[0] > polyBBox[2]) {\n const halfWorldSize = worldSize * 0.5;\n let shift = (p[0] - polyBBox[0] > halfWorldSize) ? -worldSize : (polyBBox[0] - p[0] > halfWorldSize) ? worldSize : 0;\n if (shift === 0) {\n shift = (p[0] - polyBBox[2] > halfWorldSize) ? -worldSize : (polyBBox[2] - p[0] > halfWorldSize) ? worldSize : 0;\n }\n p[0] += shift;\n }\n updateBBox(bbox, p);\n}\n\nfunction resetBBox(bbox) {\n bbox[0] = bbox[1] = Infinity;\n bbox[2] = bbox[3] = -Infinity;\n}\n\nfunction getTilePoints(geometry, pointBBox, polyBBox, canonical: CanonicalTileID) {\n const worldSize = Math.pow(2, canonical.z) * EXTENT;\n const shifts = [canonical.x * EXTENT, canonical.y * EXTENT];\n const tilePoints = [];\n if (!geometry) return tilePoints;\n for (const points of geometry) {\n for (const point of points) {\n const p = [point.x + shifts[0], point.y + shifts[1]];\n updatePoint(p, pointBBox, polyBBox, worldSize);\n tilePoints.push(p);\n }\n }\n return tilePoints;\n}\n\nfunction getTileLines(geometry, lineBBox, polyBBox, canonical: CanonicalTileID) {\n const worldSize = Math.pow(2, canonical.z) * EXTENT;\n const shifts = [canonical.x * EXTENT, canonical.y * EXTENT];\n const tileLines = [];\n if (!geometry) return tileLines;\n for (const line of geometry) {\n const tileLine = [];\n for (const point of line) {\n const p = [point.x + shifts[0], point.y + shifts[1]];\n updateBBox(lineBBox, p);\n tileLine.push(p);\n }\n tileLines.push(tileLine);\n }\n if (lineBBox[2] - lineBBox[0] <= worldSize / 2) {\n resetBBox(lineBBox);\n for (const line of tileLines) {\n for (const p of line) {\n updatePoint(p, lineBBox, polyBBox, worldSize);\n }\n }\n }\n return tileLines;\n}\n\nfunction pointsWithinPolygons(ctx: EvaluationContext, polygonGeometry: GeoJSONPolygons) {\n const pointBBox = [Infinity, Infinity, -Infinity, -Infinity];\n const polyBBox = [Infinity, Infinity, -Infinity, -Infinity];\n\n const canonical = ctx.canonicalID();\n if (!canonical) {\n return false;\n }\n\n if (polygonGeometry.type === 'Polygon') {\n const tilePolygon = getTilePolygon(polygonGeometry.coordinates, polyBBox, canonical);\n const tilePoints = getTilePoints(ctx.geometry(), pointBBox, polyBBox, canonical);\n if (!boxWithinBox(pointBBox, polyBBox)) return false;\n\n for (const point of tilePoints) {\n if (!pointWithinPolygon(point, tilePolygon)) return false;\n }\n }\n if (polygonGeometry.type === 'MultiPolygon') {\n const tilePolygons = getTilePolygons(polygonGeometry.coordinates, polyBBox, canonical);\n const tilePoints = getTilePoints(ctx.geometry(), pointBBox, polyBBox, canonical);\n if (!boxWithinBox(pointBBox, polyBBox)) return false;\n\n for (const point of tilePoints) {\n if (!pointWithinPolygons(point, tilePolygons)) return false;\n }\n }\n\n return true;\n}\n\nfunction linesWithinPolygons(ctx: EvaluationContext, polygonGeometry: GeoJSONPolygons) {\n const lineBBox = [Infinity, Infinity, -Infinity, -Infinity];\n const polyBBox = [Infinity, Infinity, -Infinity, -Infinity];\n\n const canonical = ctx.canonicalID();\n if (!canonical) {\n return false;\n }\n\n if (polygonGeometry.type === 'Polygon') {\n const tilePolygon = getTilePolygon(polygonGeometry.coordinates, polyBBox, canonical);\n const tileLines = getTileLines(ctx.geometry(), lineBBox, polyBBox, canonical);\n if (!boxWithinBox(lineBBox, polyBBox)) return false;\n\n for (const line of tileLines) {\n if (!lineStringWithinPolygon(line, tilePolygon)) return false;\n }\n }\n if (polygonGeometry.type === 'MultiPolygon') {\n const tilePolygons = getTilePolygons(polygonGeometry.coordinates, polyBBox, canonical);\n const tileLines = getTileLines(ctx.geometry(), lineBBox, polyBBox, canonical);\n if (!boxWithinBox(lineBBox, polyBBox)) return false;\n\n for (const line of tileLines) {\n if (!lineStringWithinPolygons(line, tilePolygons)) return false;\n }\n }\n return true;\n}\n\nclass Within implements Expression {\n type: Type;\n geojson: GeoJSON\n geometries: GeoJSONPolygons;\n\n constructor(geojson: GeoJSON, geometries: GeoJSONPolygons) {\n this.type = BooleanType;\n this.geojson = geojson;\n this.geometries = geometries;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Within {\n if (args.length !== 2)\n return context.error(`'within' expression requires exactly one argument, but found ${args.length - 1} instead.`);\n if (isValue(args[1])) {\n const geojson = (args[1]: Object);\n if (geojson.type === 'FeatureCollection') {\n for (let i = 0; i < geojson.features.length; ++i) {\n const type = geojson.features[i].geometry.type;\n if (type === 'Polygon' || type === 'MultiPolygon') {\n return new Within(geojson, geojson.features[i].geometry);\n }\n }\n } else if (geojson.type === 'Feature') {\n const type = geojson.geometry.type;\n if (type === 'Polygon' || type === 'MultiPolygon') {\n return new Within(geojson, geojson.geometry);\n }\n } else if (geojson.type === 'Polygon' || geojson.type === 'MultiPolygon') {\n return new Within(geojson, geojson);\n }\n }\n return context.error(`'within' expression requires valid geojson object that contains polygon geometry type.`);\n }\n\n evaluate(ctx: EvaluationContext): boolean {\n if (ctx.geometry() != null && ctx.canonicalID() != null) {\n if (ctx.geometryType() === 'Point') {\n return pointsWithinPolygons(ctx, this.geometries);\n } else if (ctx.geometryType() === 'LineString') {\n return linesWithinPolygons(ctx, this.geometries);\n }\n }\n return false;\n }\n\n eachChild() {}\n\n outputDefined(): boolean {\n return true;\n }\n\n serialize(): SerializedExpression {\n return [\"within\", this.geojson];\n }\n\n}\n\nexport default Within;\n","// @flow\n\nimport CompoundExpression from './compound_expression.js';\nimport Within from './definitions/within.js';\nimport type {Expression} from './expression.js';\n\nfunction isFeatureConstant(e: Expression): boolean {\n if (e instanceof CompoundExpression) {\n if (e.name === 'get' && e.args.length === 1) {\n return false;\n } else if (e.name === 'feature-state') {\n return false;\n } else if (e.name === 'has' && e.args.length === 1) {\n return false;\n } else if (\n e.name === 'properties' ||\n e.name === 'geometry-type' ||\n e.name === 'id'\n ) {\n return false;\n } else if (/^filter-/.test(e.name)) {\n return false;\n }\n }\n\n if (e instanceof Within) {\n return false;\n }\n\n let result = true;\n e.eachChild(arg => {\n if (result && !isFeatureConstant(arg)) { result = false; }\n });\n return result;\n}\n\nfunction isStateConstant(e: Expression): boolean {\n if (e instanceof CompoundExpression) {\n if (e.name === 'feature-state') {\n return false;\n }\n }\n let result = true;\n e.eachChild(arg => {\n if (result && !isStateConstant(arg)) { result = false; }\n });\n return result;\n}\n\nfunction isGlobalPropertyConstant(e: Expression, properties: Array): boolean {\n if (e instanceof CompoundExpression && properties.indexOf(e.name) >= 0) { return false; }\n let result = true;\n e.eachChild((arg) => {\n if (result && !isGlobalPropertyConstant(arg, properties)) { result = false; }\n });\n return result;\n}\n\nexport {isFeatureConstant, isGlobalPropertyConstant, isStateConstant};\n","// @flow\n\nimport type {Type} from '../types.js';\nimport type {Expression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\n\nclass Var implements Expression {\n type: Type;\n name: string;\n boundExpression: Expression;\n\n constructor(name: string, boundExpression: Expression) {\n this.type = boundExpression.type;\n this.name = name;\n this.boundExpression = boundExpression;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): void | Var {\n if (args.length !== 2 || typeof args[1] !== 'string')\n return context.error(`'var' expression requires exactly one string literal argument.`);\n\n const name = args[1];\n if (!context.scope.has(name)) {\n return context.error(`Unknown variable \"${name}\". Make sure \"${name}\" has been bound in an enclosing \"let\" expression before using it.`, 1);\n }\n\n return new Var(name, context.scope.get(name));\n }\n\n evaluate(ctx: EvaluationContext): any {\n return this.boundExpression.evaluate(ctx);\n }\n\n eachChild() {}\n\n outputDefined(): boolean {\n return false;\n }\n\n serialize(): Array {\n return [\"var\", this.name];\n }\n}\n\nexport default Var;\n","// @flow\n\nimport Scope from './scope.js';\nimport {checkSubtype} from './types.js';\nimport ParsingError from './parsing_error.js';\nimport Literal from './definitions/literal.js';\nimport Assertion from './definitions/assertion.js';\nimport Coercion from './definitions/coercion.js';\nimport EvaluationContext from './evaluation_context.js';\nimport CompoundExpression from './compound_expression.js';\nimport CollatorExpression from './definitions/collator.js';\nimport Within from './definitions/within.js';\nimport {isGlobalPropertyConstant, isFeatureConstant} from './is_constant.js';\nimport Var from './definitions/var.js';\n\nimport type {Expression, ExpressionRegistry} from './expression.js';\nimport type {Type} from './types.js';\n\n/**\n * State associated parsing at a given point in an expression tree.\n * @private\n */\nclass ParsingContext {\n registry: ExpressionRegistry;\n path: Array;\n key: string;\n scope: Scope;\n errors: Array;\n\n // The expected type of this expression. Provided only to allow Expression\n // implementations to infer argument types: Expression#parse() need not\n // check that the output type of the parsed expression matches\n // `expectedType`.\n expectedType: ?Type;\n\n constructor(\n registry: ExpressionRegistry,\n path: Array = [],\n expectedType: ?Type,\n scope: Scope = new Scope(),\n errors: Array = []\n ) {\n this.registry = registry;\n this.path = path;\n this.key = path.map(part => `[${part}]`).join('');\n this.scope = scope;\n this.errors = errors;\n this.expectedType = expectedType;\n }\n\n /**\n * @param expr the JSON expression to parse\n * @param index the optional argument index if this expression is an argument of a parent expression that's being parsed\n * @param options\n * @param options.omitTypeAnnotations set true to omit inferred type annotations. Caller beware: with this option set, the parsed expression's type will NOT satisfy `expectedType` if it would normally be wrapped in an inferred annotation.\n * @private\n */\n parse(\n expr: mixed,\n index?: number,\n expectedType?: ?Type,\n bindings?: Array<[string, Expression]>,\n options: {typeAnnotation?: 'assert' | 'coerce' | 'omit'} = {}\n ): ?Expression {\n if (index) {\n return this.concat(index, expectedType, bindings)._parse(expr, options);\n }\n return this._parse(expr, options);\n }\n\n _parse(expr: mixed, options: {typeAnnotation?: 'assert' | 'coerce' | 'omit'}): ?Expression {\n if (expr === null || typeof expr === 'string' || typeof expr === 'boolean' || typeof expr === 'number') {\n expr = ['literal', expr];\n }\n\n function annotate(parsed, type, typeAnnotation: 'assert' | 'coerce' | 'omit') {\n if (typeAnnotation === 'assert') {\n return new Assertion(type, [parsed]);\n } else if (typeAnnotation === 'coerce') {\n return new Coercion(type, [parsed]);\n } else {\n return parsed;\n }\n }\n\n if (Array.isArray(expr)) {\n if (expr.length === 0) {\n return this.error(`Expected an array with at least one element. If you wanted a literal array, use [\"literal\", []].`);\n }\n\n const op = expr[0];\n if (typeof op !== 'string') {\n this.error(`Expression name must be a string, but found ${typeof op} instead. If you wanted a literal array, use [\"literal\", [...]].`, 0);\n return null;\n }\n\n const Expr = this.registry[op];\n if (Expr) {\n let parsed = Expr.parse(expr, this);\n if (!parsed) return null;\n\n if (this.expectedType) {\n const expected = this.expectedType;\n const actual = parsed.type;\n\n // When we expect a number, string, boolean, or array but have a value, wrap it in an assertion.\n // When we expect a color or formatted string, but have a string or value, wrap it in a coercion.\n // Otherwise, we do static type-checking.\n //\n // These behaviors are overridable for:\n // * The \"coalesce\" operator, which needs to omit type annotations.\n // * String-valued properties (e.g. `text-field`), where coercion is more convenient than assertion.\n //\n if ((expected.kind === 'string' || expected.kind === 'number' || expected.kind === 'boolean' || expected.kind === 'object' || expected.kind === 'array') && actual.kind === 'value') {\n parsed = annotate(parsed, expected, options.typeAnnotation || 'assert');\n } else if ((expected.kind === 'color' || expected.kind === 'formatted' || expected.kind === 'resolvedImage') && (actual.kind === 'value' || actual.kind === 'string')) {\n parsed = annotate(parsed, expected, options.typeAnnotation || 'coerce');\n } else if (this.checkSubtype(expected, actual)) {\n return null;\n }\n }\n\n // If an expression's arguments are all literals, we can evaluate\n // it immediately and replace it with a literal value in the\n // parsed/compiled result. Expressions that expect an image should\n // not be resolved here so we can later get the available images.\n if (!(parsed instanceof Literal) && (parsed.type.kind !== 'resolvedImage') && isConstant(parsed)) {\n const ec = new EvaluationContext();\n try {\n parsed = new Literal(parsed.type, parsed.evaluate(ec));\n } catch (e) {\n this.error(e.message);\n return null;\n }\n }\n\n return parsed;\n }\n\n return this.error(`Unknown expression \"${op}\". If you wanted a literal array, use [\"literal\", [...]].`, 0);\n } else if (typeof expr === 'undefined') {\n return this.error(`'undefined' value invalid. Use null instead.`);\n } else if (typeof expr === 'object') {\n return this.error(`Bare objects invalid. Use [\"literal\", {...}] instead.`);\n } else {\n return this.error(`Expected an array, but found ${typeof expr} instead.`);\n }\n }\n\n /**\n * Returns a copy of this context suitable for parsing the subexpression at\n * index `index`, optionally appending to 'let' binding map.\n *\n * Note that `errors` property, intended for collecting errors while\n * parsing, is copied by reference rather than cloned.\n * @private\n */\n concat(index: number, expectedType?: ?Type, bindings?: Array<[string, Expression]>): ParsingContext {\n const path = typeof index === 'number' ? this.path.concat(index) : this.path;\n const scope = bindings ? this.scope.concat(bindings) : this.scope;\n return new ParsingContext(\n this.registry,\n path,\n expectedType || null,\n scope,\n this.errors\n );\n }\n\n /**\n * Push a parsing (or type checking) error into the `this.errors`\n * @param error The message\n * @param keys Optionally specify the source of the error at a child\n * of the current expression at `this.key`.\n * @private\n */\n error(error: string, ...keys: Array) {\n const key = `${this.key}${keys.map(k => `[${k}]`).join('')}`;\n this.errors.push(new ParsingError(key, error));\n }\n\n /**\n * Returns null if `t` is a subtype of `expected`; otherwise returns an\n * error message and also pushes it to `this.errors`.\n */\n checkSubtype(expected: Type, t: Type): ?string {\n const error = checkSubtype(expected, t);\n if (error) this.error(error);\n return error;\n }\n}\n\nexport default ParsingContext;\n\nfunction isConstant(expression: Expression) {\n if (expression instanceof Var) {\n return isConstant(expression.boundExpression);\n } else if (expression instanceof CompoundExpression && expression.name === 'error') {\n return false;\n } else if (expression instanceof CollatorExpression) {\n // Although the results of a Collator expression with fixed arguments\n // generally shouldn't change between executions, we can't serialize them\n // as constant expressions because results change based on environment.\n return false;\n } else if (expression instanceof Within) {\n return false;\n }\n\n const isTypeAnnotation = expression instanceof Coercion ||\n expression instanceof Assertion;\n\n let childrenConstant = true;\n expression.eachChild(child => {\n // We can _almost_ assume that if `expressions` children are constant,\n // they would already have been evaluated to Literal values when they\n // were parsed. Type annotations are the exception, because they might\n // have been inferred and added after a child was parsed.\n\n // So we recurse into isConstant() for the children of type annotations,\n // but otherwise simply check whether they are Literals.\n if (isTypeAnnotation) {\n childrenConstant = childrenConstant && isConstant(child);\n } else {\n childrenConstant = childrenConstant && child instanceof Literal;\n }\n });\n if (!childrenConstant) {\n return false;\n }\n\n return isFeatureConstant(expression) &&\n isGlobalPropertyConstant(expression, ['zoom', 'heatmap-density', 'line-progress', 'sky-radial-progress', 'accumulated', 'is-supported-script', 'pitch', 'distance-from-center']);\n}\n","// @flow\n\nimport RuntimeError from './runtime_error.js';\n\nimport type {Expression} from './expression.js';\n\nexport type Stops = Array<[number, Expression]>;\n\n/**\n * Returns the index of the last stop <= input, or 0 if it doesn't exist.\n * @private\n */\nexport function findStopLessThanOrEqualTo(stops: Array, input: number): number {\n const lastIndex = stops.length - 1;\n let lowerIndex = 0;\n let upperIndex = lastIndex;\n let currentIndex = 0;\n let currentValue, nextValue;\n\n while (lowerIndex <= upperIndex) {\n currentIndex = Math.floor((lowerIndex + upperIndex) / 2);\n currentValue = stops[currentIndex];\n nextValue = stops[currentIndex + 1];\n\n if (currentValue <= input) {\n if (currentIndex === lastIndex || input < nextValue) { // Search complete\n return currentIndex;\n }\n\n lowerIndex = currentIndex + 1;\n } else if (currentValue > input) {\n upperIndex = currentIndex - 1;\n } else {\n throw new RuntimeError('Input is not a number.');\n }\n }\n\n return 0;\n}\n","// @flow\n\nimport {NumberType} from '../types.js';\n\nimport {findStopLessThanOrEqualTo} from '../stops.js';\n\nimport type {Stops} from '../stops.js';\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nclass Step implements Expression {\n type: Type;\n\n input: Expression;\n labels: Array;\n outputs: Array;\n\n constructor(type: Type, input: Expression, stops: Stops) {\n this.type = type;\n this.input = input;\n\n this.labels = [];\n this.outputs = [];\n for (const [label, expression] of stops) {\n this.labels.push(label);\n this.outputs.push(expression);\n }\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Step {\n if (args.length - 1 < 4) {\n return context.error(`Expected at least 4 arguments, but found only ${args.length - 1}.`);\n }\n\n if ((args.length - 1) % 2 !== 0) {\n return context.error(`Expected an even number of arguments.`);\n }\n\n const input = context.parse(args[1], 1, NumberType);\n if (!input) return null;\n\n const stops: Stops = [];\n\n let outputType: Type = (null: any);\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n\n for (let i = 1; i < args.length; i += 2) {\n const label = i === 1 ? -Infinity : args[i];\n const value = args[i + 1];\n\n const labelKey = i;\n const valueKey = i + 1;\n\n if (typeof label !== 'number') {\n return context.error('Input/output pairs for \"step\" expressions must be defined using literal numeric values (not computed expressions) for the input values.', labelKey);\n }\n\n if (stops.length && stops[stops.length - 1][0] >= label) {\n return context.error('Input/output pairs for \"step\" expressions must be arranged with input values in strictly ascending order.', labelKey);\n }\n\n const parsed = context.parse(value, valueKey, outputType);\n if (!parsed) return null;\n outputType = outputType || parsed.type;\n stops.push([label, parsed]);\n }\n\n return new Step(outputType, input, stops);\n }\n\n evaluate(ctx: EvaluationContext): any {\n const labels = this.labels;\n const outputs = this.outputs;\n\n if (labels.length === 1) {\n return outputs[0].evaluate(ctx);\n }\n\n const value = ((this.input.evaluate(ctx): any): number);\n if (value <= labels[0]) {\n return outputs[0].evaluate(ctx);\n }\n\n const stopCount = labels.length;\n if (value >= labels[stopCount - 1]) {\n return outputs[stopCount - 1].evaluate(ctx);\n }\n\n const index = findStopLessThanOrEqualTo(labels, value);\n return outputs[index].evaluate(ctx);\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.input);\n for (const expression of this.outputs) {\n fn(expression);\n }\n }\n\n outputDefined(): boolean {\n return this.outputs.every(out => out.outputDefined());\n }\n\n serialize(): SerializedExpression {\n const serialized = [\"step\", this.input.serialize()];\n for (let i = 0; i < this.labels.length; i++) {\n if (i > 0) {\n serialized.push(this.labels[i]);\n }\n serialized.push(this.outputs[i].serialize());\n }\n return serialized;\n }\n}\n\nexport default Step;\n","/*\n * Copyright (C) 2008 Apple Inc. All Rights Reserved.\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions\n * are met:\n * 1. Redistributions of source code must retain the above copyright\n * notice, this list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright\n * notice, this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n *\n * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY\n * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR\n * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR\n * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,\n * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,\n * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR\n * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY\n * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n *\n * Ported from Webkit\n * http://svn.webkit.org/repository/webkit/trunk/Source/WebCore/platform/graphics/UnitBezier.h\n */\n\nmodule.exports = UnitBezier;\n\nfunction UnitBezier(p1x, p1y, p2x, p2y) {\n // Calculate the polynomial coefficients, implicit first and last control points are (0,0) and (1,1).\n this.cx = 3.0 * p1x;\n this.bx = 3.0 * (p2x - p1x) - this.cx;\n this.ax = 1.0 - this.cx - this.bx;\n\n this.cy = 3.0 * p1y;\n this.by = 3.0 * (p2y - p1y) - this.cy;\n this.ay = 1.0 - this.cy - this.by;\n\n this.p1x = p1x;\n this.p1y = p2y;\n this.p2x = p2x;\n this.p2y = p2y;\n}\n\nUnitBezier.prototype.sampleCurveX = function(t) {\n // `ax t^3 + bx t^2 + cx t' expanded using Horner's rule.\n return ((this.ax * t + this.bx) * t + this.cx) * t;\n};\n\nUnitBezier.prototype.sampleCurveY = function(t) {\n return ((this.ay * t + this.by) * t + this.cy) * t;\n};\n\nUnitBezier.prototype.sampleCurveDerivativeX = function(t) {\n return (3.0 * this.ax * t + 2.0 * this.bx) * t + this.cx;\n};\n\nUnitBezier.prototype.solveCurveX = function(x, epsilon) {\n if (typeof epsilon === 'undefined') epsilon = 1e-6;\n\n var t0, t1, t2, x2, i;\n\n // First try a few iterations of Newton's method -- normally very fast.\n for (t2 = x, i = 0; i < 8; i++) {\n\n x2 = this.sampleCurveX(t2) - x;\n if (Math.abs(x2) < epsilon) return t2;\n\n var d2 = this.sampleCurveDerivativeX(t2);\n if (Math.abs(d2) < 1e-6) break;\n\n t2 = t2 - x2 / d2;\n }\n\n // Fall back to the bisection method for reliability.\n t0 = 0.0;\n t1 = 1.0;\n t2 = x;\n\n if (t2 < t0) return t0;\n if (t2 > t1) return t1;\n\n while (t0 < t1) {\n\n x2 = this.sampleCurveX(t2);\n if (Math.abs(x2 - x) < epsilon) return t2;\n\n if (x > x2) {\n t0 = t2;\n } else {\n t1 = t2;\n }\n\n t2 = (t1 - t0) * 0.5 + t0;\n }\n\n // Failure.\n return t2;\n};\n\nUnitBezier.prototype.solve = function(x, epsilon) {\n return this.sampleCurveY(this.solveCurveX(x, epsilon));\n};\n","// @flow\n\nimport Color from './color.js';\n\nexport function number(a: number, b: number, t: number): number {\n return (a * (1 - t)) + (b * t);\n}\n\nexport function color(from: Color, to: Color, t: number): Color {\n return new Color(\n number(from.r, to.r, t),\n number(from.g, to.g, t),\n number(from.b, to.b, t),\n number(from.a, to.a, t)\n );\n}\n\nexport function array(from: Array, to: Array, t: number): Array {\n return from.map((d, i) => {\n return number(d, to[i], t);\n });\n}\n","// @flow\n\nimport Color from './color.js';\n\nimport {number as interpolateNumber} from './interpolate.js';\n\ntype LABColor = {\n l: number,\n a: number,\n b: number,\n alpha: number\n};\n\ntype HCLColor = {\n h: number,\n c: number,\n l: number,\n alpha: number\n};\n\n// Constants\nconst Xn = 0.950470, // D65 standard referent\n Yn = 1,\n Zn = 1.088830,\n t0 = 4 / 29,\n t1 = 6 / 29,\n t2 = 3 * t1 * t1,\n t3 = t1 * t1 * t1,\n deg2rad = Math.PI / 180,\n rad2deg = 180 / Math.PI;\n\n// Utilities\nfunction xyz2lab(t: number) {\n return t > t3 ? Math.pow(t, 1 / 3) : t / t2 + t0;\n}\n\nfunction lab2xyz(t: number) {\n return t > t1 ? t * t * t : t2 * (t - t0);\n}\n\nfunction xyz2rgb(x: number) {\n return 255 * (x <= 0.0031308 ? 12.92 * x : 1.055 * Math.pow(x, 1 / 2.4) - 0.055);\n}\n\nfunction rgb2xyz(x: number) {\n x /= 255;\n return x <= 0.04045 ? x / 12.92 : Math.pow((x + 0.055) / 1.055, 2.4);\n}\n\n// LAB\nfunction rgbToLab(rgbColor: Color): LABColor {\n const b = rgb2xyz(rgbColor.r),\n a = rgb2xyz(rgbColor.g),\n l = rgb2xyz(rgbColor.b),\n x = xyz2lab((0.4124564 * b + 0.3575761 * a + 0.1804375 * l) / Xn),\n y = xyz2lab((0.2126729 * b + 0.7151522 * a + 0.0721750 * l) / Yn),\n z = xyz2lab((0.0193339 * b + 0.1191920 * a + 0.9503041 * l) / Zn);\n\n return {\n l: 116 * y - 16,\n a: 500 * (x - y),\n b: 200 * (y - z),\n alpha: rgbColor.a\n };\n}\n\nfunction labToRgb(labColor: LABColor): Color {\n let y = (labColor.l + 16) / 116,\n x = isNaN(labColor.a) ? y : y + labColor.a / 500,\n z = isNaN(labColor.b) ? y : y - labColor.b / 200;\n y = Yn * lab2xyz(y);\n x = Xn * lab2xyz(x);\n z = Zn * lab2xyz(z);\n return new Color(\n xyz2rgb(3.2404542 * x - 1.5371385 * y - 0.4985314 * z), // D65 -> sRGB\n xyz2rgb(-0.9692660 * x + 1.8760108 * y + 0.0415560 * z),\n xyz2rgb(0.0556434 * x - 0.2040259 * y + 1.0572252 * z),\n labColor.alpha\n );\n}\n\nfunction interpolateLab(from: LABColor, to: LABColor, t: number): LABColor {\n return {\n l: interpolateNumber(from.l, to.l, t),\n a: interpolateNumber(from.a, to.a, t),\n b: interpolateNumber(from.b, to.b, t),\n alpha: interpolateNumber(from.alpha, to.alpha, t)\n };\n}\n\n// HCL\nfunction rgbToHcl(rgbColor: Color): HCLColor {\n const {l, a, b} = rgbToLab(rgbColor);\n const h = Math.atan2(b, a) * rad2deg;\n return {\n h: h < 0 ? h + 360 : h,\n c: Math.sqrt(a * a + b * b),\n l,\n alpha: rgbColor.a\n };\n}\n\nfunction hclToRgb(hclColor: HCLColor): Color {\n const h = hclColor.h * deg2rad,\n c = hclColor.c,\n l = hclColor.l;\n return labToRgb({\n l,\n a: Math.cos(h) * c,\n b: Math.sin(h) * c,\n alpha: hclColor.alpha\n });\n}\n\nfunction interpolateHue(a: number, b: number, t: number) {\n const d = b - a;\n return a + t * (d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d);\n}\n\nfunction interpolateHcl(from: HCLColor, to: HCLColor, t: number): HCLColor {\n return {\n h: interpolateHue(from.h, to.h, t),\n c: interpolateNumber(from.c, to.c, t),\n l: interpolateNumber(from.l, to.l, t),\n alpha: interpolateNumber(from.alpha, to.alpha, t)\n };\n}\n\nexport const lab = {\n forward: rgbToLab,\n reverse: labToRgb,\n interpolate: interpolateLab\n};\n\nexport const hcl = {\n forward: rgbToHcl,\n reverse: hclToRgb,\n interpolate: interpolateHcl\n};\n","// @flow\n\nimport UnitBezier from '@mapbox/unitbezier';\n\nimport * as interpolate from '../../util/interpolate.js';\nimport {toString, NumberType, ColorType} from '../types.js';\nimport {findStopLessThanOrEqualTo} from '../stops.js';\nimport {hcl, lab} from '../../util/color_spaces.js';\nimport Color from '../../util/color.js';\n\nimport type {Stops} from '../stops.js';\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nexport type InterpolationType =\n { name: 'linear' } |\n { name: 'exponential', base: number } |\n { name: 'cubic-bezier', controlPoints: [number, number, number, number] };\n\nclass Interpolate implements Expression {\n type: Type;\n\n operator: 'interpolate' | 'interpolate-hcl' | 'interpolate-lab';\n interpolation: InterpolationType;\n input: Expression;\n labels: Array;\n outputs: Array;\n\n constructor(type: Type, operator: 'interpolate' | 'interpolate-hcl' | 'interpolate-lab', interpolation: InterpolationType, input: Expression, stops: Stops) {\n this.type = type;\n this.operator = operator;\n this.interpolation = interpolation;\n this.input = input;\n\n this.labels = [];\n this.outputs = [];\n for (const [label, expression] of stops) {\n this.labels.push(label);\n this.outputs.push(expression);\n }\n }\n\n static interpolationFactor(interpolation: InterpolationType, input: number, lower: number, upper: number): number {\n let t = 0;\n if (interpolation.name === 'exponential') {\n t = exponentialInterpolation(input, interpolation.base, lower, upper);\n } else if (interpolation.name === 'linear') {\n t = exponentialInterpolation(input, 1, lower, upper);\n } else if (interpolation.name === 'cubic-bezier') {\n const c = interpolation.controlPoints;\n const ub = new UnitBezier(c[0], c[1], c[2], c[3]);\n t = ub.solve(exponentialInterpolation(input, 1, lower, upper));\n }\n return t;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Interpolate {\n let [operator, interpolation, input, ...rest] = args;\n\n if (!Array.isArray(interpolation) || interpolation.length === 0) {\n return context.error(`Expected an interpolation type expression.`, 1);\n }\n\n if (interpolation[0] === 'linear') {\n interpolation = {name: 'linear'};\n } else if (interpolation[0] === 'exponential') {\n const base = interpolation[1];\n if (typeof base !== 'number')\n return context.error(`Exponential interpolation requires a numeric base.`, 1, 1);\n interpolation = {\n name: 'exponential',\n base\n };\n } else if (interpolation[0] === 'cubic-bezier') {\n const controlPoints = interpolation.slice(1);\n if (\n controlPoints.length !== 4 ||\n controlPoints.some(t => typeof t !== 'number' || t < 0 || t > 1)\n ) {\n return context.error('Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.', 1);\n }\n\n interpolation = {\n name: 'cubic-bezier',\n controlPoints: (controlPoints: any)\n };\n } else {\n return context.error(`Unknown interpolation type ${String(interpolation[0])}`, 1, 0);\n }\n\n if (args.length - 1 < 4) {\n return context.error(`Expected at least 4 arguments, but found only ${args.length - 1}.`);\n }\n\n if ((args.length - 1) % 2 !== 0) {\n return context.error(`Expected an even number of arguments.`);\n }\n\n input = context.parse(input, 2, NumberType);\n if (!input) return null;\n\n const stops: Stops = [];\n\n let outputType: Type = (null: any);\n if (operator === 'interpolate-hcl' || operator === 'interpolate-lab') {\n outputType = ColorType;\n } else if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n\n for (let i = 0; i < rest.length; i += 2) {\n const label = rest[i];\n const value = rest[i + 1];\n\n const labelKey = i + 3;\n const valueKey = i + 4;\n\n if (typeof label !== 'number') {\n return context.error('Input/output pairs for \"interpolate\" expressions must be defined using literal numeric values (not computed expressions) for the input values.', labelKey);\n }\n\n if (stops.length && stops[stops.length - 1][0] >= label) {\n return context.error('Input/output pairs for \"interpolate\" expressions must be arranged with input values in strictly ascending order.', labelKey);\n }\n\n const parsed = context.parse(value, valueKey, outputType);\n if (!parsed) return null;\n outputType = outputType || parsed.type;\n stops.push([label, parsed]);\n }\n\n if (outputType.kind !== 'number' &&\n outputType.kind !== 'color' &&\n !(\n outputType.kind === 'array' &&\n outputType.itemType.kind === 'number' &&\n typeof outputType.N === 'number'\n )\n ) {\n return context.error(`Type ${toString(outputType)} is not interpolatable.`);\n }\n\n return new Interpolate(outputType, (operator: any), interpolation, input, stops);\n }\n\n evaluate(ctx: EvaluationContext): Color {\n const labels = this.labels;\n const outputs = this.outputs;\n\n if (labels.length === 1) {\n return outputs[0].evaluate(ctx);\n }\n\n const value = ((this.input.evaluate(ctx): any): number);\n if (value <= labels[0]) {\n return outputs[0].evaluate(ctx);\n }\n\n const stopCount = labels.length;\n if (value >= labels[stopCount - 1]) {\n return outputs[stopCount - 1].evaluate(ctx);\n }\n\n const index = findStopLessThanOrEqualTo(labels, value);\n const lower = labels[index];\n const upper = labels[index + 1];\n const t = Interpolate.interpolationFactor(this.interpolation, value, lower, upper);\n\n const outputLower = outputs[index].evaluate(ctx);\n const outputUpper = outputs[index + 1].evaluate(ctx);\n\n if (this.operator === 'interpolate') {\n return (interpolate[this.type.kind.toLowerCase()]: any)(outputLower, outputUpper, t); // eslint-disable-line import/namespace\n } else if (this.operator === 'interpolate-hcl') {\n return hcl.reverse(hcl.interpolate(hcl.forward(outputLower), hcl.forward(outputUpper), t));\n } else {\n return lab.reverse(lab.interpolate(lab.forward(outputLower), lab.forward(outputUpper), t));\n }\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.input);\n for (const expression of this.outputs) {\n fn(expression);\n }\n }\n\n outputDefined(): boolean {\n return this.outputs.every(out => out.outputDefined());\n }\n\n serialize(): SerializedExpression {\n let interpolation;\n if (this.interpolation.name === 'linear') {\n interpolation = [\"linear\"];\n } else if (this.interpolation.name === 'exponential') {\n if (this.interpolation.base === 1) {\n interpolation = [\"linear\"];\n } else {\n interpolation = [\"exponential\", this.interpolation.base];\n }\n } else {\n interpolation = [\"cubic-bezier\" ].concat(this.interpolation.controlPoints);\n }\n\n const serialized = [this.operator, interpolation, this.input.serialize()];\n\n for (let i = 0; i < this.labels.length; i++) {\n serialized.push(\n this.labels[i],\n this.outputs[i].serialize()\n );\n }\n return serialized;\n }\n}\n\n/**\n * Returns a ratio that can be used to interpolate between exponential function\n * stops.\n * How it works: Two consecutive stop values define a (scaled and shifted) exponential function `f(x) = a * base^x + b`, where `base` is the user-specified base,\n * and `a` and `b` are constants affording sufficient degrees of freedom to fit\n * the function to the given stops.\n *\n * Here's a bit of algebra that lets us compute `f(x)` directly from the stop\n * values without explicitly solving for `a` and `b`:\n *\n * First stop value: `f(x0) = y0 = a * base^x0 + b`\n * Second stop value: `f(x1) = y1 = a * base^x1 + b`\n * => `y1 - y0 = a(base^x1 - base^x0)`\n * => `a = (y1 - y0)/(base^x1 - base^x0)`\n *\n * Desired value: `f(x) = y = a * base^x + b`\n * => `f(x) = y0 + a * (base^x - base^x0)`\n *\n * From the above, we can replace the `a` in `a * (base^x - base^x0)` and do a\n * little algebra:\n * ```\n * a * (base^x - base^x0) = (y1 - y0)/(base^x1 - base^x0) * (base^x - base^x0)\n * = (y1 - y0) * (base^x - base^x0) / (base^x1 - base^x0)\n * ```\n *\n * If we let `(base^x - base^x0) / (base^x1 base^x0)`, then we have\n * `f(x) = y0 + (y1 - y0) * ratio`. In other words, `ratio` may be treated as\n * an interpolation factor between the two stops' output values.\n *\n * (Note: a slightly different form for `ratio`,\n * `(base^(x-x0) - 1) / (base^(x1-x0) - 1) `, is equivalent, but requires fewer\n * expensive `Math.pow()` operations.)\n *\n * @private\n*/\nfunction exponentialInterpolation(input, base, lowerValue, upperValue) {\n const difference = upperValue - lowerValue;\n const progress = input - lowerValue;\n\n if (difference === 0) {\n return 0;\n } else if (base === 1) {\n return progress / difference;\n } else {\n return (Math.pow(base, progress) - 1) / (Math.pow(base, difference) - 1);\n }\n}\n\nexport default Interpolate;\n","// @flow\n\nimport assert from 'assert';\n\nimport {checkSubtype, ValueType} from '../types.js';\nimport ResolvedImage from '../types/resolved_image.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nclass Coalesce implements Expression {\n type: Type;\n args: Array;\n\n constructor(type: Type, args: Array) {\n this.type = type;\n this.args = args;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Coalesce {\n if (args.length < 2) {\n return context.error(\"Expectected at least one argument.\");\n }\n let outputType: Type = (null: any);\n const expectedType = context.expectedType;\n if (expectedType && expectedType.kind !== 'value') {\n outputType = expectedType;\n }\n const parsedArgs = [];\n\n for (const arg of args.slice(1)) {\n const parsed = context.parse(arg, 1 + parsedArgs.length, outputType, undefined, {typeAnnotation: 'omit'});\n if (!parsed) return null;\n outputType = outputType || parsed.type;\n parsedArgs.push(parsed);\n }\n assert(outputType);\n\n // Above, we parse arguments without inferred type annotation so that\n // they don't produce a runtime error for `null` input, which would\n // preempt the desired null-coalescing behavior.\n // Thus, if any of our arguments would have needed an annotation, we\n // need to wrap the enclosing coalesce expression with it instead.\n const needsAnnotation = expectedType &&\n parsedArgs.some(arg => checkSubtype(expectedType, arg.type));\n\n return needsAnnotation ?\n new Coalesce(ValueType, parsedArgs) :\n new Coalesce((outputType: any), parsedArgs);\n }\n\n evaluate(ctx: EvaluationContext): any | null {\n let result = null;\n let argCount = 0;\n let firstImage;\n for (const arg of this.args) {\n argCount++;\n result = arg.evaluate(ctx);\n // we need to keep track of the first requested image in a coalesce statement\n // if coalesce can't find a valid image, we return the first image so styleimagemissing can fire\n if (result && result instanceof ResolvedImage && !result.available) {\n // set to first image\n if (!firstImage) {\n firstImage = result;\n }\n result = null;\n // if we reach the end, return the first image\n if (argCount === this.args.length) {\n return firstImage;\n }\n }\n\n if (result !== null) break;\n }\n return result;\n }\n\n eachChild(fn: (_: Expression) => void) {\n this.args.forEach(fn);\n }\n\n outputDefined(): boolean {\n return this.args.every(arg => arg.outputDefined());\n }\n\n serialize(): SerializedExpression {\n const serialized = [\"coalesce\"];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n}\n\nexport default Coalesce;\n","// @flow\n\nimport type {Type} from '../types.js';\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\n\nclass Let implements Expression {\n type: Type;\n bindings: Array<[string, Expression]>;\n result: Expression;\n\n constructor(bindings: Array<[string, Expression]>, result: Expression) {\n this.type = result.type;\n this.bindings = [].concat(bindings);\n this.result = result;\n }\n\n evaluate(ctx: EvaluationContext): any {\n return this.result.evaluate(ctx);\n }\n\n eachChild(fn: (_: Expression) => void) {\n for (const binding of this.bindings) {\n fn(binding[1]);\n }\n fn(this.result);\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Let {\n if (args.length < 4)\n return context.error(`Expected at least 3 arguments, but found ${args.length - 1} instead.`);\n\n const bindings: Array<[string, Expression]> = [];\n for (let i = 1; i < args.length - 1; i += 2) {\n const name = args[i];\n\n if (typeof name !== 'string') {\n return context.error(`Expected string, but found ${typeof name} instead.`, i);\n }\n\n if (/[^a-zA-Z0-9_]/.test(name)) {\n return context.error(`Variable names must contain only alphanumeric characters or '_'.`, i);\n }\n\n const value = context.parse(args[i + 1], i + 1);\n if (!value) return null;\n\n bindings.push([name, value]);\n }\n\n const result = context.parse(args[args.length - 1], args.length - 1, context.expectedType, bindings);\n if (!result) return null;\n\n return new Let(bindings, result);\n }\n\n outputDefined(): boolean {\n return this.result.outputDefined();\n }\n\n serialize(): SerializedExpression {\n const serialized = [\"let\"];\n for (const [name, expr] of this.bindings) {\n serialized.push(name, expr.serialize());\n }\n serialized.push(this.result.serialize());\n return serialized;\n }\n}\n\nexport default Let;\n","// @flow\n\nimport {array, ValueType, NumberType} from '../types.js';\n\nimport RuntimeError from '../runtime_error.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type, ArrayType} from '../types.js';\nimport type {Value} from '../values.js';\n\nclass At implements Expression {\n type: Type;\n index: Expression;\n input: Expression;\n\n constructor(type: Type, index: Expression, input: Expression) {\n this.type = type;\n this.index = index;\n this.input = input;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?At {\n if (args.length !== 3)\n return context.error(`Expected 2 arguments, but found ${args.length - 1} instead.`);\n\n const index = context.parse(args[1], 1, NumberType);\n const input = context.parse(args[2], 2, array(context.expectedType || ValueType));\n\n if (!index || !input) return null;\n\n const t: ArrayType = (input.type: any);\n return new At(t.itemType, index, input);\n }\n\n evaluate(ctx: EvaluationContext): Value {\n const index = ((this.index.evaluate(ctx): any): number);\n const array = ((this.input.evaluate(ctx): any): Array);\n\n if (index < 0) {\n throw new RuntimeError(`Array index out of bounds: ${index} < 0.`);\n }\n\n if (index >= array.length) {\n throw new RuntimeError(`Array index out of bounds: ${index} > ${array.length - 1}.`);\n }\n\n if (index !== Math.floor(index)) {\n throw new RuntimeError(`Array index must be an integer, but found ${index} instead.`);\n }\n\n return array[index];\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.index);\n fn(this.input);\n }\n\n outputDefined(): boolean {\n return false;\n }\n\n serialize(): SerializedExpression {\n return [\"at\", this.index.serialize(), this.input.serialize()];\n }\n}\n\nexport default At;\n","// @flow\n\nimport {BooleanType, StringType, ValueType, NullType, toString, NumberType, isValidType, isValidNativeType} from '../types.js';\nimport RuntimeError from '../runtime_error.js';\nimport {typeOf} from '../values.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nclass In implements Expression {\n type: Type;\n needle: Expression;\n haystack: Expression;\n\n constructor(needle: Expression, haystack: Expression) {\n this.type = BooleanType;\n this.needle = needle;\n this.haystack = haystack;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?In {\n if (args.length !== 3) {\n return context.error(`Expected 2 arguments, but found ${args.length - 1} instead.`);\n }\n\n const needle = context.parse(args[1], 1, ValueType);\n\n const haystack = context.parse(args[2], 2, ValueType);\n\n if (!needle || !haystack) return null;\n\n if (!isValidType(needle.type, [BooleanType, StringType, NumberType, NullType, ValueType])) {\n return context.error(`Expected first argument to be of type boolean, string, number or null, but found ${toString(needle.type)} instead`);\n }\n\n return new In(needle, haystack);\n }\n\n evaluate(ctx: EvaluationContext): boolean {\n const needle = (this.needle.evaluate(ctx): any);\n const haystack = (this.haystack.evaluate(ctx): any);\n\n if (haystack == null) return false;\n\n if (!isValidNativeType(needle, ['boolean', 'string', 'number', 'null'])) {\n throw new RuntimeError(`Expected first argument to be of type boolean, string, number or null, but found ${toString(typeOf(needle))} instead.`);\n }\n\n if (!isValidNativeType(haystack, ['string', 'array'])) {\n throw new RuntimeError(`Expected second argument to be of type array or string, but found ${toString(typeOf(haystack))} instead.`);\n }\n\n return haystack.indexOf(needle) >= 0;\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.needle);\n fn(this.haystack);\n }\n\n outputDefined(): boolean {\n return true;\n }\n\n serialize(): SerializedExpression {\n return [\"in\", this.needle.serialize(), this.haystack.serialize()];\n }\n}\n\nexport default In;\n","// @flow\n\nimport {BooleanType, StringType, ValueType, NullType, toString, NumberType, isValidType, isValidNativeType} from '../types.js';\nimport RuntimeError from '../runtime_error.js';\nimport {typeOf} from '../values.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nclass IndexOf implements Expression {\n type: Type;\n needle: Expression;\n haystack: Expression;\n fromIndex: ?Expression;\n\n constructor(needle: Expression, haystack: Expression, fromIndex?: Expression) {\n this.type = NumberType;\n this.needle = needle;\n this.haystack = haystack;\n this.fromIndex = fromIndex;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?IndexOf {\n if (args.length <= 2 || args.length >= 5) {\n return context.error(`Expected 3 or 4 arguments, but found ${args.length - 1} instead.`);\n }\n\n const needle = context.parse(args[1], 1, ValueType);\n\n const haystack = context.parse(args[2], 2, ValueType);\n\n if (!needle || !haystack) return null;\n if (!isValidType(needle.type, [BooleanType, StringType, NumberType, NullType, ValueType])) {\n return context.error(`Expected first argument to be of type boolean, string, number or null, but found ${toString(needle.type)} instead`);\n }\n\n if (args.length === 4) {\n const fromIndex = context.parse(args[3], 3, NumberType);\n if (!fromIndex) return null;\n return new IndexOf(needle, haystack, fromIndex);\n } else {\n return new IndexOf(needle, haystack);\n }\n }\n\n evaluate(ctx: EvaluationContext): any {\n const needle = (this.needle.evaluate(ctx): any);\n const haystack = (this.haystack.evaluate(ctx): any);\n\n if (!isValidNativeType(needle, ['boolean', 'string', 'number', 'null'])) {\n throw new RuntimeError(`Expected first argument to be of type boolean, string, number or null, but found ${toString(typeOf(needle))} instead.`);\n }\n\n if (!isValidNativeType(haystack, ['string', 'array'])) {\n throw new RuntimeError(`Expected second argument to be of type array or string, but found ${toString(typeOf(haystack))} instead.`);\n }\n\n if (this.fromIndex) {\n const fromIndex = (this.fromIndex.evaluate(ctx): number);\n return haystack.indexOf(needle, fromIndex);\n }\n\n return haystack.indexOf(needle);\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.needle);\n fn(this.haystack);\n if (this.fromIndex) {\n fn(this.fromIndex);\n }\n }\n\n outputDefined(): boolean {\n return false;\n }\n\n serialize(): SerializedExpression {\n if (this.fromIndex != null && this.fromIndex !== undefined) {\n const fromIndex = this.fromIndex.serialize();\n return [\"index-of\", this.needle.serialize(), this.haystack.serialize(), fromIndex];\n }\n return [\"index-of\", this.needle.serialize(), this.haystack.serialize()];\n }\n}\n\nexport default IndexOf;\n","// @flow\n\nimport assert from 'assert';\n\nimport {typeOf} from '../values.js';\nimport {ValueType, type Type} from '../types.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\n\n// Map input label values to output expression index\ntype Cases = {[number | string]: number};\n\nclass Match implements Expression {\n type: Type;\n inputType: Type;\n\n input: Expression;\n cases: Cases;\n outputs: Array;\n otherwise: Expression;\n\n constructor(inputType: Type, outputType: Type, input: Expression, cases: Cases, outputs: Array, otherwise: Expression) {\n this.inputType = inputType;\n this.type = outputType;\n this.input = input;\n this.cases = cases;\n this.outputs = outputs;\n this.otherwise = otherwise;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Match {\n if (args.length < 5)\n return context.error(`Expected at least 4 arguments, but found only ${args.length - 1}.`);\n if (args.length % 2 !== 1)\n return context.error(`Expected an even number of arguments.`);\n\n let inputType;\n let outputType;\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n const cases = {};\n const outputs = [];\n for (let i = 2; i < args.length - 1; i += 2) {\n let labels = args[i];\n const value = args[i + 1];\n\n if (!Array.isArray(labels)) {\n labels = [labels];\n }\n\n const labelContext = context.concat(i);\n if (labels.length === 0) {\n return labelContext.error('Expected at least one branch label.');\n }\n\n for (const label of labels) {\n if (typeof label !== 'number' && typeof label !== 'string') {\n return labelContext.error(`Branch labels must be numbers or strings.`);\n } else if (typeof label === 'number' && Math.abs(label) > Number.MAX_SAFE_INTEGER) {\n return labelContext.error(`Branch labels must be integers no larger than ${Number.MAX_SAFE_INTEGER}.`);\n\n } else if (typeof label === 'number' && Math.floor(label) !== label) {\n return labelContext.error(`Numeric branch labels must be integer values.`);\n\n } else if (!inputType) {\n inputType = typeOf(label);\n } else if (labelContext.checkSubtype(inputType, typeOf(label))) {\n return null;\n }\n\n if (typeof cases[String(label)] !== 'undefined') {\n return labelContext.error('Branch labels must be unique.');\n }\n\n cases[String(label)] = outputs.length;\n }\n\n const result = context.parse(value, i, outputType);\n if (!result) return null;\n outputType = outputType || result.type;\n outputs.push(result);\n }\n\n const input = context.parse(args[1], 1, ValueType);\n if (!input) return null;\n\n const otherwise = context.parse(args[args.length - 1], args.length - 1, outputType);\n if (!otherwise) return null;\n\n assert(inputType && outputType);\n\n if (input.type.kind !== 'value' && context.concat(1).checkSubtype((inputType: any), input.type)) {\n return null;\n }\n\n return new Match((inputType: any), (outputType: any), input, cases, outputs, otherwise);\n }\n\n evaluate(ctx: EvaluationContext): any {\n const input = (this.input.evaluate(ctx): any);\n const output = (typeOf(input) === this.inputType && this.outputs[this.cases[input]]) || this.otherwise;\n return output.evaluate(ctx);\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.input);\n this.outputs.forEach(fn);\n fn(this.otherwise);\n }\n\n outputDefined(): boolean {\n return this.outputs.every(out => out.outputDefined()) && this.otherwise.outputDefined();\n }\n\n serialize(): SerializedExpression {\n const serialized = [\"match\", this.input.serialize()];\n\n // Sort so serialization has an arbitrary defined order, even though\n // branch order doesn't affect evaluation\n const sortedLabels = Object.keys(this.cases).sort();\n\n // Group branches by unique match expression to support condensed\n // serializations of the form [case1, case2, ...] -> matchExpression\n const groupedByOutput: Array<[number, Array]> = [];\n const outputLookup: {[index: number]: number} = {}; // lookup index into groupedByOutput for a given output expression\n for (const label of sortedLabels) {\n const outputIndex = outputLookup[this.cases[label]];\n if (outputIndex === undefined) {\n // First time seeing this output, add it to the end of the grouped list\n outputLookup[this.cases[label]] = groupedByOutput.length;\n groupedByOutput.push([this.cases[label], [label]]);\n } else {\n // We've seen this expression before, add the label to that output's group\n groupedByOutput[outputIndex][1].push(label);\n }\n }\n\n const coerceLabel = (label) => this.inputType.kind === 'number' ? Number(label) : label;\n\n for (const [outputIndex, labels] of groupedByOutput) {\n if (labels.length === 1) {\n // Only a single label matches this output expression\n serialized.push(coerceLabel(labels[0]));\n } else {\n // Array of literal labels pointing to this output expression\n serialized.push(labels.map(coerceLabel));\n }\n serialized.push(this.outputs[outputIndex].serialize());\n }\n serialized.push(this.otherwise.serialize());\n return serialized;\n }\n}\n\nexport default Match;\n","// @flow\n\nimport assert from 'assert';\n\nimport {BooleanType} from '../types.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\ntype Branches = Array<[Expression, Expression]>;\n\nclass Case implements Expression {\n type: Type;\n\n branches: Branches;\n otherwise: Expression;\n\n constructor(type: Type, branches: Branches, otherwise: Expression) {\n this.type = type;\n this.branches = branches;\n this.otherwise = otherwise;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Case {\n if (args.length < 4)\n return context.error(`Expected at least 3 arguments, but found only ${args.length - 1}.`);\n if (args.length % 2 !== 0)\n return context.error(`Expected an odd number of arguments.`);\n\n let outputType: ?Type;\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n\n const branches = [];\n for (let i = 1; i < args.length - 1; i += 2) {\n const test = context.parse(args[i], i, BooleanType);\n if (!test) return null;\n\n const result = context.parse(args[i + 1], i + 1, outputType);\n if (!result) return null;\n\n branches.push([test, result]);\n\n outputType = outputType || result.type;\n }\n\n const otherwise = context.parse(args[args.length - 1], args.length - 1, outputType);\n if (!otherwise) return null;\n\n assert(outputType);\n return new Case((outputType: any), branches, otherwise);\n }\n\n evaluate(ctx: EvaluationContext): any {\n for (const [test, expression] of this.branches) {\n if (test.evaluate(ctx)) {\n return expression.evaluate(ctx);\n }\n }\n return this.otherwise.evaluate(ctx);\n }\n\n eachChild(fn: (_: Expression) => void) {\n for (const [test, expression] of this.branches) {\n fn(test);\n fn(expression);\n }\n fn(this.otherwise);\n }\n\n outputDefined(): boolean {\n return this.branches.every(([_, out]) => out.outputDefined()) && this.otherwise.outputDefined();\n }\n\n serialize(): SerializedExpression {\n const serialized = [\"case\"];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n}\n\nexport default Case;\n","// @flow\n\nimport {ValueType, NumberType, StringType, array, toString, isValidType, isValidNativeType} from '../types.js';\nimport RuntimeError from '../runtime_error.js';\nimport {typeOf} from '../values.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nclass Slice implements Expression {\n type: Type;\n input: Expression;\n beginIndex: Expression;\n endIndex: ?Expression;\n\n constructor(type: Type, input: Expression, beginIndex: Expression, endIndex?: Expression) {\n this.type = type;\n this.input = input;\n this.beginIndex = beginIndex;\n this.endIndex = endIndex;\n\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Slice {\n if (args.length <= 2 || args.length >= 5) {\n return context.error(`Expected 3 or 4 arguments, but found ${args.length - 1} instead.`);\n }\n\n const input = context.parse(args[1], 1, ValueType);\n const beginIndex = context.parse(args[2], 2, NumberType);\n\n if (!input || !beginIndex) return null;\n\n if (!isValidType(input.type, [array(ValueType), StringType, ValueType])) {\n return context.error(`Expected first argument to be of type array or string, but found ${toString(input.type)} instead`);\n }\n\n if (args.length === 4) {\n const endIndex = context.parse(args[3], 3, NumberType);\n if (!endIndex) return null;\n return new Slice(input.type, input, beginIndex, endIndex);\n } else {\n return new Slice(input.type, input, beginIndex);\n }\n }\n\n evaluate(ctx: EvaluationContext): any {\n const input = (this.input.evaluate(ctx): any);\n const beginIndex = (this.beginIndex.evaluate(ctx): number);\n\n if (!isValidNativeType(input, ['string', 'array'])) {\n throw new RuntimeError(`Expected first argument to be of type array or string, but found ${toString(typeOf(input))} instead.`);\n }\n\n if (this.endIndex) {\n const endIndex = (this.endIndex.evaluate(ctx): number);\n return input.slice(beginIndex, endIndex);\n }\n\n return input.slice(beginIndex);\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.input);\n fn(this.beginIndex);\n if (this.endIndex) {\n fn(this.endIndex);\n }\n }\n\n outputDefined(): boolean {\n return false;\n }\n\n serialize(): SerializedExpression {\n if (this.endIndex != null && this.endIndex !== undefined) {\n const endIndex = this.endIndex.serialize();\n return [\"slice\", this.input.serialize(), this.beginIndex.serialize(), endIndex];\n }\n return [\"slice\", this.input.serialize(), this.beginIndex.serialize()];\n }\n}\n\nexport default Slice;\n","// @flow\n\nimport {toString, ValueType, BooleanType, CollatorType} from '../types.js';\nimport Assertion from './assertion.js';\nimport {typeOf} from '../values.js';\nimport RuntimeError from '../runtime_error.js';\n\nimport type {Expression, SerializedExpression, ExpressionRegistration} from '../expression.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type {Type} from '../types.js';\n\ntype ComparisonOperator = '==' | '!=' | '<' | '>' | '<=' | '>=' ;\n\nfunction isComparableType(op: ComparisonOperator, type: Type) {\n if (op === '==' || op === '!=') {\n // equality operator\n return type.kind === 'boolean' ||\n type.kind === 'string' ||\n type.kind === 'number' ||\n type.kind === 'null' ||\n type.kind === 'value';\n } else {\n // ordering operator\n return type.kind === 'string' ||\n type.kind === 'number' ||\n type.kind === 'value';\n }\n}\n\nfunction eq(ctx: EvaluationContext, a: any, b: any): boolean { return a === b; }\nfunction neq(ctx: EvaluationContext, a: any, b: any): boolean { return a !== b; }\nfunction lt(ctx: EvaluationContext, a: any, b: any): boolean { return a < b; }\nfunction gt(ctx: EvaluationContext, a: any, b: any): boolean { return a > b; }\nfunction lteq(ctx: EvaluationContext, a: any, b: any): boolean { return a <= b; }\nfunction gteq(ctx: EvaluationContext, a: any, b: any): boolean { return a >= b; }\n\nfunction eqCollate(ctx: EvaluationContext, a: any, b: any, c: any): boolean { return c.compare(a, b) === 0; }\nfunction neqCollate(ctx: EvaluationContext, a: any, b: any, c: any): boolean { return !eqCollate(ctx, a, b, c); }\nfunction ltCollate(ctx: EvaluationContext, a: any, b: any, c: any): boolean { return c.compare(a, b) < 0; }\nfunction gtCollate(ctx: EvaluationContext, a: any, b: any, c: any): boolean { return c.compare(a, b) > 0; }\nfunction lteqCollate(ctx: EvaluationContext, a: any, b: any, c: any): boolean { return c.compare(a, b) <= 0; }\nfunction gteqCollate(ctx: EvaluationContext, a: any, b: any, c: any): boolean { return c.compare(a, b) >= 0; }\n\n/**\n * Special form for comparison operators, implementing the signatures:\n * - (T, T, ?Collator) => boolean\n * - (T, value, ?Collator) => boolean\n * - (value, T, ?Collator) => boolean\n *\n * For inequalities, T must be either value, string, or number. For ==/!=, it\n * can also be boolean or null.\n *\n * Equality semantics are equivalent to Javascript's strict equality (===/!==)\n * -- i.e., when the arguments' types don't match, == evaluates to false, != to\n * true.\n *\n * When types don't match in an ordering comparison, a runtime error is thrown.\n *\n * @private\n */\nfunction makeComparison(op: ComparisonOperator, compareBasic: (EvaluationContext, any, any) => boolean, compareWithCollator: (EvaluationContext, any, any, any) => boolean): ExpressionRegistration {\n const isOrderComparison = op !== '==' && op !== '!=';\n\n return class Comparison implements Expression {\n type: Type;\n lhs: Expression;\n rhs: Expression;\n collator: ?Expression;\n hasUntypedArgument: boolean;\n\n constructor(lhs: Expression, rhs: Expression, collator: ?Expression) {\n this.type = BooleanType;\n this.lhs = lhs;\n this.rhs = rhs;\n this.collator = collator;\n this.hasUntypedArgument = lhs.type.kind === 'value' || rhs.type.kind === 'value';\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n if (args.length !== 3 && args.length !== 4)\n return context.error(`Expected two or three arguments.`);\n\n const op: ComparisonOperator = (args[0]: any);\n\n let lhs = context.parse(args[1], 1, ValueType);\n if (!lhs) return null;\n if (!isComparableType(op, lhs.type)) {\n return context.concat(1).error(`\"${op}\" comparisons are not supported for type '${toString(lhs.type)}'.`);\n }\n let rhs = context.parse(args[2], 2, ValueType);\n if (!rhs) return null;\n if (!isComparableType(op, rhs.type)) {\n return context.concat(2).error(`\"${op}\" comparisons are not supported for type '${toString(rhs.type)}'.`);\n }\n\n if (\n lhs.type.kind !== rhs.type.kind &&\n lhs.type.kind !== 'value' &&\n rhs.type.kind !== 'value'\n ) {\n return context.error(`Cannot compare types '${toString(lhs.type)}' and '${toString(rhs.type)}'.`);\n }\n\n if (isOrderComparison) {\n // typing rules specific to less/greater than operators\n if (lhs.type.kind === 'value' && rhs.type.kind !== 'value') {\n // (value, T)\n lhs = new Assertion(rhs.type, [lhs]);\n } else if (lhs.type.kind !== 'value' && rhs.type.kind === 'value') {\n // (T, value)\n rhs = new Assertion(lhs.type, [rhs]);\n }\n }\n\n let collator = null;\n if (args.length === 4) {\n if (\n lhs.type.kind !== 'string' &&\n rhs.type.kind !== 'string' &&\n lhs.type.kind !== 'value' &&\n rhs.type.kind !== 'value'\n ) {\n return context.error(`Cannot use collator to compare non-string types.`);\n }\n collator = context.parse(args[3], 3, CollatorType);\n if (!collator) return null;\n }\n\n return new Comparison(lhs, rhs, collator);\n }\n\n evaluate(ctx: EvaluationContext): boolean {\n const lhs = this.lhs.evaluate(ctx);\n const rhs = this.rhs.evaluate(ctx);\n\n if (isOrderComparison && this.hasUntypedArgument) {\n const lt = typeOf(lhs);\n const rt = typeOf(rhs);\n // check that type is string or number, and equal\n if (lt.kind !== rt.kind || !(lt.kind === 'string' || lt.kind === 'number')) {\n throw new RuntimeError(`Expected arguments for \"${op}\" to be (string, string) or (number, number), but found (${lt.kind}, ${rt.kind}) instead.`);\n }\n }\n\n if (this.collator && !isOrderComparison && this.hasUntypedArgument) {\n const lt = typeOf(lhs);\n const rt = typeOf(rhs);\n if (lt.kind !== 'string' || rt.kind !== 'string') {\n return compareBasic(ctx, lhs, rhs);\n }\n }\n\n return this.collator ?\n compareWithCollator(ctx, lhs, rhs, this.collator.evaluate(ctx)) :\n compareBasic(ctx, lhs, rhs);\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.lhs);\n fn(this.rhs);\n if (this.collator) {\n fn(this.collator);\n }\n }\n\n outputDefined(): boolean {\n return true;\n }\n\n serialize(): SerializedExpression {\n const serialized = [op];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n };\n}\n\nexport const Equals: $Call = makeComparison('==', eq, eqCollate);\nexport const NotEquals: $Call = makeComparison('<', lt, ltCollate);\nexport const GreaterThan: $Call', typeof gt, typeof gtCollate> = makeComparison('>', gt, gtCollate);\nexport const LessThanOrEqual: $Call=', typeof gteq, typeof gteqCollate> = makeComparison('>=', gteq, gteqCollate);\n","// @flow\n\nimport {StringType, NumberType} from '../types.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type {Type} from '../types.js';\n\ndeclare var Intl: {\n NumberFormat: Class\n};\n\ndeclare class Intl$NumberFormat {\n constructor (\n locales?: string | string[],\n options?: NumberFormatOptions\n ): Intl$NumberFormat;\n\n static (\n locales?: string | string[],\n options?: NumberFormatOptions\n ): Intl$NumberFormat;\n\n format(a: number): string;\n\n resolvedOptions(): any;\n}\n\ntype NumberFormatOptions = {\n style?: 'decimal' | 'currency' | 'percent' | 'unit';\n currency?: null | string;\n unit?: null | string;\n minimumFractionDigits?: null | string;\n maximumFractionDigits?: null | string;\n};\n\nexport default class NumberFormat implements Expression {\n type: Type;\n number: Expression;\n locale: Expression | null; // BCP 47 language tag\n currency: Expression | null; // ISO 4217 currency code, required if style=currency\n unit: Expression | null; // Simple units sanctioned for use in ECMAScript, required if style=unit. https://tc39.es/proposal-unified-intl-numberformat/section6/locales-currencies-tz_proposed_out.html#sec-issanctionedsimpleunitidentifier\n minFractionDigits: Expression | null; // Default 0\n maxFractionDigits: Expression | null; // Default 3\n\n constructor(number: Expression,\n locale: Expression | null,\n currency: Expression | null,\n unit: Expression | null,\n minFractionDigits: Expression | null,\n maxFractionDigits: Expression | null) {\n this.type = StringType;\n this.number = number;\n this.locale = locale;\n this.currency = currency;\n this.unit = unit;\n this.minFractionDigits = minFractionDigits;\n this.maxFractionDigits = maxFractionDigits;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n if (args.length !== 3)\n return context.error(`Expected two arguments.`);\n\n const number = context.parse(args[1], 1, NumberType);\n if (!number) return null;\n\n const options = (args[2]: any);\n if (typeof options !== \"object\" || Array.isArray(options))\n return context.error(`NumberFormat options argument must be an object.`);\n\n let locale = null;\n if (options['locale']) {\n locale = context.parse(options['locale'], 1, StringType);\n if (!locale) return null;\n }\n\n let currency = null;\n if (options['currency']) {\n currency = context.parse(options['currency'], 1, StringType);\n if (!currency) return null;\n }\n\n let unit = null;\n if (options['unit']) {\n unit = context.parse(options['unit'], 1, StringType);\n if (!unit) return null;\n }\n\n let minFractionDigits = null;\n if (options['min-fraction-digits']) {\n minFractionDigits = context.parse(options['min-fraction-digits'], 1, NumberType);\n if (!minFractionDigits) return null;\n }\n\n let maxFractionDigits = null;\n if (options['max-fraction-digits']) {\n maxFractionDigits = context.parse(options['max-fraction-digits'], 1, NumberType);\n if (!maxFractionDigits) return null;\n }\n\n return new NumberFormat(number, locale, currency, unit, minFractionDigits, maxFractionDigits);\n }\n\n evaluate(ctx: EvaluationContext): string {\n return new Intl.NumberFormat(this.locale ? this.locale.evaluate(ctx) : [],\n {\n style:\n (this.currency && \"currency\") ||\n (this.unit && \"unit\") ||\n \"decimal\",\n currency: this.currency ? this.currency.evaluate(ctx) : undefined,\n unit: this.unit ? this.unit.evaluate(ctx) : undefined,\n minimumFractionDigits: this.minFractionDigits ? this.minFractionDigits.evaluate(ctx) : undefined,\n maximumFractionDigits: this.maxFractionDigits ? this.maxFractionDigits.evaluate(ctx) : undefined,\n }).format(this.number.evaluate(ctx));\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.number);\n if (this.locale) {\n fn(this.locale);\n }\n if (this.currency) {\n fn(this.currency);\n }\n if (this.unit) {\n fn(this.unit);\n }\n if (this.minFractionDigits) {\n fn(this.minFractionDigits);\n }\n if (this.maxFractionDigits) {\n fn(this.maxFractionDigits);\n }\n }\n\n outputDefined(): boolean {\n return false;\n }\n\n serialize(): SerializedExpression {\n const options = {};\n if (this.locale) {\n options['locale'] = this.locale.serialize();\n }\n if (this.currency) {\n options['currency'] = this.currency.serialize();\n }\n if (this.unit) {\n options['unit'] = this.unit.serialize();\n }\n if (this.minFractionDigits) {\n options['min-fraction-digits'] = this.minFractionDigits.serialize();\n }\n if (this.maxFractionDigits) {\n options['max-fraction-digits'] = this.maxFractionDigits.serialize();\n }\n return [\"number-format\", this.number.serialize(), options];\n }\n}\n","// @flow\n\nimport {NumberType, toString} from '../types.js';\n\nimport {typeOf} from '../values.js';\nimport RuntimeError from '../runtime_error.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nclass Length implements Expression {\n type: Type;\n input: Expression;\n\n constructor(input: Expression) {\n this.type = NumberType;\n this.input = input;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Length {\n if (args.length !== 2)\n return context.error(`Expected 1 argument, but found ${args.length - 1} instead.`);\n\n const input = context.parse(args[1], 1);\n if (!input) return null;\n\n if (input.type.kind !== 'array' && input.type.kind !== 'string' && input.type.kind !== 'value')\n return context.error(`Expected argument of type string or array, but found ${toString(input.type)} instead.`);\n\n return new Length(input);\n }\n\n evaluate(ctx: EvaluationContext): any | number {\n const input = this.input.evaluate(ctx);\n if (typeof input === 'string') {\n return input.length;\n } else if (Array.isArray(input)) {\n return input.length;\n } else {\n throw new RuntimeError(`Expected value to be of type string or array, but found ${toString(typeOf(input))} instead.`);\n }\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.input);\n }\n\n outputDefined(): boolean {\n return false;\n }\n\n serialize(): SerializedExpression {\n const serialized = [\"length\"];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n}\n\nexport default Length;\n","// @flow\n\nimport {\n type Type,\n NumberType,\n StringType,\n BooleanType,\n ColorType,\n ObjectType,\n ValueType,\n ErrorType,\n CollatorType,\n array,\n toString as typeToString\n} from '../types.js';\n\nimport {typeOf, Color, validateRGBA, toString as valueToString} from '../values.js';\nimport CompoundExpression from '../compound_expression.js';\nimport RuntimeError from '../runtime_error.js';\nimport Let from './let.js';\nimport Var from './var.js';\nimport Literal from './literal.js';\nimport Assertion from './assertion.js';\nimport Coercion from './coercion.js';\nimport At from './at.js';\nimport In from './in.js';\nimport IndexOf from './index_of.js';\nimport Match from './match.js';\nimport Case from './case.js';\nimport Slice from './slice.js';\nimport Step from './step.js';\nimport Interpolate from './interpolate.js';\nimport Coalesce from './coalesce.js';\nimport {\n Equals,\n NotEquals,\n LessThan,\n GreaterThan,\n LessThanOrEqual,\n GreaterThanOrEqual\n} from './comparison.js';\nimport CollatorExpression from './collator.js';\nimport NumberFormat from './number_format.js';\nimport FormatExpression from './format.js';\nimport ImageExpression from './image.js';\nimport Length from './length.js';\nimport Within from './within.js';\n\nimport type {Varargs} from '../compound_expression.js';\nimport type {ExpressionRegistry} from '../expression.js';\n\nconst expressions: ExpressionRegistry = {\n // special forms\n '==': Equals,\n '!=': NotEquals,\n '>': GreaterThan,\n '<': LessThan,\n '>=': GreaterThanOrEqual,\n '<=': LessThanOrEqual,\n 'array': Assertion,\n 'at': At,\n 'boolean': Assertion,\n 'case': Case,\n 'coalesce': Coalesce,\n 'collator': CollatorExpression,\n 'format': FormatExpression,\n 'image': ImageExpression,\n 'in': In,\n 'index-of': IndexOf,\n 'interpolate': Interpolate,\n 'interpolate-hcl': Interpolate,\n 'interpolate-lab': Interpolate,\n 'length': Length,\n 'let': Let,\n 'literal': Literal,\n 'match': Match,\n 'number': Assertion,\n 'number-format': NumberFormat,\n 'object': Assertion,\n 'slice': Slice,\n 'step': Step,\n 'string': Assertion,\n 'to-boolean': Coercion,\n 'to-color': Coercion,\n 'to-number': Coercion,\n 'to-string': Coercion,\n 'var': Var,\n 'within': Within\n};\n\nfunction rgba(ctx, [r, g, b, a]) {\n r = r.evaluate(ctx);\n g = g.evaluate(ctx);\n b = b.evaluate(ctx);\n const alpha = a ? a.evaluate(ctx) : 1;\n const error = validateRGBA(r, g, b, alpha);\n if (error) throw new RuntimeError(error);\n return new Color(r / 255 * alpha, g / 255 * alpha, b / 255 * alpha, alpha);\n}\n\nfunction has(key, obj) {\n return key in obj;\n}\n\nfunction get(key, obj) {\n const v = obj[key];\n return typeof v === 'undefined' ? null : v;\n}\n\nfunction binarySearch(v, a, i, j) {\n while (i <= j) {\n const m = (i + j) >> 1;\n if (a[m] === v)\n return true;\n if (a[m] > v)\n j = m - 1;\n else\n i = m + 1;\n }\n return false;\n}\n\nfunction varargs(type: Type): Varargs {\n return {type};\n}\n\nCompoundExpression.register(expressions, {\n 'error': [\n ErrorType,\n [StringType],\n (ctx, [v]) => { throw new RuntimeError(v.evaluate(ctx)); }\n ],\n 'typeof': [\n StringType,\n [ValueType],\n (ctx, [v]) => typeToString(typeOf(v.evaluate(ctx)))\n ],\n 'to-rgba': [\n array(NumberType, 4),\n [ColorType],\n (ctx, [v]) => {\n return v.evaluate(ctx).toArray();\n }\n ],\n 'rgb': [\n ColorType,\n [NumberType, NumberType, NumberType],\n rgba\n ],\n 'rgba': [\n ColorType,\n [NumberType, NumberType, NumberType, NumberType],\n rgba\n ],\n 'has': {\n type: BooleanType,\n overloads: [\n [\n [StringType],\n (ctx, [key]) => has(key.evaluate(ctx), ctx.properties())\n ], [\n [StringType, ObjectType],\n (ctx, [key, obj]) => has(key.evaluate(ctx), obj.evaluate(ctx))\n ]\n ]\n },\n 'get': {\n type: ValueType,\n overloads: [\n [\n [StringType],\n (ctx, [key]) => get(key.evaluate(ctx), ctx.properties())\n ], [\n [StringType, ObjectType],\n (ctx, [key, obj]) => get(key.evaluate(ctx), obj.evaluate(ctx))\n ]\n ]\n },\n 'feature-state': [\n ValueType,\n [StringType],\n (ctx, [key]) => get(key.evaluate(ctx), ctx.featureState || {})\n ],\n 'properties': [\n ObjectType,\n [],\n (ctx) => ctx.properties()\n ],\n 'geometry-type': [\n StringType,\n [],\n (ctx) => ctx.geometryType()\n ],\n 'id': [\n ValueType,\n [],\n (ctx) => ctx.id()\n ],\n 'zoom': [\n NumberType,\n [],\n (ctx) => ctx.globals.zoom\n ],\n 'pitch': [\n NumberType,\n [],\n (ctx) => ctx.globals.pitch || 0\n ],\n 'distance-from-center': [\n NumberType,\n [],\n (ctx) => ctx.distanceFromCenter()\n ],\n 'heatmap-density': [\n NumberType,\n [],\n (ctx) => ctx.globals.heatmapDensity || 0\n ],\n 'line-progress': [\n NumberType,\n [],\n (ctx) => ctx.globals.lineProgress || 0\n ],\n 'sky-radial-progress': [\n NumberType,\n [],\n (ctx) => ctx.globals.skyRadialProgress || 0\n ],\n 'accumulated': [\n ValueType,\n [],\n (ctx) => ctx.globals.accumulated === undefined ? null : ctx.globals.accumulated\n ],\n '+': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => {\n let result = 0;\n for (const arg of args) {\n result += arg.evaluate(ctx);\n }\n return result;\n }\n ],\n '*': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => {\n let result = 1;\n for (const arg of args) {\n result *= arg.evaluate(ctx);\n }\n return result;\n }\n ],\n '-': {\n type: NumberType,\n overloads: [\n [\n [NumberType, NumberType],\n (ctx, [a, b]) => a.evaluate(ctx) - b.evaluate(ctx)\n ], [\n [NumberType],\n (ctx, [a]) => -a.evaluate(ctx)\n ]\n ]\n },\n '/': [\n NumberType,\n [NumberType, NumberType],\n (ctx, [a, b]) => a.evaluate(ctx) / b.evaluate(ctx)\n ],\n '%': [\n NumberType,\n [NumberType, NumberType],\n (ctx, [a, b]) => a.evaluate(ctx) % b.evaluate(ctx)\n ],\n 'ln2': [\n NumberType,\n [],\n () => Math.LN2\n ],\n 'pi': [\n NumberType,\n [],\n () => Math.PI\n ],\n 'e': [\n NumberType,\n [],\n () => Math.E\n ],\n '^': [\n NumberType,\n [NumberType, NumberType],\n (ctx, [b, e]) => Math.pow(b.evaluate(ctx), e.evaluate(ctx))\n ],\n 'sqrt': [\n NumberType,\n [NumberType],\n (ctx, [x]) => Math.sqrt(x.evaluate(ctx))\n ],\n 'log10': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.log(n.evaluate(ctx)) / Math.LN10\n ],\n 'ln': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.log(n.evaluate(ctx))\n ],\n 'log2': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.log(n.evaluate(ctx)) / Math.LN2\n ],\n 'sin': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.sin(n.evaluate(ctx))\n ],\n 'cos': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.cos(n.evaluate(ctx))\n ],\n 'tan': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.tan(n.evaluate(ctx))\n ],\n 'asin': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.asin(n.evaluate(ctx))\n ],\n 'acos': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.acos(n.evaluate(ctx))\n ],\n 'atan': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.atan(n.evaluate(ctx))\n ],\n 'min': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => Math.min(...args.map(arg => arg.evaluate(ctx)))\n ],\n 'max': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => Math.max(...args.map(arg => arg.evaluate(ctx)))\n ],\n 'abs': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.abs(n.evaluate(ctx))\n ],\n 'round': [\n NumberType,\n [NumberType],\n (ctx, [n]) => {\n const v = n.evaluate(ctx);\n // Javascript's Math.round() rounds towards +Infinity for halfway\n // values, even when they're negative. It's more common to round\n // away from 0 (e.g., this is what python and C++ do)\n return v < 0 ? -Math.round(-v) : Math.round(v);\n }\n ],\n 'floor': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.floor(n.evaluate(ctx))\n ],\n 'ceil': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.ceil(n.evaluate(ctx))\n ],\n 'filter-==': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => ctx.properties()[(k: any).value] === (v: any).value\n ],\n 'filter-id-==': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => ctx.id() === (v: any).value\n ],\n 'filter-type-==': [\n BooleanType,\n [StringType],\n (ctx, [v]) => ctx.geometryType() === (v: any).value\n ],\n 'filter-<': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[(k: any).value];\n const b = (v: any).value;\n return typeof a === typeof b && a < b;\n }\n ],\n 'filter-id-<': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = (v: any).value;\n return typeof a === typeof b && a < b;\n }\n ],\n 'filter->': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[(k: any).value];\n const b = (v: any).value;\n return typeof a === typeof b && a > b;\n }\n ],\n 'filter-id->': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = (v: any).value;\n return typeof a === typeof b && a > b;\n }\n ],\n 'filter-<=': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[(k: any).value];\n const b = (v: any).value;\n return typeof a === typeof b && a <= b;\n }\n ],\n 'filter-id-<=': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = (v: any).value;\n return typeof a === typeof b && a <= b;\n }\n ],\n 'filter->=': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[(k: any).value];\n const b = (v: any).value;\n return typeof a === typeof b && a >= b;\n }\n ],\n 'filter-id->=': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = (v: any).value;\n return typeof a === typeof b && a >= b;\n }\n ],\n 'filter-has': [\n BooleanType,\n [ValueType],\n (ctx, [k]) => (k: any).value in ctx.properties()\n ],\n 'filter-has-id': [\n BooleanType,\n [],\n (ctx) => (ctx.id() !== null && ctx.id() !== undefined)\n ],\n 'filter-type-in': [\n BooleanType,\n [array(StringType)],\n (ctx, [v]) => (v: any).value.indexOf(ctx.geometryType()) >= 0\n ],\n 'filter-id-in': [\n BooleanType,\n [array(ValueType)],\n (ctx, [v]) => (v: any).value.indexOf(ctx.id()) >= 0\n ],\n 'filter-in-small': [\n BooleanType,\n [StringType, array(ValueType)],\n // assumes v is an array literal\n (ctx, [k, v]) => (v: any).value.indexOf(ctx.properties()[(k: any).value]) >= 0\n ],\n 'filter-in-large': [\n BooleanType,\n [StringType, array(ValueType)],\n // assumes v is a array literal with values sorted in ascending order and of a single type\n (ctx, [k, v]) => binarySearch(ctx.properties()[(k: any).value], (v: any).value, 0, (v: any).value.length - 1)\n ],\n 'all': {\n type: BooleanType,\n overloads: [\n [\n [BooleanType, BooleanType],\n (ctx, [a, b]) => a.evaluate(ctx) && b.evaluate(ctx)\n ],\n [\n varargs(BooleanType),\n (ctx, args) => {\n for (const arg of args) {\n if (!arg.evaluate(ctx))\n return false;\n }\n return true;\n }\n ]\n ]\n },\n 'any': {\n type: BooleanType,\n overloads: [\n [\n [BooleanType, BooleanType],\n (ctx, [a, b]) => a.evaluate(ctx) || b.evaluate(ctx)\n ],\n [\n varargs(BooleanType),\n (ctx, args) => {\n for (const arg of args) {\n if (arg.evaluate(ctx))\n return true;\n }\n return false;\n }\n ]\n ]\n },\n '!': [\n BooleanType,\n [BooleanType],\n (ctx, [b]) => !b.evaluate(ctx)\n ],\n 'is-supported-script': [\n BooleanType,\n [StringType],\n // At parse time this will always return true, so we need to exclude this expression with isGlobalPropertyConstant\n (ctx, [s]) => {\n const isSupportedScript = ctx.globals && ctx.globals.isSupportedScript;\n if (isSupportedScript) {\n return isSupportedScript(s.evaluate(ctx));\n }\n return true;\n }\n ],\n 'upcase': [\n StringType,\n [StringType],\n (ctx, [s]) => s.evaluate(ctx).toUpperCase()\n ],\n 'downcase': [\n StringType,\n [StringType],\n (ctx, [s]) => s.evaluate(ctx).toLowerCase()\n ],\n 'concat': [\n StringType,\n varargs(ValueType),\n (ctx, args) => args.map(arg => valueToString(arg.evaluate(ctx))).join('')\n ],\n 'resolved-locale': [\n StringType,\n [CollatorType],\n (ctx, [collator]) => collator.evaluate(ctx).resolvedLocale()\n ]\n});\n\nexport default expressions;\n","// @flow\n\n/**\n * A type used for returning and propagating errors. The first element of the union\n * represents success and contains a value, and the second represents an error and\n * contains an error value.\n * @private\n */\nexport type Result =\n | {| result: 'success', value: T |}\n | {| result: 'error', value: E |};\n\nexport function success(value: T): Result {\n return {result: 'success', value};\n}\n\nexport function error(value: E): Result {\n return {result: 'error', value};\n}\n","// @flow\n\nimport type {StylePropertySpecification} from '../style-spec.js';\n\nexport function supportsPropertyExpression(spec: StylePropertySpecification): boolean {\n return spec['property-type'] === 'data-driven';\n}\n\nexport function supportsZoomExpression(spec: StylePropertySpecification): boolean {\n return !!spec.expression && spec.expression.parameters.indexOf('zoom') > -1;\n}\n\nexport function supportsInterpolation(spec: StylePropertySpecification): boolean {\n return !!spec.expression && spec.expression.interpolated;\n}\n","\nimport * as colorSpaces from '../util/color_spaces.js';\nimport Color from '../util/color.js';\nimport extend from '../util/extend.js';\nimport getType from '../util/get_type.js';\nimport * as interpolate from '../util/interpolate.js';\nimport Interpolate from '../expression/definitions/interpolate.js';\nimport Formatted from '../expression/types/formatted.js';\nimport ResolvedImage from '../expression/types/resolved_image.js';\nimport {supportsInterpolation} from '../util/properties.js';\nimport {findStopLessThanOrEqualTo} from '../expression/stops.js';\n\nexport function isFunction(value) {\n return typeof value === 'object' && value !== null && !Array.isArray(value);\n}\n\nfunction identityFunction(x) {\n return x;\n}\n\nexport function createFunction(parameters, propertySpec) {\n const isColor = propertySpec.type === 'color';\n const zoomAndFeatureDependent = parameters.stops && typeof parameters.stops[0][0] === 'object';\n const featureDependent = zoomAndFeatureDependent || parameters.property !== undefined;\n const zoomDependent = zoomAndFeatureDependent || !featureDependent;\n const type = parameters.type || (supportsInterpolation(propertySpec) ? 'exponential' : 'interval');\n\n if (isColor) {\n parameters = extend({}, parameters);\n\n if (parameters.stops) {\n parameters.stops = parameters.stops.map((stop) => {\n return [stop[0], Color.parse(stop[1])];\n });\n }\n\n if (parameters.default) {\n parameters.default = Color.parse(parameters.default);\n } else {\n parameters.default = Color.parse(propertySpec.default);\n }\n }\n\n if (parameters.colorSpace && parameters.colorSpace !== 'rgb' && !colorSpaces[parameters.colorSpace]) { // eslint-disable-line import/namespace\n throw new Error(`Unknown color space: ${parameters.colorSpace}`);\n }\n\n let innerFun;\n let hashedStops;\n let categoricalKeyType;\n if (type === 'exponential') {\n innerFun = evaluateExponentialFunction;\n } else if (type === 'interval') {\n innerFun = evaluateIntervalFunction;\n } else if (type === 'categorical') {\n innerFun = evaluateCategoricalFunction;\n\n // For categorical functions, generate an Object as a hashmap of the stops for fast searching\n hashedStops = Object.create(null);\n for (const stop of parameters.stops) {\n hashedStops[stop[0]] = stop[1];\n }\n\n // Infer key type based on first stop key-- used to encforce strict type checking later\n categoricalKeyType = typeof parameters.stops[0][0];\n\n } else if (type === 'identity') {\n innerFun = evaluateIdentityFunction;\n } else {\n throw new Error(`Unknown function type \"${type}\"`);\n }\n\n if (zoomAndFeatureDependent) {\n const featureFunctions = {};\n const zoomStops = [];\n for (let s = 0; s < parameters.stops.length; s++) {\n const stop = parameters.stops[s];\n const zoom = stop[0].zoom;\n if (featureFunctions[zoom] === undefined) {\n featureFunctions[zoom] = {\n zoom,\n type: parameters.type,\n property: parameters.property,\n default: parameters.default,\n stops: []\n };\n zoomStops.push(zoom);\n }\n featureFunctions[zoom].stops.push([stop[0].value, stop[1]]);\n }\n\n const featureFunctionStops = [];\n for (const z of zoomStops) {\n featureFunctionStops.push([featureFunctions[z].zoom, createFunction(featureFunctions[z], propertySpec)]);\n }\n\n const interpolationType = {name: 'linear'};\n return {\n kind: 'composite',\n interpolationType,\n interpolationFactor: Interpolate.interpolationFactor.bind(undefined, interpolationType),\n zoomStops: featureFunctionStops.map(s => s[0]),\n evaluate({zoom}, properties) {\n return evaluateExponentialFunction({\n stops: featureFunctionStops,\n base: parameters.base\n }, propertySpec, zoom).evaluate(zoom, properties);\n }\n };\n } else if (zoomDependent) {\n const interpolationType = type === 'exponential' ?\n {name: 'exponential', base: parameters.base !== undefined ? parameters.base : 1} : null;\n return {\n kind: 'camera',\n interpolationType,\n interpolationFactor: Interpolate.interpolationFactor.bind(undefined, interpolationType),\n zoomStops: parameters.stops.map(s => s[0]),\n evaluate: ({zoom}) => innerFun(parameters, propertySpec, zoom, hashedStops, categoricalKeyType)\n };\n } else {\n return {\n kind: 'source',\n evaluate(_, feature) {\n const value = feature && feature.properties ? feature.properties[parameters.property] : undefined;\n if (value === undefined) {\n return coalesce(parameters.default, propertySpec.default);\n }\n return innerFun(parameters, propertySpec, value, hashedStops, categoricalKeyType);\n }\n };\n }\n}\n\nfunction coalesce(a, b, c) {\n if (a !== undefined) return a;\n if (b !== undefined) return b;\n if (c !== undefined) return c;\n}\n\nfunction evaluateCategoricalFunction(parameters, propertySpec, input, hashedStops, keyType) {\n const evaluated = typeof input === keyType ? hashedStops[input] : undefined; // Enforce strict typing on input\n return coalesce(evaluated, parameters.default, propertySpec.default);\n}\n\nfunction evaluateIntervalFunction(parameters, propertySpec, input) {\n // Edge cases\n if (getType(input) !== 'number') return coalesce(parameters.default, propertySpec.default);\n const n = parameters.stops.length;\n if (n === 1) return parameters.stops[0][1];\n if (input <= parameters.stops[0][0]) return parameters.stops[0][1];\n if (input >= parameters.stops[n - 1][0]) return parameters.stops[n - 1][1];\n\n const index = findStopLessThanOrEqualTo(parameters.stops.map((stop) => stop[0]), input);\n\n return parameters.stops[index][1];\n}\n\nfunction evaluateExponentialFunction(parameters, propertySpec, input) {\n const base = parameters.base !== undefined ? parameters.base : 1;\n\n // Edge cases\n if (getType(input) !== 'number') return coalesce(parameters.default, propertySpec.default);\n const n = parameters.stops.length;\n if (n === 1) return parameters.stops[0][1];\n if (input <= parameters.stops[0][0]) return parameters.stops[0][1];\n if (input >= parameters.stops[n - 1][0]) return parameters.stops[n - 1][1];\n\n const index = findStopLessThanOrEqualTo(parameters.stops.map((stop) => stop[0]), input);\n const t = interpolationFactor(\n input, base,\n parameters.stops[index][0],\n parameters.stops[index + 1][0]);\n\n const outputLower = parameters.stops[index][1];\n const outputUpper = parameters.stops[index + 1][1];\n let interp = interpolate[propertySpec.type] || identityFunction; // eslint-disable-line import/namespace\n\n if (parameters.colorSpace && parameters.colorSpace !== 'rgb') {\n const colorspace = colorSpaces[parameters.colorSpace]; // eslint-disable-line import/namespace\n interp = (a, b) => colorspace.reverse(colorspace.interpolate(colorspace.forward(a), colorspace.forward(b), t));\n }\n\n if (typeof outputLower.evaluate === 'function') {\n return {\n evaluate(...args) {\n const evaluatedLower = outputLower.evaluate.apply(undefined, args);\n const evaluatedUpper = outputUpper.evaluate.apply(undefined, args);\n // Special case for fill-outline-color, which has no spec default.\n if (evaluatedLower === undefined || evaluatedUpper === undefined) {\n return undefined;\n }\n return interp(evaluatedLower, evaluatedUpper, t);\n }\n };\n }\n\n return interp(outputLower, outputUpper, t);\n}\n\nfunction evaluateIdentityFunction(parameters, propertySpec, input) {\n if (propertySpec.type === 'color') {\n input = Color.parse(input);\n } else if (propertySpec.type === 'formatted') {\n input = Formatted.fromString(input.toString());\n } else if (propertySpec.type === 'resolvedImage') {\n input = ResolvedImage.fromString(input.toString());\n } else if (getType(input) !== propertySpec.type && (propertySpec.type !== 'enum' || !propertySpec.values[input])) {\n input = undefined;\n }\n return coalesce(input, parameters.default, propertySpec.default);\n}\n\n/**\n * Returns a ratio that can be used to interpolate between exponential function\n * stops.\n *\n * How it works:\n * Two consecutive stop values define a (scaled and shifted) exponential\n * function `f(x) = a * base^x + b`, where `base` is the user-specified base,\n * and `a` and `b` are constants affording sufficient degrees of freedom to fit\n * the function to the given stops.\n *\n * Here's a bit of algebra that lets us compute `f(x)` directly from the stop\n * values without explicitly solving for `a` and `b`:\n *\n * First stop value: `f(x0) = y0 = a * base^x0 + b`\n * Second stop value: `f(x1) = y1 = a * base^x1 + b`\n * => `y1 - y0 = a(base^x1 - base^x0)`\n * => `a = (y1 - y0)/(base^x1 - base^x0)`\n *\n * Desired value: `f(x) = y = a * base^x + b`\n * => `f(x) = y0 + a * (base^x - base^x0)`\n *\n * From the above, we can replace the `a` in `a * (base^x - base^x0)` and do a\n * little algebra:\n * ```\n * a * (base^x - base^x0) = (y1 - y0)/(base^x1 - base^x0) * (base^x - base^x0)\n * = (y1 - y0) * (base^x - base^x0) / (base^x1 - base^x0)\n * ```\n *\n * If we let `(base^x - base^x0) / (base^x1 base^x0)`, then we have\n * `f(x) = y0 + (y1 - y0) * ratio`. In other words, `ratio` may be treated as\n * an interpolation factor between the two stops' output values.\n *\n * (Note: a slightly different form for `ratio`,\n * `(base^(x-x0) - 1) / (base^(x1-x0) - 1) `, is equivalent, but requires fewer\n * expensive `Math.pow()` operations.)\n *\n * @private\n */\nfunction interpolationFactor(input, base, lowerValue, upperValue) {\n const difference = upperValue - lowerValue;\n const progress = input - lowerValue;\n\n if (difference === 0) {\n return 0;\n } else if (base === 1) {\n return progress / difference;\n } else {\n return (Math.pow(base, progress) - 1) / (Math.pow(base, difference) - 1);\n }\n}\n","// @flow\n\nimport assert from 'assert';\n\nimport extend from '../util/extend.js';\nimport ParsingError from './parsing_error.js';\nimport ParsingContext from './parsing_context.js';\nimport EvaluationContext from './evaluation_context.js';\nimport CompoundExpression from './compound_expression.js';\nimport Step from './definitions/step.js';\nimport Interpolate from './definitions/interpolate.js';\nimport Coalesce from './definitions/coalesce.js';\nimport Let from './definitions/let.js';\nimport definitions from './definitions/index.js';\nimport * as isConstant from './is_constant.js';\nimport RuntimeError from './runtime_error.js';\nimport {success, error} from '../util/result.js';\nimport {supportsPropertyExpression, supportsZoomExpression, supportsInterpolation} from '../util/properties.js';\n\nimport type {Type, EvaluationKind} from './types.js';\nimport type {Value} from './values.js';\nimport type {Expression} from './expression.js';\nimport type {StylePropertySpecification} from '../style-spec.js';\nimport type {Result} from '../util/result.js';\nimport type {InterpolationType} from './definitions/interpolate.js';\nimport type {PropertyValueSpecification} from '../types.js';\nimport type {FormattedSection} from './types/formatted.js';\nimport type Point from '@mapbox/point-geometry';\nimport type {CanonicalTileID} from '../../source/tile_id.js';\nimport type {FeatureDistanceData} from '../feature_filter/index.js';\n\nexport type Feature = {\n +type: 1 | 2 | 3 | 'Unknown' | 'Point' | 'LineString' | 'Polygon',\n +id?: number | null,\n +properties: {[_: string]: any},\n +patterns?: {[_: string]: string},\n +geometry?: Array>\n};\n\nexport type FeatureState = {[_: string]: any};\n\nexport type GlobalProperties = $ReadOnly<{\n zoom: number,\n pitch?: number,\n heatmapDensity?: number,\n lineProgress?: number,\n skyRadialProgress?: number,\n isSupportedScript?: (_: string) => boolean,\n accumulated?: Value\n}>;\n\nexport class StyleExpression {\n expression: Expression;\n\n _evaluator: EvaluationContext;\n _defaultValue: Value;\n _warningHistory: {[key: string]: boolean};\n _enumValues: ?{[_: string]: any};\n\n constructor(expression: Expression, propertySpec: ?StylePropertySpecification) {\n this.expression = expression;\n this._warningHistory = {};\n this._evaluator = new EvaluationContext();\n this._defaultValue = propertySpec ? getDefaultValue(propertySpec) : null;\n this._enumValues = propertySpec && propertySpec.type === 'enum' ? propertySpec.values : null;\n }\n\n evaluateWithoutErrorHandling(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection, featureTileCoord?: Point, featureDistanceData?: FeatureDistanceData): any {\n this._evaluator.globals = globals;\n this._evaluator.feature = feature;\n this._evaluator.featureState = featureState;\n this._evaluator.canonical = canonical || null;\n this._evaluator.availableImages = availableImages || null;\n this._evaluator.formattedSection = formattedSection;\n this._evaluator.featureTileCoord = featureTileCoord || null;\n this._evaluator.featureDistanceData = featureDistanceData || null;\n\n return this.expression.evaluate(this._evaluator);\n }\n\n evaluate(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection, featureTileCoord?: Point, featureDistanceData?: FeatureDistanceData): any {\n this._evaluator.globals = globals;\n this._evaluator.feature = feature || null;\n this._evaluator.featureState = featureState || null;\n this._evaluator.canonical = canonical || null;\n this._evaluator.availableImages = availableImages || null;\n this._evaluator.formattedSection = formattedSection || null;\n this._evaluator.featureTileCoord = featureTileCoord || null;\n this._evaluator.featureDistanceData = featureDistanceData || null;\n\n try {\n const val = this.expression.evaluate(this._evaluator);\n // eslint-disable-next-line no-self-compare\n if (val === null || val === undefined || (typeof val === 'number' && val !== val)) {\n return this._defaultValue;\n }\n if (this._enumValues && !(val in this._enumValues)) {\n throw new RuntimeError(`Expected value to be one of ${Object.keys(this._enumValues).map(v => JSON.stringify(v)).join(', ')}, but found ${JSON.stringify(val)} instead.`);\n }\n return val;\n } catch (e) {\n if (!this._warningHistory[e.message]) {\n this._warningHistory[e.message] = true;\n if (typeof console !== 'undefined') {\n console.warn(e.message);\n }\n }\n return this._defaultValue;\n }\n }\n}\n\nexport function isExpression(expression: mixed): boolean {\n return Array.isArray(expression) && expression.length > 0 &&\n typeof expression[0] === 'string' && expression[0] in definitions;\n}\n\n/**\n * Parse and typecheck the given style spec JSON expression. If\n * options.defaultValue is provided, then the resulting StyleExpression's\n * `evaluate()` method will handle errors by logging a warning (once per\n * message) and returning the default value. Otherwise, it will throw\n * evaluation errors.\n *\n * @private\n */\nexport function createExpression(expression: mixed, propertySpec: ?StylePropertySpecification): Result> {\n const parser = new ParsingContext(definitions, [], propertySpec ? getExpectedType(propertySpec) : undefined);\n\n // For string-valued properties, coerce to string at the top level rather than asserting.\n const parsed = parser.parse(expression, undefined, undefined, undefined,\n propertySpec && propertySpec.type === 'string' ? {typeAnnotation: 'coerce'} : undefined);\n\n if (!parsed) {\n assert(parser.errors.length > 0);\n return error(parser.errors);\n }\n\n return success(new StyleExpression(parsed, propertySpec));\n}\n\nexport class ZoomConstantExpression {\n kind: Kind;\n isStateDependent: boolean;\n _styleExpression: StyleExpression;\n\n constructor(kind: Kind, expression: StyleExpression) {\n this.kind = kind;\n this._styleExpression = expression;\n this.isStateDependent = kind !== ('constant': EvaluationKind) && !isConstant.isStateConstant(expression.expression);\n }\n\n evaluateWithoutErrorHandling(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection): any {\n return this._styleExpression.evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection);\n }\n\n evaluate(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection): any {\n return this._styleExpression.evaluate(globals, feature, featureState, canonical, availableImages, formattedSection);\n }\n}\n\nexport class ZoomDependentExpression {\n kind: Kind;\n zoomStops: Array;\n isStateDependent: boolean;\n\n _styleExpression: StyleExpression;\n interpolationType: ?InterpolationType;\n\n constructor(kind: Kind, expression: StyleExpression, zoomStops: Array, interpolationType?: InterpolationType) {\n this.kind = kind;\n this.zoomStops = zoomStops;\n this._styleExpression = expression;\n this.isStateDependent = kind !== ('camera': EvaluationKind) && !isConstant.isStateConstant(expression.expression);\n this.interpolationType = interpolationType;\n }\n\n evaluateWithoutErrorHandling(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection): any {\n return this._styleExpression.evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection);\n }\n\n evaluate(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection): any {\n return this._styleExpression.evaluate(globals, feature, featureState, canonical, availableImages, formattedSection);\n }\n\n interpolationFactor(input: number, lower: number, upper: number): number {\n if (this.interpolationType) {\n return Interpolate.interpolationFactor(this.interpolationType, input, lower, upper);\n } else {\n return 0;\n }\n }\n}\n\nexport type ConstantExpression = {\n kind: 'constant',\n +evaluate: (globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array) => any,\n}\n\nexport type SourceExpression = {\n kind: 'source',\n isStateDependent: boolean,\n +evaluate: (globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection) => any,\n};\n\nexport type CameraExpression = {\n kind: 'camera',\n +evaluate: (globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array) => any,\n +interpolationFactor: (input: number, lower: number, upper: number) => number,\n zoomStops: Array,\n interpolationType: ?InterpolationType\n};\n\nexport type CompositeExpression = {\n kind: 'composite',\n isStateDependent: boolean,\n +evaluate: (globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection) => any,\n +interpolationFactor: (input: number, lower: number, upper: number) => number,\n zoomStops: Array,\n interpolationType: ?InterpolationType\n};\n\nexport type StylePropertyExpression =\n | ConstantExpression\n | SourceExpression\n | CameraExpression\n | CompositeExpression;\n\nexport function createPropertyExpression(expression: mixed, propertySpec: StylePropertySpecification): Result> {\n expression = createExpression(expression, propertySpec);\n if (expression.result === 'error') {\n return expression;\n }\n\n const parsed = expression.value.expression;\n\n const isFeatureConstant = isConstant.isFeatureConstant(parsed);\n if (!isFeatureConstant && !supportsPropertyExpression(propertySpec)) {\n return error([new ParsingError('', 'data expressions not supported')]);\n }\n\n const isZoomConstant = isConstant.isGlobalPropertyConstant(parsed, ['zoom', 'pitch', 'distance-from-center']);\n if (!isZoomConstant && !supportsZoomExpression(propertySpec)) {\n return error([new ParsingError('', 'zoom expressions not supported')]);\n }\n\n const zoomCurve = findZoomCurve(parsed);\n if (!zoomCurve && !isZoomConstant) {\n return error([new ParsingError('', '\"zoom\" expression may only be used as input to a top-level \"step\" or \"interpolate\" expression.')]);\n } else if (zoomCurve instanceof ParsingError) {\n return error([zoomCurve]);\n } else if (zoomCurve instanceof Interpolate && !supportsInterpolation(propertySpec)) {\n return error([new ParsingError('', '\"interpolate\" expressions cannot be used with this property')]);\n }\n\n if (!zoomCurve) {\n return success(isFeatureConstant ?\n (new ZoomConstantExpression('constant', expression.value): ConstantExpression) :\n (new ZoomConstantExpression('source', expression.value): SourceExpression));\n }\n\n const interpolationType = zoomCurve instanceof Interpolate ? zoomCurve.interpolation : undefined;\n\n return success(isFeatureConstant ?\n (new ZoomDependentExpression('camera', expression.value, zoomCurve.labels, interpolationType): CameraExpression) :\n (new ZoomDependentExpression('composite', expression.value, zoomCurve.labels, interpolationType): CompositeExpression));\n}\n\nimport {isFunction, createFunction} from '../function/index.js';\nimport {Color} from './values.js';\n\n// serialization wrapper for old-style stop functions normalized to the\n// expression interface\nexport class StylePropertyFunction {\n _parameters: PropertyValueSpecification;\n _specification: StylePropertySpecification;\n\n kind: EvaluationKind;\n evaluate: (globals: GlobalProperties, feature?: Feature) => any;\n interpolationFactor: ?(input: number, lower: number, upper: number) => number;\n zoomStops: ?Array;\n\n constructor(parameters: PropertyValueSpecification, specification: StylePropertySpecification) {\n this._parameters = parameters;\n this._specification = specification;\n extend(this, createFunction(this._parameters, this._specification));\n }\n\n static deserialize(serialized: {_parameters: PropertyValueSpecification, _specification: StylePropertySpecification}): StylePropertyFunction {\n return new StylePropertyFunction(serialized._parameters, serialized._specification);\n }\n\n static serialize(input: StylePropertyFunction): {_parameters: PropertyValueSpecification, _specification: StylePropertySpecification} {\n return {\n _parameters: input._parameters,\n _specification: input._specification\n };\n }\n}\n\nexport function normalizePropertyExpression(value: PropertyValueSpecification, specification: StylePropertySpecification): StylePropertyExpression {\n if (isFunction(value)) {\n return (new StylePropertyFunction(value, specification): any);\n\n } else if (isExpression(value)) {\n const expression = createPropertyExpression(value, specification);\n if (expression.result === 'error') {\n // this should have been caught in validation\n throw new Error(expression.value.map(err => `${err.key}: ${err.message}`).join(', '));\n }\n return expression.value;\n\n } else {\n let constant: any = value;\n if (typeof value === 'string' && specification.type === 'color') {\n constant = Color.parse(value);\n }\n return {\n kind: 'constant',\n evaluate: () => constant\n };\n }\n}\n\n// Zoom-dependent expressions may only use [\"zoom\"] as the input to a top-level \"step\" or \"interpolate\"\n// expression (collectively referred to as a \"curve\"). The curve may be wrapped in one or more \"let\" or\n// \"coalesce\" expressions.\nfunction findZoomCurve(expression: Expression): Step | Interpolate | ParsingError | null {\n let result = null;\n if (expression instanceof Let) {\n result = findZoomCurve(expression.result);\n\n } else if (expression instanceof Coalesce) {\n for (const arg of expression.args) {\n result = findZoomCurve(arg);\n if (result) {\n break;\n }\n }\n\n } else if ((expression instanceof Step || expression instanceof Interpolate) &&\n expression.input instanceof CompoundExpression &&\n expression.input.name === 'zoom') {\n\n result = expression;\n }\n\n if (result instanceof ParsingError) {\n return result;\n }\n\n expression.eachChild((child) => {\n const childResult = findZoomCurve(child);\n if (childResult instanceof ParsingError) {\n result = childResult;\n } else if (!result && childResult) {\n result = new ParsingError('', '\"zoom\" expression may only be used as input to a top-level \"step\" or \"interpolate\" expression.');\n } else if (result && childResult && result !== childResult) {\n result = new ParsingError('', 'Only one zoom-based \"step\" or \"interpolate\" subexpression may be used in an expression.');\n }\n });\n\n return result;\n}\n\nimport {ColorType, StringType, NumberType, BooleanType, ValueType, FormattedType, ResolvedImageType, array} from './types.js';\n\nfunction getExpectedType(spec: StylePropertySpecification): Type {\n const types = {\n color: ColorType,\n string: StringType,\n number: NumberType,\n enum: StringType,\n boolean: BooleanType,\n formatted: FormattedType,\n resolvedImage: ResolvedImageType\n };\n\n if (spec.type === 'array') {\n return array(types[spec.value] || ValueType, spec.length);\n }\n\n return types[spec.type];\n}\n\nfunction getDefaultValue(spec: StylePropertySpecification): Value {\n if (spec.type === 'color' && (isFunction(spec.default) || Array.isArray(spec.default))) {\n // Special case for heatmap-color: it uses the 'default:' to define a\n // default color ramp, but createExpression expects a simple value to fall\n // back to in case of runtime errors\n return new Color(0, 0, 0, 0);\n } else if (spec.type === 'color') {\n return Color.parse(spec.default) || null;\n } else if (spec.default === undefined) {\n return null;\n } else {\n return spec.default;\n }\n}\n","// @flow\n\n// Turn jsonlint-lines-primitives objects into primitive objects\nexport function unbundle(value: mixed): mixed {\n if (value instanceof Number || value instanceof String || value instanceof Boolean) {\n return value.valueOf();\n } else {\n return value;\n }\n}\n\nexport function deepUnbundle(value: mixed): mixed {\n if (Array.isArray(value)) {\n return value.map(deepUnbundle);\n } else if (value instanceof Object && !(value instanceof Number || value instanceof String || value instanceof Boolean)) {\n const unbundledValue: { [key: string]: mixed } = {};\n for (const key in value) {\n unbundledValue[key] = deepUnbundle(value[key]);\n }\n return unbundledValue;\n }\n\n return unbundle(value);\n}\n","{\n \"$version\": 8,\n \"$root\": {\n \"version\": {\n \"required\": true,\n \"type\": \"enum\",\n \"values\": [\n 8\n ],\n \"doc\": \"Style specification version number. Must be 8.\",\n \"example\": 8\n },\n \"name\": {\n \"type\": \"string\",\n \"doc\": \"A human-readable name for the style.\",\n \"example\": \"Bright\"\n },\n \"metadata\": {\n \"type\": \"*\",\n \"doc\": \"Arbitrary properties useful to track with the stylesheet, but do not influence rendering. Properties should be prefixed to avoid collisions, like 'mapbox:'.\"\n },\n \"center\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"doc\": \"Default map center in longitude and latitude. The style center will be used only if the map has not been positioned by other means (e.g. map options or user interaction).\",\n \"example\": [\n -73.9749,\n 40.7736\n ]\n },\n \"zoom\": {\n \"type\": \"number\",\n \"doc\": \"Default zoom level. The style zoom will be used only if the map has not been positioned by other means (e.g. map options or user interaction).\",\n \"example\": 12.5\n },\n \"bearing\": {\n \"type\": \"number\",\n \"default\": 0,\n \"period\": 360,\n \"units\": \"degrees\",\n \"doc\": \"Default bearing, in degrees. The bearing is the compass direction that is \\\"up\\\"; for example, a bearing of 90° orients the map so that east is up. This value will be used only if the map has not been positioned by other means (e.g. map options or user interaction).\",\n \"example\": 29\n },\n \"pitch\": {\n \"type\": \"number\",\n \"default\": 0,\n \"units\": \"degrees\",\n \"doc\": \"Default pitch, in degrees. Zero is perpendicular to the surface, for a look straight down at the map, while a greater value like 60 looks ahead towards the horizon. The style pitch will be used only if the map has not been positioned by other means (e.g. map options or user interaction).\",\n \"example\": 50\n },\n \"light\": {\n \"type\": \"light\",\n \"doc\": \"The global light source.\",\n \"example\": {\n \"anchor\": \"viewport\",\n \"color\": \"white\",\n \"intensity\": 0.4\n }\n },\n \"terrain\": {\n \"type\": \"terrain\",\n \"doc\": \"A global modifier that elevates layers and markers based on a DEM data source.\"\n },\n \"fog\": {\n \"type\": \"fog\",\n \"doc\": \"A global effect that fades layers and markers based on their distance to the camera. The fog can be used to approximate the effect of atmosphere on distant objects and enhance the depth perception of the map when used with terrain or 3D features. Note: fog is renamed to atmosphere in the Android and iOS SDKs and planned to be changed in GL-JS v.3.0.0.\"\n },\n \"sources\": {\n \"required\": true,\n \"type\": \"sources\",\n \"doc\": \"Data source specifications.\",\n \"example\": {\n \"mapbox-streets\": {\n \"type\": \"vector\",\n \"url\": \"mapbox://mapbox.mapbox-streets-v6\"\n }\n }\n },\n \"sprite\": {\n \"type\": \"string\",\n \"doc\": \"A base URL for retrieving the sprite image and metadata. The extensions `.png`, `.json` and scale factor `@2x.png` will be automatically appended. This property is required if any layer uses the `background-pattern`, `fill-pattern`, `line-pattern`, `fill-extrusion-pattern`, or `icon-image` properties. The URL must be absolute, containing the [scheme, authority and path components](https://en.wikipedia.org/wiki/URL#Syntax).\",\n \"example\": \"mapbox://sprites/mapbox/bright-v8\"\n },\n \"glyphs\": {\n \"type\": \"string\",\n \"doc\": \"A URL template for loading signed-distance-field glyph sets in PBF format. The URL must include `{fontstack}` and `{range}` tokens. This property is required if any layer uses the `text-field` layout property. The URL must be absolute, containing the [scheme, authority and path components](https://en.wikipedia.org/wiki/URL#Syntax).\",\n \"example\": \"mapbox://fonts/mapbox/{fontstack}/{range}.pbf\"\n },\n \"transition\": {\n \"type\": \"transition\",\n \"doc\": \"A global transition definition to use as a default across properties, to be used for timing transitions between one value and the next when no property-specific transition is set. Collision-based symbol fading is controlled independently of the style's `transition` property.\",\n \"example\": {\n \"duration\": 300,\n \"delay\": 0\n }\n },\n \"projection\": {\n \"type\": \"projection\",\n \"doc\": \"The projection the map should be rendered in. Supported projections are Mercator, Globe, Albers, Equal Earth, Equirectangular (WGS84), Lambert conformal conic, Natural Earth, and Winkel Tripel. Terrain, sky and fog are supported by only Mercator and globe. CustomLayerInterface is not supported outside of Mercator.\",\n \"example\": {\n \"name\": \"albers\",\n \"center\": [-154, 50],\n \"parallels\": [55, 65]\n }\n },\n \"layers\": {\n \"required\": true,\n \"type\": \"array\",\n \"value\": \"layer\",\n \"doc\": \"Layers will be drawn in the order of this array.\",\n \"example\": [\n {\n \"id\": \"water\",\n \"source\": \"mapbox-streets\",\n \"source-layer\": \"water\",\n \"type\": \"fill\",\n \"paint\": {\n \"fill-color\": \"#00ffff\"\n }\n }\n ]\n }\n },\n \"sources\": {\n \"*\": {\n \"type\": \"source\",\n \"doc\": \"Specification of a data source. For vector and raster sources, either TileJSON or a URL to a TileJSON must be provided. For image and video sources, a URL must be provided. For GeoJSON sources, a URL or inline GeoJSON must be provided.\"\n }\n },\n \"source\": [\n \"source_vector\",\n \"source_raster\",\n \"source_raster_dem\",\n \"source_geojson\",\n \"source_video\",\n \"source_image\"\n ],\n \"source_vector\": {\n \"type\": {\n \"required\": true,\n \"type\": \"enum\",\n \"values\": {\n \"vector\": {\n \"doc\": \"A vector tile source.\"\n }\n },\n \"doc\": \"The type of the source.\"\n },\n \"url\": {\n \"type\": \"string\",\n \"doc\": \"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://`.\"\n },\n \"tiles\": {\n \"type\": \"array\",\n \"value\": \"string\",\n \"doc\": \"An array of one or more tile source URLs, as in the TileJSON spec.\"\n },\n \"bounds\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 4,\n \"default\": [\n -180,\n -85.051129,\n 180,\n 85.051129\n ],\n \"doc\": \"An array containing the longitude and latitude of the southwest and northeast corners of the source's bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL.\"\n },\n \"scheme\": {\n \"type\": \"enum\",\n \"values\": {\n \"xyz\": {\n \"doc\": \"Slippy map tilenames scheme.\"\n },\n \"tms\": {\n \"doc\": \"OSGeo spec scheme.\"\n }\n },\n \"default\": \"xyz\",\n \"doc\": \"Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed.\"\n },\n \"minzoom\": {\n \"type\": \"number\",\n \"default\": 0,\n \"doc\": \"Minimum zoom level for which tiles are available, as in the TileJSON spec.\"\n },\n \"maxzoom\": {\n \"type\": \"number\",\n \"default\": 22,\n \"doc\": \"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels.\"\n },\n \"attribution\": {\n \"type\": \"string\",\n \"doc\": \"Contains an attribution to be displayed when the map is shown to a user.\"\n },\n \"promoteId\": {\n \"type\": \"promoteId\",\n \"doc\": \"A property to use as a feature id (for feature state). Either a property name, or an object of the form `{: }`. If specified as a string for a vector tile source, the same property is used across all its source layers. If specified as an object only specified source layers will have id overriden, others will fallback to original feature id\"\n },\n \"volatile\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"A setting to determine whether a source's tiles are cached locally.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"android\": \"9.3.0\",\n \"ios\": \"5.10.0\"\n }\n }\n },\n \"*\": {\n \"type\": \"*\",\n \"doc\": \"Other keys to configure the data source.\"\n }\n },\n \"source_raster\": {\n \"type\": {\n \"required\": true,\n \"type\": \"enum\",\n \"values\": {\n \"raster\": {\n \"doc\": \"A raster tile source.\"\n }\n },\n \"doc\": \"The type of the source.\"\n },\n \"url\": {\n \"type\": \"string\",\n \"doc\": \"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://`.\"\n },\n \"tiles\": {\n \"type\": \"array\",\n \"value\": \"string\",\n \"doc\": \"An array of one or more tile source URLs, as in the TileJSON spec.\"\n },\n \"bounds\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 4,\n \"default\": [\n -180,\n -85.051129,\n 180,\n 85.051129\n ],\n \"doc\": \"An array containing the longitude and latitude of the southwest and northeast corners of the source's bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL.\"\n },\n \"minzoom\": {\n \"type\": \"number\",\n \"default\": 0,\n \"doc\": \"Minimum zoom level for which tiles are available, as in the TileJSON spec.\"\n },\n \"maxzoom\": {\n \"type\": \"number\",\n \"default\": 22,\n \"doc\": \"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels.\"\n },\n \"tileSize\": {\n \"type\": \"number\",\n \"default\": 512,\n \"units\": \"pixels\",\n \"doc\": \"The minimum visual size to display tiles for this layer. Only configurable for raster layers.\"\n },\n \"scheme\": {\n \"type\": \"enum\",\n \"values\": {\n \"xyz\": {\n \"doc\": \"Slippy map tilenames scheme.\"\n },\n \"tms\": {\n \"doc\": \"OSGeo spec scheme.\"\n }\n },\n \"default\": \"xyz\",\n \"doc\": \"Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed.\"\n },\n \"attribution\": {\n \"type\": \"string\",\n \"doc\": \"Contains an attribution to be displayed when the map is shown to a user.\"\n },\n \"volatile\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"A setting to determine whether a source's tiles are cached locally.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"android\": \"9.3.0\",\n \"ios\": \"5.10.0\"\n }\n }\n },\n \"*\": {\n \"type\": \"*\",\n \"doc\": \"Other keys to configure the data source.\"\n }\n },\n \"source_raster_dem\": {\n \"type\": {\n \"required\": true,\n \"type\": \"enum\",\n \"values\": {\n \"raster-dem\": {\n \"doc\": \"A RGB-encoded raster DEM source\"\n }\n },\n \"doc\": \"The type of the source.\"\n },\n \"url\": {\n \"type\": \"string\",\n \"doc\": \"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://`.\"\n },\n \"tiles\": {\n \"type\": \"array\",\n \"value\": \"string\",\n \"doc\": \"An array of one or more tile source URLs, as in the TileJSON spec.\"\n },\n \"bounds\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 4,\n \"default\": [\n -180,\n -85.051129,\n 180,\n 85.051129\n ],\n \"doc\": \"An array containing the longitude and latitude of the southwest and northeast corners of the source's bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL.\"\n },\n \"minzoom\": {\n \"type\": \"number\",\n \"default\": 0,\n \"doc\": \"Minimum zoom level for which tiles are available, as in the TileJSON spec.\"\n },\n \"maxzoom\": {\n \"type\": \"number\",\n \"default\": 22,\n \"doc\": \"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels.\"\n },\n \"tileSize\": {\n \"type\": \"number\",\n \"default\": 512,\n \"units\": \"pixels\",\n \"doc\": \"The minimum visual size to display tiles for this layer. Only configurable for raster layers.\"\n },\n \"attribution\": {\n \"type\": \"string\",\n \"doc\": \"Contains an attribution to be displayed when the map is shown to a user.\"\n },\n \"encoding\": {\n \"type\": \"enum\",\n \"values\": {\n \"terrarium\": {\n \"doc\": \"Terrarium format PNG tiles. See https://aws.amazon.com/es/public-datasets/terrain/ for more info.\"\n },\n \"mapbox\": {\n \"doc\": \"Mapbox Terrain RGB tiles. See https://www.mapbox.com/help/access-elevation-data/#mapbox-terrain-rgb for more info.\"\n }\n },\n \"default\": \"mapbox\",\n \"doc\": \"The encoding used by this source. Mapbox Terrain RGB is used by default\"\n },\n \"volatile\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"A setting to determine whether a source's tiles are cached locally.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"android\": \"9.3.0\",\n \"ios\": \"5.10.0\"\n }\n }\n },\n \"*\": {\n \"type\": \"*\",\n \"doc\": \"Other keys to configure the data source.\"\n }\n },\n \"source_geojson\": {\n \"type\": {\n \"required\": true,\n \"type\": \"enum\",\n \"values\": {\n \"geojson\": {\n \"doc\": \"A GeoJSON data source.\"\n }\n },\n \"doc\": \"The data type of the GeoJSON source.\"\n },\n \"data\": {\n \"type\": \"*\",\n \"doc\": \"A URL to a GeoJSON file, or inline GeoJSON.\"\n },\n \"maxzoom\": {\n \"type\": \"number\",\n \"default\": 18,\n \"doc\": \"Maximum zoom level at which to create vector tiles (higher means greater detail at high zoom levels).\"\n },\n \"attribution\": {\n \"type\": \"string\",\n \"doc\": \"Contains an attribution to be displayed when the map is shown to a user.\"\n },\n \"buffer\": {\n \"type\": \"number\",\n \"default\": 128,\n \"maximum\": 512,\n \"minimum\": 0,\n \"doc\": \"Size of the tile buffer on each side. A value of 0 produces no buffer. A value of 512 produces a buffer as wide as the tile itself. Larger values produce fewer rendering artifacts near tile edges and slower performance.\"\n },\n \"filter\": {\n \"type\": \"*\",\n \"doc\": \"An expression for filtering features prior to processing them for rendering.\"\n },\n \"tolerance\": {\n \"type\": \"number\",\n \"default\": 0.375,\n \"doc\": \"Douglas-Peucker simplification tolerance (higher means simpler geometries and faster performance).\"\n },\n \"cluster\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If the data is a collection of point features, setting this to true clusters the points by radius into groups. Cluster groups become new `Point` features in the source with additional properties:\\n * `cluster` Is `true` if the point is a cluster \\n * `cluster_id` A unqiue id for the cluster to be used in conjunction with the [cluster inspection methods](https://www.mapbox.com/mapbox-gl-js/api/#geojsonsource#getclusterexpansionzoom)\\n * `point_count` Number of original points grouped into this cluster\\n * `point_count_abbreviated` An abbreviated point count\"\n },\n \"clusterRadius\": {\n \"type\": \"number\",\n \"default\": 50,\n \"minimum\": 0,\n \"doc\": \"Radius of each cluster if clustering is enabled. A value of 512 indicates a radius equal to the width of a tile.\"\n },\n \"clusterMaxZoom\": {\n \"type\": \"number\",\n \"doc\": \"Max zoom on which to cluster points if clustering is enabled. Defaults to one zoom less than maxzoom (so that last zoom features are not clustered). Clusters are re-evaluated at integer zoom levels so setting clusterMaxZoom to 14 means the clusters will be displayed until z15.\"\n },\n \"clusterMinPoints\": {\n \"type\": \"number\",\n \"doc\": \"Minimum number of points necessary to form a cluster if clustering is enabled. Defaults to `2`.\"\n },\n \"clusterProperties\": {\n \"type\": \"*\",\n \"doc\": \"An object defining custom properties on the generated clusters if clustering is enabled, aggregating values from clustered points. Has the form `{\\\"property_name\\\": [operator, map_expression]}`. `operator` is any expression function that accepts at least 2 operands (e.g. `\\\"+\\\"` or `\\\"max\\\"`) — it accumulates the property value from clusters/points the cluster contains; `map_expression` produces the value of a single point.\\n\\nExample: `{\\\"sum\\\": [\\\"+\\\", [\\\"get\\\", \\\"scalerank\\\"]]}`.\\n\\nFor more advanced use cases, in place of `operator`, you can use a custom reduce expression that references a special `[\\\"accumulated\\\"]` value, e.g.:\\n`{\\\"sum\\\": [[\\\"+\\\", [\\\"accumulated\\\"], [\\\"get\\\", \\\"sum\\\"]], [\\\"get\\\", \\\"scalerank\\\"]]}`\"\n },\n \"lineMetrics\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"Whether to calculate line distance metrics. This is required for line layers that specify `line-gradient` values.\"\n },\n \"generateId\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"Whether to generate ids for the geojson features. When enabled, the `feature.id` property will be auto assigned based on its index in the `features` array, over-writing any previous values.\"\n },\n \"promoteId\": {\n \"type\": \"promoteId\",\n \"doc\": \"A property to use as a feature id (for feature state). Either a property name, or an object of the form `{: }`.\"\n }\n },\n \"source_video\": {\n \"type\": {\n \"required\": true,\n \"type\": \"enum\",\n \"values\": {\n \"video\": {\n \"doc\": \"A video data source.\"\n }\n },\n \"doc\": \"The data type of the video source.\"\n },\n \"urls\": {\n \"required\": true,\n \"type\": \"array\",\n \"value\": \"string\",\n \"doc\": \"URLs to video content in order of preferred format.\"\n },\n \"coordinates\": {\n \"required\": true,\n \"doc\": \"Corners of video specified in longitude, latitude pairs.\",\n \"type\": \"array\",\n \"length\": 4,\n \"value\": {\n \"type\": \"array\",\n \"length\": 2,\n \"value\": \"number\",\n \"doc\": \"A single longitude, latitude pair.\"\n }\n }\n },\n \"source_image\": {\n \"type\": {\n \"required\": true,\n \"type\": \"enum\",\n \"values\": {\n \"image\": {\n \"doc\": \"An image data source.\"\n }\n },\n \"doc\": \"The data type of the image source.\"\n },\n \"url\": {\n \"required\": true,\n \"type\": \"string\",\n \"doc\": \"URL that points to an image.\"\n },\n \"coordinates\": {\n \"required\": true,\n \"doc\": \"Corners of image specified in longitude, latitude pairs.\",\n \"type\": \"array\",\n \"length\": 4,\n \"value\": {\n \"type\": \"array\",\n \"length\": 2,\n \"value\": \"number\",\n \"doc\": \"A single longitude, latitude pair.\"\n }\n }\n },\n \"layer\": {\n \"id\": {\n \"type\": \"string\",\n \"doc\": \"Unique layer name.\",\n \"required\": true\n },\n \"type\": {\n \"type\": \"enum\",\n \"values\": {\n \"fill\": {\n \"doc\": \"A filled polygon with an optional stroked border.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n }\n },\n \"line\": {\n \"doc\": \"A stroked line.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n }\n },\n \"symbol\": {\n \"doc\": \"An icon or a text label.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n }\n },\n \"circle\": {\n \"doc\": \"A filled circle.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n }\n },\n \"heatmap\": {\n \"doc\": \"A heatmap.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"fill-extrusion\": {\n \"doc\": \"An extruded (3D) polygon.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n }\n },\n \"raster\": {\n \"doc\": \"Raster map textures such as satellite imagery.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n }\n },\n \"hillshade\": {\n \"doc\": \"Client-side hillshading visualization based on DEM data. Currently, the implementation only supports Mapbox Terrain RGB and Mapzen Terrarium tiles.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"background\": {\n \"doc\": \"The background color or pattern of the map.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n }\n },\n \"sky\": {\n \"doc\": \"A spherical dome around the map that is always rendered behind all other layers.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n }\n }\n },\n \"doc\": \"Rendering type of this layer.\",\n \"required\": true\n },\n \"metadata\": {\n \"type\": \"*\",\n \"doc\": \"Arbitrary properties useful to track with the layer, but do not influence rendering. Properties should be prefixed to avoid collisions, like 'mapbox:'.\"\n },\n \"source\": {\n \"type\": \"string\",\n \"doc\": \"Name of a source description to be used for this layer. Required for all layer types except `background`.\"\n },\n \"source-layer\": {\n \"type\": \"string\",\n \"doc\": \"Layer to use from a vector tile source. Required for vector tile sources; prohibited for all other source types, including GeoJSON sources.\"\n },\n \"minzoom\": {\n \"type\": \"number\",\n \"minimum\": 0,\n \"maximum\": 24,\n \"doc\": \"The minimum zoom level for the layer. At zoom levels less than the minzoom, the layer will be hidden.\"\n },\n \"maxzoom\": {\n \"type\": \"number\",\n \"minimum\": 0,\n \"maximum\": 24,\n \"doc\": \"The maximum zoom level for the layer. At zoom levels equal to or greater than the maxzoom, the layer will be hidden.\"\n },\n \"filter\": {\n \"type\": \"filter\",\n \"doc\": \"An expression specifying conditions on source features. Only features that match the filter are displayed. Zoom expressions in filters are only evaluated at integer zoom levels. The `[\\\"feature-state\\\", ...]` expression is not supported in filter expressions. The `[\\\"pitch\\\"]` and `[\\\"distance-from-center\\\"]` expressions are supported only for filter expressions on the symbol layer.\"\n },\n \"layout\": {\n \"type\": \"layout\",\n \"doc\": \"Layout properties for the layer.\"\n },\n \"paint\": {\n \"type\": \"paint\",\n \"doc\": \"Default paint properties for this layer.\"\n }\n },\n \"layout\": [\n \"layout_fill\",\n \"layout_line\",\n \"layout_circle\",\n \"layout_heatmap\",\n \"layout_fill-extrusion\",\n \"layout_symbol\",\n \"layout_raster\",\n \"layout_hillshade\",\n \"layout_background\",\n \"layout_sky\"\n ],\n \"layout_background\": {\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_sky\": {\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_fill\": {\n \"fill-sort-key\": {\n \"type\": \"number\",\n \"doc\": \"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.2.0\",\n \"android\": \"9.1.0\",\n \"ios\": \"5.8.0\",\n \"macos\": \"0.15.0\"\n },\n \"data-driven styling\": {\n \"js\": \"1.2.0\",\n \"android\": \"9.1.0\",\n \"ios\": \"5.8.0\",\n \"macos\": \"0.15.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_circle\": {\n \"circle-sort-key\": {\n \"type\": \"number\",\n \"doc\": \"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.2.0\",\n \"android\": \"9.2.0\",\n \"ios\": \"5.9.0\",\n \"macos\": \"0.16.0\"\n },\n \"data-driven styling\": {\n \"js\": \"1.2.0\",\n \"android\": \"9.2.0\",\n \"ios\": \"5.9.0\",\n \"macos\": \"0.16.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_heatmap\": {\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_fill-extrusion\": {\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"property-type\": \"constant\"\n },\n \"fill-extrusion-edge-radius\": {\n \"type\": \"number\",\n \"private\": true,\n \"default\": 0,\n \"minimum\": 0,\n \"maximum\": 1,\n \"doc\": \"Radius of a fill extrusion edge in meters. If not zero, rounds extrusion edges for a smoother appearance.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"v2.10.0\",\n \"android\": \"10.7.0\",\n \"ios\": \"10.7.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_line\": {\n \"line-cap\": {\n \"type\": \"enum\",\n \"values\": {\n \"butt\": {\n \"doc\": \"A cap with a squared-off end which is drawn to the exact endpoint of the line.\"\n },\n \"round\": {\n \"doc\": \"A cap with a rounded end which is drawn beyond the endpoint of the line at a radius of one-half of the line's width and centered on the endpoint of the line.\"\n },\n \"square\": {\n \"doc\": \"A cap with a squared-off end which is drawn beyond the endpoint of the line at a distance of one-half of the line's width.\"\n }\n },\n \"default\": \"butt\",\n \"doc\": \"The display of line endings.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"2.3.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-join\": {\n \"type\": \"enum\",\n \"values\": {\n \"bevel\": {\n \"doc\": \"A join with a squared-off end which is drawn beyond the endpoint of the line at a distance of one-half of the line's width.\"\n },\n \"round\": {\n \"doc\": \"A join with a rounded end which is drawn beyond the endpoint of the line at a radius of one-half of the line's width and centered on the endpoint of the line.\"\n },\n \"miter\": {\n \"doc\": \"A join with a sharp, angled corner which is drawn with the outer sides beyond the endpoint of the path until they meet.\"\n }\n },\n \"default\": \"miter\",\n \"doc\": \"The display of lines when joining.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.40.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-miter-limit\": {\n \"type\": \"number\",\n \"default\": 2,\n \"doc\": \"Used to automatically convert miter joins to bevel joins for sharp angles.\",\n \"requires\": [\n {\n \"line-join\": \"miter\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"line-round-limit\": {\n \"type\": \"number\",\n \"default\": 1.05,\n \"doc\": \"Used to automatically convert round joins to miter joins for shallow angles.\",\n \"requires\": [\n {\n \"line-join\": \"round\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"line-sort-key\": {\n \"type\": \"number\",\n \"doc\": \"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.2.0\",\n \"android\": \"9.1.0\",\n \"ios\": \"5.8.0\",\n \"macos\": \"0.15.0\"\n },\n \"data-driven styling\": {\n \"js\": \"1.2.0\",\n \"android\": \"9.1.0\",\n \"ios\": \"5.8.0\",\n \"macos\": \"0.15.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_symbol\": {\n \"symbol-placement\": {\n \"type\": \"enum\",\n \"values\": {\n \"point\": {\n \"doc\": \"The label is placed at the point where the geometry is located.\"\n },\n \"line\": {\n \"doc\": \"The label is placed along the line of the geometry. Can only be used on `LineString` and `Polygon` geometries.\"\n },\n \"line-center\": {\n \"doc\": \"The label is placed at the center of the line of the geometry. Can only be used on `LineString` and `Polygon` geometries. Note that a single feature in a vector tile may contain multiple line geometries.\"\n }\n },\n \"default\": \"point\",\n \"doc\": \"Label placement relative to its geometry.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"`line-center` value\": {\n \"js\": \"0.47.0\",\n \"android\": \"6.4.0\",\n \"ios\": \"4.3.0\",\n \"macos\": \"0.10.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"symbol-spacing\": {\n \"type\": \"number\",\n \"default\": 250,\n \"minimum\": 1,\n \"units\": \"pixels\",\n \"doc\": \"Distance between two symbol anchors.\",\n \"requires\": [\n {\n \"symbol-placement\": \"line\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"symbol-avoid-edges\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, the symbols will not cross tile edges to avoid mutual collisions. Recommended in layers that don't have enough padding in the vector tile to prevent collisions, or if it is a point symbol layer placed after a line symbol layer. When using a client that supports global collision detection, like Mapbox GL JS version 0.42.0 or greater, enabling this property is not needed to prevent clipped labels at tile boundaries.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"symbol-sort-key\": {\n \"type\": \"number\",\n \"doc\": \"Sorts features in ascending order based on this value. Features with lower sort keys are drawn and placed first. When `icon-allow-overlap` or `text-allow-overlap` is `false`, features with a lower sort key will have priority during placement. When `icon-allow-overlap` or `text-allow-overlap` is set to `true`, features with a higher sort key will overlap over features with a lower sort key.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.53.0\",\n \"android\": \"7.4.0\",\n \"ios\": \"4.11.0\",\n \"macos\": \"0.14.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.53.0\",\n \"android\": \"7.4.0\",\n \"ios\": \"4.11.0\",\n \"macos\": \"0.14.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"symbol-z-order\": {\n \"type\": \"enum\",\n \"values\": {\n \"auto\": {\n \"doc\": \"Sorts symbols by `symbol-sort-key` if set. Otherwise, sorts symbols by their y-position relative to the viewport if `icon-allow-overlap` or `text-allow-overlap` is set to `true` or `icon-ignore-placement` or `text-ignore-placement` is `false`.\"\n },\n \"viewport-y\": {\n \"doc\": \"Sorts symbols by their y-position relative to the viewport if `icon-allow-overlap` or `text-allow-overlap` is set to `true` or `icon-ignore-placement` or `text-ignore-placement` is `false`.\"\n },\n \"source\": {\n \"doc\": \"Sorts symbols by `symbol-sort-key` if set. Otherwise, no sorting is applied; symbols are rendered in the same order as the source data.\"\n }\n },\n \"default\": \"auto\",\n \"doc\": \"Determines whether overlapping symbols in the same layer are rendered in the order that they appear in the data source or by their y-position relative to the viewport. To control the order and prioritization of symbols otherwise, use `symbol-sort-key`.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.49.0\",\n \"android\": \"6.6.0\",\n \"ios\": \"4.5.0\",\n \"macos\": \"0.12.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-allow-overlap\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, the icon will be visible even if it collides with other previously drawn symbols.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-ignore-placement\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, other symbols can be visible even if they collide with the icon.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-optional\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, text will display without their corresponding icons when the icon collides with other symbols and the text does not.\",\n \"requires\": [\n \"icon-image\",\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-rotation-alignment\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"When `symbol-placement` is set to `point`, aligns icons east-west. When `symbol-placement` is set to `line` or `line-center`, aligns icon x-axes with the line.\"\n },\n \"viewport\": {\n \"doc\": \"Produces icons whose x-axes are aligned with the x-axis of the viewport, regardless of the value of `symbol-placement`.\"\n },\n \"auto\": {\n \"doc\": \"When `symbol-placement` is set to `point`, this is equivalent to `viewport`. When `symbol-placement` is set to `line` or `line-center`, this is equivalent to `map`.\"\n }\n },\n \"default\": \"auto\",\n \"doc\": \"In combination with `symbol-placement`, determines the rotation behavior of icons.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"`auto` value\": {\n \"js\": \"0.25.0\",\n \"android\": \"4.2.0\",\n \"ios\": \"3.4.0\",\n \"macos\": \"0.3.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-size\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"units\": \"factor of the original icon size\",\n \"doc\": \"Scales the original size of the icon by the provided factor. The new pixel size of the image will be the original pixel size multiplied by `icon-size`. 1 is the original size; 3 triples the size of the image.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.35.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-text-fit\": {\n \"type\": \"enum\",\n \"values\": {\n \"none\": {\n \"doc\": \"The icon is displayed at its intrinsic aspect ratio.\"\n },\n \"width\": {\n \"doc\": \"The icon is scaled in the x-dimension to fit the width of the text.\"\n },\n \"height\": {\n \"doc\": \"The icon is scaled in the y-dimension to fit the height of the text.\"\n },\n \"both\": {\n \"doc\": \"The icon is scaled in both x- and y-dimensions.\"\n }\n },\n \"default\": \"none\",\n \"doc\": \"Scales the icon to fit around the associated text.\",\n \"requires\": [\n \"icon-image\",\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.21.0\",\n \"android\": \"4.2.0\",\n \"ios\": \"3.4.0\",\n \"macos\": \"0.2.1\"\n },\n \"stretchable icons\": {\n \"js\": \"1.6.0\",\n \"android\": \"9.2.0\",\n \"ios\": \"5.8.0\",\n \"macos\": \"0.15.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-text-fit-padding\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 4,\n \"default\": [\n 0,\n 0,\n 0,\n 0\n ],\n \"units\": \"pixels\",\n \"doc\": \"Size of the additional area added to dimensions determined by `icon-text-fit`, in clockwise order: top, right, bottom, left.\",\n \"requires\": [\n \"icon-image\",\n \"text-field\",\n {\n \"icon-text-fit\": [\n \"both\",\n \"width\",\n \"height\"\n ]\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.21.0\",\n \"android\": \"4.2.0\",\n \"ios\": \"3.4.0\",\n \"macos\": \"0.2.1\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-image\": {\n \"type\": \"resolvedImage\",\n \"doc\": \"Name of image in sprite to use for drawing an image background.\",\n \"tokens\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.35.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-rotate\": {\n \"type\": \"number\",\n \"default\": 0,\n \"period\": 360,\n \"units\": \"degrees\",\n \"doc\": \"Rotates the icon clockwise.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.21.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-padding\": {\n \"type\": \"number\",\n \"default\": 2,\n \"minimum\": 0,\n \"units\": \"pixels\",\n \"doc\": \"Size of the additional area around the icon bounding box used for detecting symbol collisions.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-keep-upright\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, the icon may be flipped to prevent it from being rendered upside-down.\",\n \"requires\": [\n \"icon-image\",\n {\n \"icon-rotation-alignment\": \"map\"\n },\n {\n \"symbol-placement\": [\n \"line\",\n \"line-center\"\n ]\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-offset\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"doc\": \"Offset distance of icon from its anchor. Positive values indicate right and down, while negative values indicate left and up. Each component is multiplied by the value of `icon-size` to obtain the final offset in pixels. When combined with `icon-rotate` the offset will be as if the rotated direction was up.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"center\": {\n \"doc\": \"The center of the icon is placed closest to the anchor.\"\n },\n \"left\": {\n \"doc\": \"The left side of the icon is placed closest to the anchor.\"\n },\n \"right\": {\n \"doc\": \"The right side of the icon is placed closest to the anchor.\"\n },\n \"top\": {\n \"doc\": \"The top of the icon is placed closest to the anchor.\"\n },\n \"bottom\": {\n \"doc\": \"The bottom of the icon is placed closest to the anchor.\"\n },\n \"top-left\": {\n \"doc\": \"The top left corner of the icon is placed closest to the anchor.\"\n },\n \"top-right\": {\n \"doc\": \"The top right corner of the icon is placed closest to the anchor.\"\n },\n \"bottom-left\": {\n \"doc\": \"The bottom left corner of the icon is placed closest to the anchor.\"\n },\n \"bottom-right\": {\n \"doc\": \"The bottom right corner of the icon is placed closest to the anchor.\"\n }\n },\n \"default\": \"center\",\n \"doc\": \"Part of the icon placed closest to the anchor.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.40.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.40.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-pitch-alignment\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The icon is aligned to the plane of the map.\"\n },\n \"viewport\": {\n \"doc\": \"The icon is aligned to the plane of the viewport.\"\n },\n \"auto\": {\n \"doc\": \"Automatically matches the value of `icon-rotation-alignment`.\"\n }\n },\n \"default\": \"auto\",\n \"doc\": \"Orientation of icon when map is pitched.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.39.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-pitch-alignment\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The text is aligned to the plane of the map.\"\n },\n \"viewport\": {\n \"doc\": \"The text is aligned to the plane of the viewport.\"\n },\n \"auto\": {\n \"doc\": \"Automatically matches the value of `text-rotation-alignment`.\"\n }\n },\n \"default\": \"auto\",\n \"doc\": \"Orientation of text when map is pitched.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.21.0\",\n \"android\": \"4.2.0\",\n \"ios\": \"3.4.0\",\n \"macos\": \"0.2.1\"\n },\n \"`auto` value\": {\n \"js\": \"0.25.0\",\n \"android\": \"4.2.0\",\n \"ios\": \"3.4.0\",\n \"macos\": \"0.3.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-rotation-alignment\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"When `symbol-placement` is set to `point`, aligns text east-west. When `symbol-placement` is set to `line` or `line-center`, aligns text x-axes with the line.\"\n },\n \"viewport\": {\n \"doc\": \"Produces glyphs whose x-axes are aligned with the x-axis of the viewport, regardless of the value of `symbol-placement`.\"\n },\n \"auto\": {\n \"doc\": \"When `symbol-placement` is set to `point`, this is equivalent to `viewport`. When `symbol-placement` is set to `line` or `line-center`, this is equivalent to `map`.\"\n }\n },\n \"default\": \"auto\",\n \"doc\": \"In combination with `symbol-placement`, determines the rotation behavior of the individual glyphs forming the text.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"`auto` value\": {\n \"js\": \"0.25.0\",\n \"android\": \"4.2.0\",\n \"ios\": \"3.4.0\",\n \"macos\": \"0.3.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-field\": {\n \"type\": \"formatted\",\n \"default\": \"\",\n \"tokens\": true,\n \"doc\": \"Value to use for a text label. If a plain `string` is provided, it will be treated as a `formatted` with default/inherited formatting options. SDF images are not supported in formatted text and will be ignored.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-font\": {\n \"type\": \"array\",\n \"value\": \"string\",\n \"default\": [\n \"Open Sans Regular\",\n \"Arial Unicode MS Regular\"\n ],\n \"doc\": \"Font stack to use for displaying text.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-size\": {\n \"type\": \"number\",\n \"default\": 16,\n \"minimum\": 0,\n \"units\": \"pixels\",\n \"doc\": \"Font size.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.35.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-max-width\": {\n \"type\": \"number\",\n \"default\": 10,\n \"minimum\": 0,\n \"units\": \"ems\",\n \"doc\": \"The maximum line width for text wrapping.\",\n \"requires\": [\n \"text-field\",\n {\n \"symbol-placement\": [\n \"point\"\n ]\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.40.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-line-height\": {\n \"type\": \"number\",\n \"default\": 1.2,\n \"units\": \"ems\",\n \"doc\": \"Text leading value for multi-line text.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"2.3.0\",\n \"android\": \"10.0.0\",\n \"ios\": \"10.0.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-letter-spacing\": {\n \"type\": \"number\",\n \"default\": 0,\n \"units\": \"ems\",\n \"doc\": \"Text tracking amount.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.40.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-justify\": {\n \"type\": \"enum\",\n \"values\": {\n \"auto\": {\n \"doc\": \"The text is aligned towards the anchor position.\"\n },\n \"left\": {\n \"doc\": \"The text is aligned to the left.\"\n },\n \"center\": {\n \"doc\": \"The text is centered.\"\n },\n \"right\": {\n \"doc\": \"The text is aligned to the right.\"\n }\n },\n \"default\": \"center\",\n \"doc\": \"Text justification options.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.39.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n },\n \"auto\": {\n \"js\": \"0.54.0\",\n \"android\": \"7.4.0\",\n \"ios\": \"4.10.0\",\n \"macos\": \"0.14.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-radial-offset\": {\n \"type\": \"number\",\n \"units\": \"ems\",\n \"default\": 0,\n \"doc\": \"Radial offset of text, in the direction of the symbol's anchor. Useful in combination with `text-variable-anchor`, which defaults to using the two-dimensional `text-offset` if present.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.54.0\",\n \"android\": \"7.4.0\",\n \"ios\": \"4.10.0\",\n \"macos\": \"0.14.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.54.0\",\n \"android\": \"7.4.0\",\n \"ios\": \"4.10.0\",\n \"macos\": \"0.14.0\"\n }\n },\n \"requires\": [\n \"text-field\"\n ],\n \"property-type\": \"data-driven\",\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n }\n },\n \"text-variable-anchor\": {\n \"type\": \"array\",\n \"value\": \"enum\",\n \"values\": {\n \"center\": {\n \"doc\": \"The center of the text is placed closest to the anchor.\"\n },\n \"left\": {\n \"doc\": \"The left side of the text is placed closest to the anchor.\"\n },\n \"right\": {\n \"doc\": \"The right side of the text is placed closest to the anchor.\"\n },\n \"top\": {\n \"doc\": \"The top of the text is placed closest to the anchor.\"\n },\n \"bottom\": {\n \"doc\": \"The bottom of the text is placed closest to the anchor.\"\n },\n \"top-left\": {\n \"doc\": \"The top left corner of the text is placed closest to the anchor.\"\n },\n \"top-right\": {\n \"doc\": \"The top right corner of the text is placed closest to the anchor.\"\n },\n \"bottom-left\": {\n \"doc\": \"The bottom left corner of the text is placed closest to the anchor.\"\n },\n \"bottom-right\": {\n \"doc\": \"The bottom right corner of the text is placed closest to the anchor.\"\n }\n },\n \"requires\": [\n \"text-field\",\n {\n \"symbol-placement\": [\n \"point\"\n ]\n }\n ],\n \"doc\": \"To increase the chance of placing high-priority labels on the map, you can provide an array of `text-anchor` locations: the renderer will attempt to place the label at each location, in order, before moving onto the next label. Use `text-justify: auto` to choose justification based on anchor position. To apply an offset, use the `text-radial-offset` or the two-dimensional `text-offset`.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.54.0\",\n \"android\": \"7.4.0\",\n \"ios\": \"4.10.0\",\n \"macos\": \"0.14.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"center\": {\n \"doc\": \"The center of the text is placed closest to the anchor.\"\n },\n \"left\": {\n \"doc\": \"The left side of the text is placed closest to the anchor.\"\n },\n \"right\": {\n \"doc\": \"The right side of the text is placed closest to the anchor.\"\n },\n \"top\": {\n \"doc\": \"The top of the text is placed closest to the anchor.\"\n },\n \"bottom\": {\n \"doc\": \"The bottom of the text is placed closest to the anchor.\"\n },\n \"top-left\": {\n \"doc\": \"The top left corner of the text is placed closest to the anchor.\"\n },\n \"top-right\": {\n \"doc\": \"The top right corner of the text is placed closest to the anchor.\"\n },\n \"bottom-left\": {\n \"doc\": \"The bottom left corner of the text is placed closest to the anchor.\"\n },\n \"bottom-right\": {\n \"doc\": \"The bottom right corner of the text is placed closest to the anchor.\"\n }\n },\n \"default\": \"center\",\n \"doc\": \"Part of the text placed closest to the anchor.\",\n \"requires\": [\n \"text-field\",\n {\n \"!\": \"text-variable-anchor\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.39.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-max-angle\": {\n \"type\": \"number\",\n \"default\": 45,\n \"units\": \"degrees\",\n \"doc\": \"Maximum angle change between adjacent characters.\",\n \"requires\": [\n \"text-field\",\n {\n \"symbol-placement\": [\n \"line\",\n \"line-center\"\n ]\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-writing-mode\": {\n \"type\": \"array\",\n \"value\": \"enum\",\n \"values\": {\n \"horizontal\": {\n \"doc\": \"If a text's language supports horizontal writing mode, symbols would be laid out horizontally.\"\n },\n \"vertical\": {\n \"doc\": \"If a text's language supports vertical writing mode, symbols would be laid out vertically.\"\n }\n },\n \"doc\": \"The property allows control over a symbol's orientation. Note that the property values act as a hint, so that a symbol whose language doesn’t support the provided orientation will be laid out in its natural orientation. Example: English point symbol will be rendered horizontally even if array value contains single 'vertical' enum value. For symbol with point placement, the order of elements in an array define priority order for the placement of an orientation variant. For symbol with line placement, the default text writing mode is either ['horizontal', 'vertical'] or ['vertical', 'horizontal'], the order doesn't affect the placement.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.3.0\",\n \"android\": \"8.3.0\",\n \"ios\": \"5.3.0\",\n \"macos\": \"0.15.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-rotate\": {\n \"type\": \"number\",\n \"default\": 0,\n \"period\": 360,\n \"units\": \"degrees\",\n \"doc\": \"Rotates the text clockwise.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.35.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-padding\": {\n \"type\": \"number\",\n \"default\": 2,\n \"minimum\": 0,\n \"units\": \"pixels\",\n \"doc\": \"Size of the additional area around the text bounding box used for detecting symbol collisions.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-keep-upright\": {\n \"type\": \"boolean\",\n \"default\": true,\n \"doc\": \"If true, the text may be flipped vertically to prevent it from being rendered upside-down.\",\n \"requires\": [\n \"text-field\",\n {\n \"text-rotation-alignment\": \"map\"\n },\n {\n \"symbol-placement\": [\n \"line\",\n \"line-center\"\n ]\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-transform\": {\n \"type\": \"enum\",\n \"values\": {\n \"none\": {\n \"doc\": \"The text is not altered.\"\n },\n \"uppercase\": {\n \"doc\": \"Forces all letters to be displayed in uppercase.\"\n },\n \"lowercase\": {\n \"doc\": \"Forces all letters to be displayed in lowercase.\"\n }\n },\n \"default\": \"none\",\n \"doc\": \"Specifies how to capitalize text, similar to the CSS `text-transform` property.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-offset\": {\n \"type\": \"array\",\n \"doc\": \"Offset distance of text from its anchor. Positive values indicate right and down, while negative values indicate left and up. If used with text-variable-anchor, input values will be taken as absolute values. Offsets along the x- and y-axis will be applied automatically based on the anchor position.\",\n \"value\": \"number\",\n \"units\": \"ems\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"requires\": [\n \"text-field\",\n {\n \"!\": \"text-radial-offset\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.35.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-allow-overlap\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, the text will be visible even if it collides with other previously drawn symbols.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-ignore-placement\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, other symbols can be visible even if they collide with the text.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-optional\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, icons will display without their corresponding text when the text collides with other symbols and the icon does not.\",\n \"requires\": [\n \"text-field\",\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_raster\": {\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_hillshade\": {\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"filter\": {\n \"type\": \"array\",\n \"value\": \"*\",\n \"doc\": \"A filter selects specific features from a layer.\"\n },\n \"filter_symbol\": {\n \"type\": \"boolean\",\n \"doc\": \"Expression which determines whether or not to display a symbol. Symbols support dynamic filtering, meaning this expression can use the `[\\\"pitch\\\"]` and `[\\\"distance-from-center\\\"]` expressions to reference the current state of the view.\",\n \"default\": false,\n \"transition\": false,\n \"property-type\": \"data-driven\",\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\"zoom\", \"feature\", \"pitch\", \"distance-from-center\"]\n }\n },\n \"filter_fill\": {\n \"type\": \"boolean\",\n \"doc\": \"Expression which determines whether or not to display a polygon. Fill layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\\"pitch\\\"]` and `[\\\"distance-from-center\\\"]` expressions to reference the current state of the view.\",\n \"default\": false,\n \"transition\": false,\n \"property-type\": \"data-driven\",\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\"zoom\", \"feature\"]\n }\n },\n \"filter_line\": {\n \"type\": \"boolean\",\n \"doc\": \"Expression which determines whether or not to display a Polygon or LineString. Line layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\\"pitch\\\"]` and `[\\\"distance-from-center\\\"]` expressions to reference the current state of the view.\",\n \"default\": false,\n \"transition\": false,\n \"property-type\": \"data-driven\",\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\"zoom\", \"feature\"]\n }\n },\n \"filter_circle\": {\n \"type\": \"boolean\",\n \"doc\": \"Expression which determines whether or not to display a circle. Circle layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\\"pitch\\\"]` and `[\\\"distance-from-center\\\"]` expressions to reference the current state of the view.\",\n \"default\": false,\n \"transition\": false,\n \"property-type\": \"data-driven\",\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\"zoom\", \"feature\"]\n }\n },\n \"filter_fill-extrusion\": {\n \"type\": \"boolean\",\n \"doc\": \"Expression which determines whether or not to display a Polygon. Fill-extrusion layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\\"pitch\\\"]` and `[\\\"distance-from-center\\\"]` expressions to reference the current state of the view.\",\n \"default\": false,\n \"transition\": false,\n \"property-type\": \"data-driven\",\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\"zoom\", \"feature\"]\n }\n },\n \"filter_heatmap\": {\n \"type\": \"boolean\",\n \"doc\": \"Expression used to determine whether a point is being displayed or not. Heatmap layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\\"pitch\\\"]` and `[\\\"distance-from-center\\\"]` expressions to reference the current state of the view.\",\n \"default\": false,\n \"transition\": false,\n \"property-type\": \"data-driven\",\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\"zoom\", \"feature\"]\n }\n },\n \"filter_operator\": {\n \"type\": \"enum\",\n \"values\": {\n \"==\": {\n \"doc\": \"`[\\\"==\\\", key, value]` equality: `feature[key] = value`\"\n },\n \"!=\": {\n \"doc\": \"`[\\\"!=\\\", key, value]` inequality: `feature[key] ≠ value`\"\n },\n \">\": {\n \"doc\": \"`[\\\">\\\", key, value]` greater than: `feature[key] > value`\"\n },\n \">=\": {\n \"doc\": \"`[\\\">=\\\", key, value]` greater than or equal: `feature[key] ≥ value`\"\n },\n \"<\": {\n \"doc\": \"`[\\\"<\\\", key, value]` less than: `feature[key] < value`\"\n },\n \"<=\": {\n \"doc\": \"`[\\\"<=\\\", key, value]` less than or equal: `feature[key] ≤ value`\"\n },\n \"in\": {\n \"doc\": \"`[\\\"in\\\", key, v0, ..., vn]` set inclusion: `feature[key] ∈ {v0, ..., vn}`\"\n },\n \"!in\": {\n \"doc\": \"`[\\\"!in\\\", key, v0, ..., vn]` set exclusion: `feature[key] ∉ {v0, ..., vn}`\"\n },\n \"all\": {\n \"doc\": \"`[\\\"all\\\", f0, ..., fn]` logical `AND`: `f0 ∧ ... ∧ fn`\"\n },\n \"any\": {\n \"doc\": \"`[\\\"any\\\", f0, ..., fn]` logical `OR`: `f0 ∨ ... ∨ fn`\"\n },\n \"none\": {\n \"doc\": \"`[\\\"none\\\", f0, ..., fn]` logical `NOR`: `¬f0 ∧ ... ∧ ¬fn`\"\n },\n \"has\": {\n \"doc\": \"`[\\\"has\\\", key]` `feature[key]` exists\"\n },\n \"!has\": {\n \"doc\": \"`[\\\"!has\\\", key]` `feature[key]` does not exist\"\n },\n \"within\": {\n \"doc\": \"`[\\\"within\\\", object]` feature geometry is within object geometry\"\n }\n },\n \"doc\": \"The filter operator.\"\n },\n \"geometry_type\": {\n \"type\": \"enum\",\n \"values\": {\n \"Point\": {\n \"doc\": \"Filter to point geometries.\"\n },\n \"LineString\": {\n \"doc\": \"Filter to line geometries.\"\n },\n \"Polygon\": {\n \"doc\": \"Filter to polygon geometries.\"\n }\n },\n \"doc\": \"The geometry type for the filter to select.\"\n },\n \"function\": {\n \"expression\": {\n \"type\": \"expression\",\n \"doc\": \"An expression.\"\n },\n \"stops\": {\n \"type\": \"array\",\n \"doc\": \"An array of stops.\",\n \"value\": \"function_stop\"\n },\n \"base\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"doc\": \"The exponential base of the interpolation curve. It controls the rate at which the result increases. Higher values make the result increase more towards the high end of the range. With `1` the stops are interpolated linearly.\"\n },\n \"property\": {\n \"type\": \"string\",\n \"doc\": \"The name of a feature property to use as the function input.\",\n \"default\": \"$zoom\"\n },\n \"type\": {\n \"type\": \"enum\",\n \"values\": {\n \"identity\": {\n \"doc\": \"Return the input value as the output value.\"\n },\n \"exponential\": {\n \"doc\": \"Generate an output by interpolating between stops just less than and just greater than the function input.\"\n },\n \"interval\": {\n \"doc\": \"Return the output value of the stop just less than the function input.\"\n },\n \"categorical\": {\n \"doc\": \"Return the output value of the stop equal to the function input.\"\n }\n },\n \"doc\": \"The interpolation strategy to use in function evaluation.\",\n \"default\": \"exponential\"\n },\n \"colorSpace\": {\n \"type\": \"enum\",\n \"values\": {\n \"rgb\": {\n \"doc\": \"Use the RGB color space to interpolate color values\"\n },\n \"lab\": {\n \"doc\": \"Use the LAB color space to interpolate color values.\"\n },\n \"hcl\": {\n \"doc\": \"Use the HCL color space to interpolate color values, interpolating the Hue, Chroma, and Luminance channels individually.\"\n }\n },\n \"doc\": \"The color space in which colors interpolated. Interpolating colors in perceptual color spaces like LAB and HCL tend to produce color ramps that look more consistent and produce colors that can be differentiated more easily than those interpolated in RGB space.\",\n \"default\": \"rgb\"\n },\n \"default\": {\n \"type\": \"*\",\n \"required\": false,\n \"doc\": \"A value to serve as a fallback function result when a value isn't otherwise available. It is used in the following circumstances:\\n* In categorical functions, when the feature value does not match any of the stop domain values.\\n* In property and zoom-and-property functions, when a feature does not contain a value for the specified property.\\n* In identity functions, when the feature value is not valid for the style property (for example, if the function is being used for a `circle-color` property but the feature property value is not a string or not a valid color).\\n* In interval or exponential property and zoom-and-property functions, when the feature value is not numeric.\\nIf no default is provided, the style property's default is used in these circumstances.\"\n }\n },\n \"function_stop\": {\n \"type\": \"array\",\n \"minimum\": 0,\n \"maximum\": 24,\n \"value\": [\n \"number\",\n \"color\"\n ],\n \"length\": 2,\n \"doc\": \"Zoom level and value pair.\"\n },\n \"expression\": {\n \"type\": \"array\",\n \"value\": \"*\",\n \"minimum\": 1,\n \"doc\": \"An expression defines a function that can be used for data-driven style properties or feature filters.\"\n },\n \"expression_name\": {\n \"doc\": \"\",\n \"type\": \"enum\",\n \"values\": {\n \"let\": {\n \"doc\": \"Binds expressions to named variables, which can then be referenced in the result expression using [\\\"var\\\", \\\"variable_name\\\"].\",\n \"group\": \"Variable binding\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"var\": {\n \"doc\": \"References variable bound using \\\"let\\\".\",\n \"group\": \"Variable binding\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"literal\": {\n \"doc\": \"Provides a literal array or object value.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"array\": {\n \"doc\": \"Asserts that the input is an array (optionally with a specific item type and length). If, when the input expression is evaluated, it is not of the asserted type, then this assertion will cause the whole expression to be aborted.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"at\": {\n \"doc\": \"Retrieves an item from an array.\",\n \"group\": \"Lookup\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"in\": {\n \"doc\": \"Determines whether an item exists in an array or a substring exists in a string. In the specific case when the second and third arguments are string literals, you must wrap at least one of them in a [`literal`](#types-literal) expression to hint correct interpretation to the [type system](#type-system).\",\n \"group\": \"Lookup\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.6.0\",\n \"android\": \"9.1.0\",\n \"ios\": \"5.8.0\",\n \"macos\": \"0.15.0\"\n }\n }\n },\n \"index-of\": {\n \"doc\": \"Returns the first position at which an item can be found in an array or a substring can be found in a string, or `-1` if the input cannot be found. Accepts an optional index from where to begin the search.\",\n \"group\": \"Lookup\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.10.0\",\n \"android\": \"10.0.0\",\n \"ios\": \"10.0.0\"\n }\n }\n },\n \"slice\": {\n \"doc\": \"Returns an item from an array or a substring from a string from a specified start index, or between a start index and an end index if set. The return value is inclusive of the start index but not of the end index.\",\n \"group\": \"Lookup\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.10.0\",\n \"android\": \"10.0.0\",\n \"ios\": \"10.0.0\"\n }\n }\n },\n \"case\": {\n \"doc\": \"Selects the first output whose corresponding test condition evaluates to true, or the fallback value otherwise.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"match\": {\n \"doc\": \"Selects the output for which the label value matches the input value, or the fallback value if no match is found. The input can be any expression (for example, `[\\\"get\\\", \\\"building_type\\\"]`). Each label must be unique, and must be either:\\n - a single literal value; or\\n - an array of literal values, the values of which must be all strings or all numbers (for example `[100, 101]` or `[\\\"c\\\", \\\"b\\\"]`).\\n\\nThe input matches if any of the values in the array matches using strict equality, similar to the `\\\"in\\\"` operator.\\nIf the input type does not match the type of the labels, the result will be the fallback value.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"coalesce\": {\n \"doc\": \"Evaluates each expression in turn until the first valid value is obtained. Invalid values are `null` and [`'image'`](#types-image) expressions that are unavailable in the style. If all values are invalid, `coalesce` returns the first value listed.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"step\": {\n \"doc\": \"Produces discrete, stepped results by evaluating a piecewise-constant function defined by pairs of input and output values (\\\"stops\\\"). The `input` may be any numeric expression (e.g., `[\\\"get\\\", \\\"population\\\"]`). Stop inputs must be numeric literals in strictly ascending order. Returns the output value of the stop just less than the input, or the first output if the input is less than the first stop.\",\n \"group\": \"Ramps, scales, curves\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.42.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"interpolate\": {\n \"doc\": \"Produces continuous, smooth results by interpolating between pairs of input and output values (\\\"stops\\\"). The `input` may be any numeric expression (e.g., `[\\\"get\\\", \\\"population\\\"]`). Stop inputs must be numeric literals in strictly ascending order. The output type must be `number`, `array`, or `color`.\\n\\nInterpolation types:\\n- `[\\\"linear\\\"]`: Interpolates linearly between the pair of stops just less than and just greater than the input.\\n- `[\\\"exponential\\\", base]`: Interpolates exponentially between the stops just less than and just greater than the input. `base` controls the rate at which the output increases: higher values make the output increase more towards the high end of the range. With values close to 1 the output increases linearly.\\n- `[\\\"cubic-bezier\\\", x1, y1, x2, y2]`: Interpolates using the cubic bezier curve defined by the given control points.\",\n \"group\": \"Ramps, scales, curves\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.42.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"interpolate-hcl\": {\n \"doc\": \"Produces continuous, smooth results by interpolating between pairs of input and output values (\\\"stops\\\"). Works like `interpolate`, but the output type must be `color`, and the interpolation is performed in the Hue-Chroma-Luminance color space.\",\n \"group\": \"Ramps, scales, curves\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.49.0\"\n }\n }\n },\n \"interpolate-lab\": {\n \"doc\": \"Produces continuous, smooth results by interpolating between pairs of input and output values (\\\"stops\\\"). Works like `interpolate`, but the output type must be `color`, and the interpolation is performed in the CIELAB color space.\",\n \"group\": \"Ramps, scales, curves\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.49.0\"\n }\n }\n },\n \"ln2\": {\n \"doc\": \"Returns mathematical constant ln(2).\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"pi\": {\n \"doc\": \"Returns the mathematical constant pi.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"e\": {\n \"doc\": \"Returns the mathematical constant e.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"typeof\": {\n \"doc\": \"Returns a string describing the type of the given value.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"string\": {\n \"doc\": \"Asserts that the input value is a string. If multiple values are provided, each one is evaluated in order until a string is obtained. If none of the inputs are strings, the expression is an error.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"number\": {\n \"doc\": \"Asserts that the input value is a number. If multiple values are provided, each one is evaluated in order until a number is obtained. If none of the inputs are numbers, the expression is an error.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"boolean\": {\n \"doc\": \"Asserts that the input value is a boolean. If multiple values are provided, each one is evaluated in order until a boolean is obtained. If none of the inputs are booleans, the expression is an error.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"object\": {\n \"doc\": \"Asserts that the input value is an object. If multiple values are provided, each one is evaluated in order until an object is obtained. If none of the inputs are objects, the expression is an error.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"collator\": {\n \"doc\": \"Returns a `collator` for use in locale-dependent comparison operations. The `case-sensitive` and `diacritic-sensitive` options default to `false`. The `locale` argument specifies the IETF language tag of the locale to use. If none is provided, the default locale is used. If the requested locale is not available, the `collator` will use a system-defined fallback locale. Use `resolved-locale` to test the results of locale fallback behavior.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n },\n \"format\": {\n \"doc\": \"Returns a `formatted` string for displaying mixed-format text in the `text-field` property. The input may contain a string literal or expression, including an [`'image'`](#types-image) expression. Strings may be followed by a style override object that supports the following properties:\\n- `\\\"text-font\\\"`: Overrides the font stack specified by the root layout property.\\n- `\\\"text-color\\\"`: Overrides the color specified by the root paint property.\\n- `\\\"font-scale\\\"`: Applies a scaling factor on `text-size` as specified by the root layout property.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.48.0\",\n \"android\": \"6.7.0\",\n \"ios\": \"4.6.0\",\n \"macos\": \"0.12.0\"\n },\n \"text-font\": {\n \"js\": \"0.48.0\",\n \"android\": \"6.7.0\",\n \"ios\": \"4.6.0\",\n \"macos\": \"0.12.0\"\n },\n \"font-scale\": {\n \"js\": \"0.48.0\",\n \"android\": \"6.7.0\",\n \"ios\": \"4.6.0\",\n \"macos\": \"0.12.0\"\n },\n \"text-color\": {\n \"js\": \"1.3.0\",\n \"android\": \"7.3.0\",\n \"ios\": \"4.10.0\",\n \"macos\": \"0.14.0\"\n },\n \"image\": {\n \"js\": \"1.6.0\",\n \"android\": \"8.6.0\",\n \"ios\": \"5.7.0\",\n \"macos\": \"0.15.0\"\n }\n }\n },\n \"image\": {\n \"doc\": \"Returns a [`ResolvedImage`](/mapbox-gl-js/style-spec/types/#resolvedimage) for use in [`icon-image`](/mapbox-gl-js/style-spec/layers/#layout-symbol-icon-image), `*-pattern` entries, and as a section in the [`'format'`](#types-format) expression. A [`'coalesce'`](#coalesce) expression containing `image` expressions will evaluate to the first listed image that is currently in the style. This validation process is synchronous and requires the image to have been added to the style before requesting it in the `'image'` argument.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.4.0\",\n \"android\": \"8.6.0\",\n \"ios\": \"5.7.0\",\n \"macos\": \"0.15.0\"\n }\n }\n },\n \"number-format\": {\n \"doc\": \"Converts the input number into a string representation using the providing formatting rules. If set, the `locale` argument specifies the locale to use, as a BCP 47 language tag. If set, the `currency` argument specifies an ISO 4217 code to use for currency-style formatting. If set, the `unit` argument specifies a [simple ECMAScript unit](https://tc39.es/proposal-unified-intl-numberformat/section6/locales-currencies-tz_proposed_out.html#sec-issanctionedsimpleunitidentifier) to use for unit-style formatting. If set, the `min-fraction-digits` and `max-fraction-digits` arguments specify the minimum and maximum number of fractional digits to include.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.54.0\",\n \"android\" : \"8.4.0\",\n \"ios\": \"5.4.0\",\n \"macos\": \"0.15.0\"\n }\n }\n },\n \"to-string\": {\n \"doc\": \"Converts the input value to a string. If the input is `null`, the result is `\\\"\\\"`. If the input is a [`boolean`](#types-boolean), the result is `\\\"true\\\"` or `\\\"false\\\"`. If the input is a number, it is converted to a string as specified by the [\\\"NumberToString\\\" algorithm](https://tc39.github.io/ecma262/#sec-tostring-applied-to-the-number-type) of the ECMAScript Language Specification. If the input is a [`color`](#color), it is converted to a string of the form `\\\"rgba(r,g,b,a)\\\"`, where `r`, `g`, and `b` are numerals ranging from 0 to 255, and `a` ranges from 0 to 1. If the input is an [`'image'`](#types-image) expression, `'to-string'` returns the image name. Otherwise, the input is converted to a string in the format specified by the [`JSON.stringify`](https://tc39.github.io/ecma262/#sec-json.stringify) function of the ECMAScript Language Specification.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"to-number\": {\n \"doc\": \"Converts the input value to a number, if possible. If the input is `null` or `false`, the result is 0. If the input is `true`, the result is 1. If the input is a string, it is converted to a number as specified by the [\\\"ToNumber Applied to the String Type\\\" algorithm](https://tc39.github.io/ecma262/#sec-tonumber-applied-to-the-string-type) of the ECMAScript Language Specification. If multiple values are provided, each one is evaluated in order until the first successful conversion is obtained. If none of the inputs can be converted, the expression is an error.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"to-boolean\": {\n \"doc\": \"Converts the input value to a boolean. The result is `false` when then input is an empty string, 0, `false`, `null`, or `NaN`; otherwise it is `true`.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"to-rgba\": {\n \"doc\": \"Returns a four-element array containing the input color's red, green, blue, and alpha components, in that order.\",\n \"group\": \"Color\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"to-color\": {\n \"doc\": \"Converts the input value to a color. If multiple values are provided, each one is evaluated in order until the first successful conversion is obtained. If none of the inputs can be converted, the expression is an error.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"rgb\": {\n \"doc\": \"Creates a color value from red, green, and blue components, which must range between 0 and 255, and an alpha component of 1. If any component is out of range, the expression is an error.\",\n \"group\": \"Color\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"rgba\": {\n \"doc\": \"Creates a color value from red, green, blue components, which must range between 0 and 255, and an alpha component which must range between 0 and 1. If any component is out of range, the expression is an error.\",\n \"group\": \"Color\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"get\": {\n \"doc\": \"Retrieves a property value from the current feature's properties, or from another object if a second argument is provided. Returns `null` if the requested property is missing.\",\n \"group\": \"Lookup\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"has\": {\n \"doc\": \"Tests for the presence of an property value in the current feature's properties, or from another object if a second argument is provided.\",\n \"group\": \"Lookup\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"length\": {\n \"doc\": \"Returns the length of an array or string.\",\n \"group\": \"Lookup\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"properties\": {\n \"doc\": \"Returns the feature properties object. Note that in some cases, it may be more efficient to use `[\\\"get\\\", \\\"property_name\\\"]` directly.\",\n \"group\": \"Feature data\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"feature-state\": {\n \"doc\": \"Retrieves a property value from the current feature's state. Returns `null` if the requested property is not present on the feature's state. A feature's state is not part of the GeoJSON or vector tile data, and must be set programmatically on each feature. Features are identified by their `id` attribute, which must be an integer or a string that can be cast to an integer. Note that [\\\"feature-state\\\"] can only be used with paint properties that support data-driven styling.\",\n \"group\": \"Feature data\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.46.0\",\n \"android\": \"10.0.0\",\n \"ios\": \"10.0.0\"\n }\n }\n },\n \"geometry-type\": {\n \"doc\": \"Returns the feature's geometry type: `Point`, `LineString` or `Polygon`. `Multi*` feature types return the singular forms.\",\n \"group\": \"Feature data\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"id\": {\n \"doc\": \"Returns the feature's id, if it has one.\",\n \"group\": \"Feature data\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"zoom\": {\n \"doc\": \"Returns the current zoom level. Note that in style layout and paint properties, [\\\"zoom\\\"] may only appear as the input to a top-level \\\"step\\\" or \\\"interpolate\\\" expression.\",\n \"group\": \"Camera\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"pitch\": {\n \"doc\": \"Returns the current pitch in degrees. `[\\\"pitch\\\"]` may only be used in the `filter` expression for a `symbol` layer.\",\n \"group\": \"Camera\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.6.0\",\n \"android\": \"10.9.0\",\n \"ios\": \"10.9.0\"\n }\n }\n },\n \"distance-from-center\": {\n \"doc\": \"Returns the distance of a `symbol` instance from the center of the map. The distance is measured in pixels divided by the height of the map container. It measures 0 at the center, decreases towards the camera and increase away from the camera. For example, if the height of the map is 1000px, a value of -1 means 1000px away from the center towards the camera, and a value of 1 means a distance of 1000px away from the camera from the center. `[\\\"distance-from-center\\\"]` may only be used in the `filter` expression for a `symbol` layer.\",\n \"group\": \"Camera\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.6.0\",\n \"android\": \"10.9.0\",\n \"ios\": \"10.9.0\"\n }\n }\n },\n \"heatmap-density\": {\n \"doc\": \"Returns the kernel density estimation of a pixel in a heatmap layer, which is a relative measure of how many data points are crowded around a particular pixel. Can only be used in the `heatmap-color` property.\",\n \"group\": \"Heatmap\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"line-progress\": {\n \"doc\": \"Returns the progress along a gradient line. Can only be used in the `line-gradient` property.\",\n \"group\": \"Feature data\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.6.0\",\n \"macos\": \"0.12.0\"\n }\n }\n },\n \"sky-radial-progress\": {\n \"doc\": \"Returns the distance of a point on the sky from the sun position. Returns 0 at sun position and 1 when the distance reaches `sky-gradient-radius`. Can only be used in the `sky-gradient` property.\",\n \"group\": \"sky\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n }\n },\n \"accumulated\": {\n \"doc\": \"Returns the value of a cluster property accumulated so far. Can only be used in the `clusterProperties` option of a clustered GeoJSON source.\",\n \"group\": \"Feature data\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.53.0\",\n \"android\": \"8.4.0\",\n \"ios\": \"5.5.0\",\n \"macos\": \"0.15.0\"\n }\n }\n },\n \"+\": {\n \"doc\": \"Returns the sum of the inputs.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"*\": {\n \"doc\": \"Returns the product of the inputs.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"-\": {\n \"doc\": \"For two inputs, returns the result of subtracting the second input from the first. For a single input, returns the result of subtracting it from 0.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"/\": {\n \"doc\": \"Returns the result of floating point division of the first input by the second.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"%\": {\n \"doc\": \"Returns the remainder after integer division of the first input by the second.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"^\": {\n \"doc\": \"Returns the result of raising the first input to the power specified by the second.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"sqrt\": {\n \"doc\": \"Returns the square root of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.42.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"log10\": {\n \"doc\": \"Returns the base-ten logarithm of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"ln\": {\n \"doc\": \"Returns the natural logarithm of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"log2\": {\n \"doc\": \"Returns the base-two logarithm of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"sin\": {\n \"doc\": \"Returns the sine of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"cos\": {\n \"doc\": \"Returns the cosine of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"tan\": {\n \"doc\": \"Returns the tangent of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"asin\": {\n \"doc\": \"Returns the arcsine of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"acos\": {\n \"doc\": \"Returns the arccosine of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"atan\": {\n \"doc\": \"Returns the arctangent of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"min\": {\n \"doc\": \"Returns the minimum value of the inputs.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"max\": {\n \"doc\": \"Returns the maximum value of the inputs.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"round\": {\n \"doc\": \"Rounds the input to the nearest integer. Halfway values are rounded away from zero. For example, `[\\\"round\\\", -1.5]` evaluates to -2.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"abs\": {\n \"doc\": \"Returns the absolute value of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"ceil\": {\n \"doc\": \"Returns the smallest integer that is greater than or equal to the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"floor\": {\n \"doc\": \"Returns the largest integer that is less than or equal to the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"distance\": {\n \"doc\": \"Returns the shortest distance in meters between the evaluated feature and the input geometry. The input value can be a valid GeoJSON of type `Point`, `MultiPoint`, `LineString`, `MultiLineString`, `Polygon`, `MultiPolygon`, `Feature`, or `FeatureCollection`. Distance values returned may vary in precision due to loss in precision from encoding geometries, particularly below zoom level 13.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"android\": \"9.2.0\",\n \"ios\": \"5.9.0\",\n \"macos\": \"0.16.0\"\n }\n }\n },\n \"==\": {\n \"doc\": \"Returns `true` if the input values are equal, `false` otherwise. The comparison is strictly typed: values of different runtime types are always considered unequal. Cases where the types are known to be different at parse time are considered invalid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"collator\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n },\n \"!=\": {\n \"doc\": \"Returns `true` if the input values are not equal, `false` otherwise. The comparison is strictly typed: values of different runtime types are always considered unequal. Cases where the types are known to be different at parse time are considered invalid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"collator\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n },\n \">\": {\n \"doc\": \"Returns `true` if the first input is strictly greater than the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"collator\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n },\n \"<\": {\n \"doc\": \"Returns `true` if the first input is strictly less than the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"collator\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n },\n \">=\": {\n \"doc\": \"Returns `true` if the first input is greater than or equal to the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"collator\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n },\n \"<=\": {\n \"doc\": \"Returns `true` if the first input is less than or equal to the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"collator\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n },\n \"all\": {\n \"doc\": \"Returns `true` if all the inputs are `true`, `false` otherwise. The inputs are evaluated in order, and evaluation is short-circuiting: once an input expression evaluates to `false`, the result is `false` and no further input expressions are evaluated.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"any\": {\n \"doc\": \"Returns `true` if any of the inputs are `true`, `false` otherwise. The inputs are evaluated in order, and evaluation is short-circuiting: once an input expression evaluates to `true`, the result is `true` and no further input expressions are evaluated.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"!\": {\n \"doc\": \"Logical negation. Returns `true` if the input is `false`, and `false` if the input is `true`.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"within\": {\n \"doc\": \"Returns `true` if the evaluated feature is fully contained inside a boundary of the input geometry, `false` otherwise. The input value can be a valid GeoJSON of type `Polygon`, `MultiPolygon`, `Feature`, or `FeatureCollection`. Supported features for evaluation:\\n- `Point`: Returns `false` if a point is on the boundary or falls outside the boundary.\\n- `LineString`: Returns `false` if any part of a line falls outside the boundary, the line intersects the boundary, or a line's endpoint is on the boundary.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.9.0\",\n \"android\": \"9.1.0\",\n \"ios\": \"5.8.0\",\n \"macos\": \"0.15.0\"\n }\n }\n },\n \"is-supported-script\": {\n \"doc\": \"Returns `true` if the input string is expected to render legibly. Returns `false` if the input string contains sections that cannot be rendered without potential loss of meaning (e.g. Indic scripts that require complex text shaping, or right-to-left scripts if the the `mapbox-gl-rtl-text` plugin is not in use in Mapbox GL JS).\",\n \"group\": \"String\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.6.0\",\n \"ios\": \"4.1.0\",\n \"macos\": \"0.8.0\"\n }\n }\n },\n \"upcase\": {\n \"doc\": \"Returns the input string converted to uppercase. Follows the Unicode Default Case Conversion algorithm and the locale-insensitive case mappings in the Unicode Character Database.\",\n \"group\": \"String\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"downcase\": {\n \"doc\": \"Returns the input string converted to lowercase. Follows the Unicode Default Case Conversion algorithm and the locale-insensitive case mappings in the Unicode Character Database.\",\n \"group\": \"String\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"concat\": {\n \"doc\": \"Returns a `string` consisting of the concatenation of the inputs. Each input is converted to a string as if by `to-string`.\",\n \"group\": \"String\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"resolved-locale\": {\n \"doc\": \"Returns the IETF language tag of the locale being used by the provided `collator`. This can be used to determine the default system locale, or to determine if a requested locale was successfully loaded.\",\n \"group\": \"String\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n }\n }\n },\n \"fog\": {\n \"range\": {\n \"type\": \"array\",\n \"default\": [\n 0.5,\n 10\n ],\n \"minimum\": -20,\n \"maximum\": 20,\n \"length\": 2,\n \"value\": \"number\",\n \"property-type\": \"data-constant\",\n \"transition\": true,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"doc\": \"The start and end distance range in which fog fades from fully transparent to fully opaque. The distance to the point at the center of the map is defined as zero, so that negative range values are closer to the camera, and positive values are farther away.\",\n \"example\": [\n 0.5,\n 10\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.3.0\",\n \"android\": \"10.6.0\",\n \"ios\": \"10.6.0\"\n }\n }\n },\n \"color\": {\n \"type\": \"color\",\n \"property-type\": \"data-constant\",\n \"default\": \"#ffffff\",\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"The color of the atmosphere region immediately below the horizon and within the `range` and above the horizon and within `horizon-blend`. Using opacity is recommended only for smoothly transitioning fog on/off as anything less than 100% opacity results in more tiles loaded and drawn.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.3.0\",\n \"android\": \"10.6.0\",\n \"ios\": \"10.6.0\"\n }\n }\n },\n \"high-color\": {\n \"type\": \"color\",\n \"property-type\": \"data-constant\",\n \"default\": \"#245cdf\",\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"The color of the atmosphere region above the horizon, `high-color` extends further above the horizon than the `color` property and its spread can be controlled with `horizon-blend`. The opacity can be set to `0` to remove the high atmosphere color contribution.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.9.0\",\n \"android\": \"10.6.0\",\n \"ios\": \"10.6.0\"\n }\n }\n },\n \"space-color\": {\n \"type\": \"color\",\n \"property-type\": \"data-constant\",\n\n \"default\":\n [\n \"interpolate\",\n [\n \"linear\"\n ],\n [\n \"zoom\"\n ],\n 4,\n \"#010b19\",\n 7,\n \"#367ab9\"\n ],\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"The color of the region above the horizon and after the end of the `horizon-blend` contribution. The opacity can be set to `0` to have a transparent background.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.9.0\",\n \"android\": \"10.6.0\",\n \"ios\": \"10.6.0\"\n }\n }\n },\n \"horizon-blend\": {\n \"type\": \"number\",\n \"property-type\": \"data-constant\",\n \"default\":\n [\n \"interpolate\",\n [\n \"linear\"\n ],\n [\n \"zoom\"\n ],\n 4,\n 0.2,\n 7,\n 0.1\n ],\n \"minimum\": 0,\n \"maximum\": 1,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"Horizon blend applies a smooth fade from the color of the atmosphere to the color of space. A value of zero leaves a sharp transition from atmosphere to space. Increasing the value blends the color of atmosphere into increasingly high angles of the sky.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.3.0\",\n \"android\": \"10.6.0\",\n \"ios\": \"10.6.0\"\n }\n }\n },\n \"star-intensity\": {\n \"type\": \"number\",\n \"property-type\": \"data-constant\",\n \"default\":\n [\n \"interpolate\",\n [\n \"linear\"\n ],\n [\n \"zoom\"\n ],\n 5,\n 0.35,\n 6,\n 0\n ],\n \"minimum\": 0,\n \"maximum\": 1,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"A value controlling the star intensity where `0` will show no stars and `1` will show stars at their maximum intensity.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.9.0\",\n \"android\": \"10.6.0\",\n \"ios\": \"10.6.0\"\n }\n }\n }\n },\n \"light\": {\n \"anchor\": {\n \"type\": \"enum\",\n \"default\": \"viewport\",\n \"values\": {\n \"map\": {\n \"doc\": \"The position of the light source is aligned to the rotation of the map.\"\n },\n \"viewport\": {\n \"doc\": \"The position of the light source is aligned to the rotation of the viewport.\"\n }\n },\n \"property-type\": \"data-constant\",\n \"transition\": false,\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"doc\": \"Whether extruded geometries are lit relative to the map or viewport.\",\n \"example\": \"map\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n }\n },\n \"position\": {\n \"type\": \"array\",\n \"default\": [\n 1.15,\n 210,\n 30\n ],\n \"length\": 3,\n \"value\": \"number\",\n \"property-type\": \"data-constant\",\n \"transition\": true,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"doc\": \"Position of the light source relative to lit (extruded) geometries, in [r radial coordinate, a azimuthal angle, p polar angle] where r indicates the distance from the center of the base of an object to its light, a indicates the position of the light relative to 0° (0° when `light.anchor` is set to `viewport` corresponds to the top of the viewport, or 0° when `light.anchor` is set to `map` corresponds to due north, and degrees proceed clockwise), and p indicates the height of the light (from 0°, directly above, to 180°, directly below).\",\n \"example\": [\n 1.5,\n 90,\n 80\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n }\n },\n \"color\": {\n \"type\": \"color\",\n \"property-type\": \"data-constant\",\n \"default\": \"#ffffff\",\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"Color tint for lighting extruded geometries.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n }\n },\n \"intensity\": {\n \"type\": \"number\",\n \"property-type\": \"data-constant\",\n \"default\": 0.5,\n \"minimum\": 0,\n \"maximum\": 1,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"Intensity of lighting (on a scale from 0 to 1). Higher numbers will present as more extreme contrast.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n }\n }\n },\n \"projection\": {\n \"name\": {\n \"type\": \"enum\",\n \"values\": {\n \"albers\": {\n \"doc\": \"An Albers equal-area projection centered on the continental United States. You can configure the projection for a different region by setting `center` and `parallels` properties. You may want to set max bounds to constrain the map to the relevant region.\"\n },\n \"equalEarth\": {\n \"doc\": \"An Equal Earth projection.\"\n },\n \"equirectangular\": {\n \"doc\": \"An Equirectangular projection. This projection is very similar to the Plate Carrée projection.\"\n },\n \"lambertConformalConic\": {\n \"doc\": \"A Lambert conformal conic projection. You can configure the projection for a region by setting `center` and `parallels` properties. You may want to set max bounds to constrain the map to the relevant region.\"\n },\n \"mercator\": {\n \"doc\": \"The Mercator projection is the default projection.\"\n },\n \"naturalEarth\": {\n \"doc\": \"A Natural Earth projection.\"\n },\n \"winkelTripel\": {\n \"doc\": \"A Winkel Tripel projection.\"\n },\n \"globe\": {\n \"doc\": \"A globe projection.\"\n }\n },\n \"default\": \"mercator\",\n \"doc\": \"The name of the projection to be used for rendering the map.\",\n \"required\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.6.0\"\n }\n }\n },\n \"center\": {\n \"type\": \"array\",\n \"length\": 2,\n \"value\": \"number\",\n \"property-type\": \"data-constant\",\n \"minimum\": [-180, -90],\n \"maximum\": [180, 90],\n \"transition\": false,\n \"doc\": \"The reference longitude and latitude of the projection. `center` takes the form of [lng, lat]. This property is only configurable for conic projections (Albers and Lambert Conformal Conic). All other projections are centered on [0, 0].\",\n \"example\": [\n -96,\n 37.5\n ],\n \"requires\": [\n {\n \"name\": [\n \"albers\",\n \"lambertConformalConic\"\n ]\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.6.0\"\n }\n }\n },\n \"parallels\": {\n \"type\": \"array\",\n \"length\": 2,\n \"value\": \"number\",\n \"property-type\": \"data-constant\",\n \"minimum\": [-90, -90],\n \"maximum\": [90, 90],\n \"transition\": false,\n \"doc\": \"The standard parallels of the projection, denoting the desired latitude range with minimal distortion. `parallels` takes the form of [lat0, lat1]. This property is only configurable for conic projections (Albers and Lambert Conformal Conic).\",\n \"example\": [\n 29.5,\n 45.5\n ],\n \"requires\": [\n {\n \"name\": [\n \"albers\",\n \"lambertConformalConic\"\n ]\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.6.0\"\n }\n }\n }\n },\n \"terrain\" : {\n \"source\": {\n \"type\": \"string\",\n \"doc\": \"Name of a source of `raster_dem` type to be used for terrain elevation.\",\n \"required\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n }\n },\n \"exaggeration\": {\n \"type\": \"number\",\n \"property-type\": \"data-constant\",\n \"default\": 1.0,\n \"minimum\": 0,\n \"maximum\": 1000,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"Exaggerates the elevation of the terrain by multiplying the data from the DEM with this value.\",\n \"requires\": [\n \"source\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n }\n }\n },\n \"paint\": [\n \"paint_fill\",\n \"paint_line\",\n \"paint_circle\",\n \"paint_heatmap\",\n \"paint_fill-extrusion\",\n \"paint_symbol\",\n \"paint_raster\",\n \"paint_hillshade\",\n \"paint_background\",\n \"paint_sky\"\n ],\n \"paint_fill\": {\n \"fill-antialias\": {\n \"type\": \"boolean\",\n \"default\": true,\n \"doc\": \"Whether or not the fill should be antialiased.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"fill-opacity\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"doc\": \"The opacity of the entire fill layer. In contrast to the `fill-color`, this value will also affect the 1px stroke around the fill, if the stroke is used.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.21.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"fill-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"doc\": \"The color of the filled part of this layer. This color can be specified as `rgba` with an alpha component and the color's opacity will not affect the opacity of the 1px stroke, if it is used.\",\n \"transition\": true,\n \"requires\": [\n {\n \"!\": \"fill-pattern\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.19.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"fill-outline-color\": {\n \"type\": \"color\",\n \"doc\": \"The outline color of the fill. Matches the value of `fill-color` if unspecified.\",\n \"transition\": true,\n \"requires\": [\n {\n \"!\": \"fill-pattern\"\n },\n {\n \"fill-antialias\": true\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.19.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"fill-translate\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"The geometry's offset. Values are [x, y] where negatives indicate left and up, respectively.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"fill-translate-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The fill is translated relative to the map.\"\n },\n \"viewport\": {\n \"doc\": \"The fill is translated relative to the viewport.\"\n }\n },\n \"doc\": \"Controls the frame of reference for `fill-translate`.\",\n \"default\": \"map\",\n \"requires\": [\n \"fill-translate\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"fill-pattern\": {\n \"type\": \"resolvedImage\",\n \"transition\": false,\n \"doc\": \"Name of image in sprite to use for drawing image fills. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.49.0\",\n \"android\": \"6.5.0\",\n \"macos\": \"0.11.0\",\n \"ios\": \"4.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n }\n },\n \"paint_fill-extrusion\": {\n \"fill-extrusion-opacity\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"doc\": \"The opacity of the entire fill extrusion layer. This is rendered on a per-layer, not per-feature, basis, and data-driven styling is not available.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"fill-extrusion-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"doc\": \"The base color of the extruded fill. The extrusion's surfaces will be shaded differently based on this color in combination with the root `light` settings. If this color is specified as `rgba` with an alpha component, the alpha component will be ignored; use `fill-extrusion-opacity` to set layer opacity.\",\n \"transition\": true,\n \"requires\": [\n {\n \"!\": \"fill-extrusion-pattern\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"fill-extrusion-translate\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"The geometry's offset. Values are [x, y] where negatives indicate left and up (on the flat plane), respectively.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"fill-extrusion-translate-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The fill extrusion is translated relative to the map.\"\n },\n \"viewport\": {\n \"doc\": \"The fill extrusion is translated relative to the viewport.\"\n }\n },\n \"doc\": \"Controls the frame of reference for `fill-extrusion-translate`.\",\n \"default\": \"map\",\n \"requires\": [\n \"fill-extrusion-translate\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"fill-extrusion-pattern\": {\n \"type\": \"resolvedImage\",\n \"transition\": false,\n \"doc\": \"Name of image in sprite to use for drawing images on extruded fills. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.49.0\",\n \"android\": \"6.5.0\",\n \"macos\": \"0.11.0\",\n \"ios\": \"4.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"fill-extrusion-height\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"units\": \"meters\",\n \"doc\": \"The height with which to extrude this layer.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"fill-extrusion-base\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"units\": \"meters\",\n \"doc\": \"The height with which to extrude the base of this layer. Must be less than or equal to `fill-extrusion-height`.\",\n \"transition\": true,\n \"requires\": [\n \"fill-extrusion-height\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"fill-extrusion-vertical-gradient\": {\n \"type\": \"boolean\",\n \"default\": true,\n \"doc\": \"Whether to apply a vertical gradient to the sides of a fill-extrusion layer. If true, sides will be shaded slightly darker farther down.\",\n \"transition\": false,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.50.0\",\n \"android\": \"7.0.0\",\n \"ios\": \"4.7.0\",\n \"macos\": \"0.13.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"fill-extrusion-ambient-occlusion-intensity\": {\n \"property-type\": \"data-constant\",\n \"type\": \"number\",\n \"private\": true,\n \"default\": 0.0,\n \"minimum\": 0,\n \"maximum\": 1,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"Controls the intensity of shading near ground and concave angles between walls. Default value 0.0 disables ambient occlusion and values around 0.3 provide the most plausible results for buildings.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.10.0\",\n \"android\": \"10.7.0\",\n \"ios\": \"10.7.0\"\n }\n }\n },\n \"fill-extrusion-ambient-occlusion-radius\": {\n \"property-type\": \"data-constant\",\n \"type\": \"number\",\n \"private\": true,\n \"default\": 3.0,\n \"minimum\": 0,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"Shades area near ground and concave angles between walls where the radius defines only vertical impact. Default value 3.0 corresponds to height of one floor and brings the most plausible results for buildings.\",\n \"requires\": [\n \"fill-extrusion-edge-radius\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.10.0\",\n \"android\": \"10.7.0\",\n \"ios\": \"10.7.0\"\n }\n }\n }\n },\n \"paint_line\": {\n \"line-opacity\": {\n \"type\": \"number\",\n \"doc\": \"The opacity at which the line will be drawn.\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-color\": {\n \"type\": \"color\",\n \"doc\": \"The color with which the line will be drawn.\",\n \"default\": \"#000000\",\n \"transition\": true,\n \"requires\": [\n {\n \"!\": \"line-pattern\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.23.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-translate\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"The geometry's offset. Values are [x, y] where negatives indicate left and up, respectively.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"line-translate-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The line is translated relative to the map.\"\n },\n \"viewport\": {\n \"doc\": \"The line is translated relative to the viewport.\"\n }\n },\n \"doc\": \"Controls the frame of reference for `line-translate`.\",\n \"default\": \"map\",\n \"requires\": [\n \"line-translate\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"line-width\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Stroke thickness.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.39.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-gap-width\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"doc\": \"Draws a line casing outside of a line's actual path. Value indicates the width of the inner gap.\",\n \"transition\": true,\n \"units\": \"pixels\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-offset\": {\n \"type\": \"number\",\n \"default\": 0,\n \"doc\": \"The line's offset. For linear features, a positive value offsets the line to the right, relative to the direction of the line, and a negative value to the left. For polygon features, a positive value results in an inset, and a negative value results in an outset.\",\n \"transition\": true,\n \"units\": \"pixels\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.12.1\",\n \"android\": \"3.0.0\",\n \"ios\": \"3.1.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-blur\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Blur applied to the line, in pixels.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-dasharray\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"doc\": \"Specifies the lengths of the alternating dashes and gaps that form the dash pattern. The lengths are later scaled by the line width. To convert a dash length to pixels, multiply the length by the current line width. Note that GeoJSON sources with `lineMetrics: true` specified won't render dashed lines to the expected scale. Also note that zoom-dependent expressions will be evaluated only at integer zoom levels.\",\n \"minimum\": 0,\n \"transition\": false,\n \"units\": \"line widths\",\n \"requires\": [\n {\n \"!\": \"line-pattern\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"2.3.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-pattern\": {\n \"type\": \"resolvedImage\",\n \"transition\": false,\n \"doc\": \"Name of image in sprite to use for drawing image lines. For seamless patterns, image width must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.49.0\",\n \"android\": \"6.5.0\",\n \"macos\": \"0.11.0\",\n \"ios\": \"4.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-gradient\": {\n \"type\": \"color\",\n \"doc\": \"Defines a gradient with which to color a line feature. Can only be used with GeoJSON sources that specify `\\\"lineMetrics\\\": true`.\",\n \"transition\": false,\n \"requires\": [\n {\n \"!\": \"line-pattern\"\n },\n {\n \"source\": \"geojson\",\n \"has\": {\n \"lineMetrics\": true\n }\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.4.0\",\n \"macos\": \"0.11.0\"\n },\n \"data-driven styling\": {}\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"line-progress\"\n ]\n },\n \"property-type\": \"color-ramp\"\n },\n \"line-trim-offset\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"doc\": \"The line part between [trim-start, trim-end] will be marked as transparent to make a route vanishing effect. The line trim-off offset is based on the whole line range [0.0, 1.0].\",\n \"length\": 2,\n \"default\": [0.0, 0.0],\n \"minimum\": [0.0, 0.0],\n \"maximum\": [1.0, 1.0],\n \"transition\": false,\n \"requires\": [\n {\n \"source\": \"geojson\",\n \"has\": {\n \"lineMetrics\": true\n }\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.9.0\",\n \"android\": \"10.5.0\",\n \"ios\": \"10.5.0\",\n \"macos\": \"10.5.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"paint_circle\": {\n \"circle-radius\": {\n \"type\": \"number\",\n \"default\": 5,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Circle radius.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.18.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"circle-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"doc\": \"The fill color of the circle.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.18.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"circle-blur\": {\n \"type\": \"number\",\n \"default\": 0,\n \"doc\": \"Amount to blur the circle. 1 blurs the circle such that only the centerpoint is full opacity.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.20.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"circle-opacity\": {\n \"type\": \"number\",\n \"doc\": \"The opacity at which the circle will be drawn.\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.20.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"circle-translate\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"The geometry's offset. Values are [x, y] where negatives indicate left and up, respectively.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"circle-translate-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The circle is translated relative to the map.\"\n },\n \"viewport\": {\n \"doc\": \"The circle is translated relative to the viewport.\"\n }\n },\n \"doc\": \"Controls the frame of reference for `circle-translate`.\",\n \"default\": \"map\",\n \"requires\": [\n \"circle-translate\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"circle-pitch-scale\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"Circles are scaled according to their apparent distance to the camera.\"\n },\n \"viewport\": {\n \"doc\": \"Circles are not scaled.\"\n }\n },\n \"default\": \"map\",\n \"doc\": \"Controls the scaling behavior of the circle when the map is pitched.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.21.0\",\n \"android\": \"4.2.0\",\n \"ios\": \"3.4.0\",\n \"macos\": \"0.2.1\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"circle-pitch-alignment\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The circle is aligned to the plane of the map.\"\n },\n \"viewport\": {\n \"doc\": \"The circle is aligned to the plane of the viewport.\"\n }\n },\n \"default\": \"viewport\",\n \"doc\": \"Orientation of circle when map is pitched.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.39.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"circle-stroke-width\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"The width of the circle's stroke. Strokes are placed outside of the `circle-radius`.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"circle-stroke-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"doc\": \"The stroke color of the circle.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"circle-stroke-opacity\": {\n \"type\": \"number\",\n \"doc\": \"The opacity of the circle's stroke.\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n }\n },\n \"paint_heatmap\": {\n \"heatmap-radius\": {\n \"type\": \"number\",\n \"default\": 30,\n \"minimum\": 1,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Radius of influence of one heatmap point in pixels. Increasing the value makes the heatmap smoother, but less detailed. `queryRenderedFeatures` on heatmap layers will return points within this radius.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"heatmap-weight\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"transition\": false,\n \"doc\": \"A measure of how much an individual point contributes to the heatmap. A value of 10 would be equivalent to having 10 points of weight 1 in the same spot. Especially useful when combined with clustering.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"heatmap-intensity\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"transition\": true,\n \"doc\": \"Similar to `heatmap-weight` but controls the intensity of the heatmap globally. Primarily used for adjusting the heatmap based on zoom level.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"heatmap-color\": {\n \"type\": \"color\",\n \"default\": [\n \"interpolate\",\n [\n \"linear\"\n ],\n [\n \"heatmap-density\"\n ],\n 0,\n \"rgba(0, 0, 255, 0)\",\n 0.1,\n \"royalblue\",\n 0.3,\n \"cyan\",\n 0.5,\n \"lime\",\n 0.7,\n \"yellow\",\n 1,\n \"red\"\n ],\n \"doc\": \"Defines the color of each pixel based on its density value in a heatmap. Should be an expression that uses `[\\\"heatmap-density\\\"]` as input.\",\n \"transition\": false,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"data-driven styling\": {}\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"heatmap-density\"\n ]\n },\n \"property-type\": \"color-ramp\"\n },\n \"heatmap-opacity\": {\n \"type\": \"number\",\n \"doc\": \"The global opacity at which the heatmap layer will be drawn.\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n }\n },\n \"paint_symbol\": {\n \"icon-opacity\": {\n \"doc\": \"The opacity at which the icon will be drawn.\",\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"transition\": true,\n \"doc\": \"The color of the icon. This can only be used with [SDF icons](/help/troubleshooting/using-recolorable-images-in-mapbox-maps/).\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-halo-color\": {\n \"type\": \"color\",\n \"default\": \"rgba(0, 0, 0, 0)\",\n \"transition\": true,\n \"doc\": \"The color of the icon's halo. Icon halos can only be used with [SDF icons](/help/troubleshooting/using-recolorable-images-in-mapbox-maps/).\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-halo-width\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Distance of halo to the icon outline.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-halo-blur\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Fade out the halo towards the outside.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-translate\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Distance that the icon's anchor is moved from its original placement. Positive values indicate right and down, while negative values indicate left and up.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-translate-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"Icons are translated relative to the map.\"\n },\n \"viewport\": {\n \"doc\": \"Icons are translated relative to the viewport.\"\n }\n },\n \"doc\": \"Controls the frame of reference for `icon-translate`.\",\n \"default\": \"map\",\n \"requires\": [\n \"icon-image\",\n \"icon-translate\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-opacity\": {\n \"type\": \"number\",\n \"doc\": \"The opacity at which the text will be drawn.\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-color\": {\n \"type\": \"color\",\n \"doc\": \"The color with which the text will be drawn.\",\n \"default\": \"#000000\",\n \"transition\": true,\n \"overridable\": true,\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-halo-color\": {\n \"type\": \"color\",\n \"default\": \"rgba(0, 0, 0, 0)\",\n \"transition\": true,\n \"doc\": \"The color of the text's halo, which helps it stand out from backgrounds.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-halo-width\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Distance of halo to the font outline. Max text halo width is 1/4 of the font-size.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-halo-blur\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"The halo's fadeout distance towards the outside.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-translate\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Distance that the text's anchor is moved from its original placement. Positive values indicate right and down, while negative values indicate left and up.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-translate-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The text is translated relative to the map.\"\n },\n \"viewport\": {\n \"doc\": \"The text is translated relative to the viewport.\"\n }\n },\n \"doc\": \"Controls the frame of reference for `text-translate`.\",\n \"default\": \"map\",\n \"requires\": [\n \"text-field\",\n \"text-translate\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n }\n },\n \"paint_raster\": {\n \"raster-opacity\": {\n \"type\": \"number\",\n \"doc\": \"The opacity at which the image will be drawn.\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"raster-hue-rotate\": {\n \"type\": \"number\",\n \"default\": 0,\n \"period\": 360,\n \"transition\": true,\n \"units\": \"degrees\",\n \"doc\": \"Rotates hues around the color wheel.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"raster-brightness-min\": {\n \"type\": \"number\",\n \"doc\": \"Increase or reduce the brightness of the image. The value is the minimum brightness.\",\n \"default\": 0,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"raster-brightness-max\": {\n \"type\": \"number\",\n \"doc\": \"Increase or reduce the brightness of the image. The value is the maximum brightness.\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"raster-saturation\": {\n \"type\": \"number\",\n \"doc\": \"Increase or reduce the saturation of the image.\",\n \"default\": 0,\n \"minimum\": -1,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"raster-contrast\": {\n \"type\": \"number\",\n \"doc\": \"Increase or reduce the contrast of the image.\",\n \"default\": 0,\n \"minimum\": -1,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"raster-resampling\": {\n \"type\": \"enum\",\n \"doc\": \"The resampling/interpolation method to use for overscaling, also known as texture magnification filter\",\n \"values\": {\n \"linear\": {\n \"doc\": \"(Bi)linear filtering interpolates pixel values using the weighted average of the four closest original source pixels creating a smooth but blurry look when overscaled\"\n },\n \"nearest\": {\n \"doc\": \"Nearest neighbor filtering interpolates pixel values using the nearest original source pixel creating a sharp but pixelated look when overscaled\"\n }\n },\n \"default\": \"linear\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.47.0\",\n \"android\": \"6.3.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"raster-fade-duration\": {\n \"type\": \"number\",\n \"default\": 300,\n \"minimum\": 0,\n \"transition\": false,\n \"units\": \"milliseconds\",\n \"doc\": \"Fade duration when a new tile is added.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n }\n },\n \"paint_hillshade\": {\n \"hillshade-illumination-direction\": {\n \"type\": \"number\",\n \"default\": 335,\n \"minimum\": 0,\n \"maximum\": 359,\n \"doc\": \"The direction of the light source used to generate the hillshading with 0 as the top of the viewport if `hillshade-illumination-anchor` is set to `viewport` and due north if `hillshade-illumination-anchor` is set to `map`.\",\n \"transition\": false,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"hillshade-illumination-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The hillshade illumination is relative to the north direction.\"\n },\n \"viewport\": {\n \"doc\": \"The hillshade illumination is relative to the top of the viewport.\"\n }\n },\n \"default\": \"viewport\",\n \"doc\": \"Direction of light source when map is rotated.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"hillshade-exaggeration\": {\n \"type\": \"number\",\n \"doc\": \"Intensity of the hillshade\",\n \"default\": 0.5,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"hillshade-shadow-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"doc\": \"The shading color of areas that face away from the light source.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"hillshade-highlight-color\": {\n \"type\": \"color\",\n \"default\": \"#FFFFFF\",\n \"doc\": \"The shading color of areas that faces towards the light source.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"hillshade-accent-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"doc\": \"The shading color used to accentuate rugged terrain like sharp cliffs and gorges.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n }\n },\n \"paint_background\": {\n \"background-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"doc\": \"The color with which the background will be drawn.\",\n \"transition\": true,\n \"requires\": [\n {\n \"!\": \"background-pattern\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"background-pattern\": {\n \"type\": \"resolvedImage\",\n \"transition\": false,\n \"doc\": \"Name of image in sprite to use for drawing an image background. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"background-opacity\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"doc\": \"The opacity at which the background will be drawn.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n }\n },\n \"paint_sky\": {\n \"sky-type\": {\n \"type\": \"enum\",\n \"values\": {\n \"gradient\": {\n \"doc\": \"Renders the sky with a gradient that can be configured with `sky-gradient-radius` and `sky-gradient`.\"\n },\n \"atmosphere\": {\n \"doc\": \"Renders the sky with a simulated atmospheric scattering algorithm, the sun direction can be attached to the light position or explicitly set through `sky-atmosphere-sun`.\"\n }\n },\n \"default\": \"atmosphere\",\n \"doc\": \"The type of the sky\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"sky-atmosphere-sun\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"units\": \"degrees\",\n \"minimum\": [0, 0],\n \"maximum\": [360, 180],\n \"transition\": false,\n \"doc\": \"Position of the sun center [a azimuthal angle, p polar angle]. The azimuthal angle indicates the position of the sun relative to 0° north, where degrees proceed clockwise. The polar angle indicates the height of the sun, where 0° is directly above, at zenith, and 90° at the horizon. When this property is ommitted, the sun center is directly inherited from the light position.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"requires\": [\n {\n \"sky-type\": \"atmosphere\"\n }\n ],\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"sky-atmosphere-sun-intensity\": {\n \"type\": \"number\",\n \"requires\": [\n {\n \"sky-type\": \"atmosphere\"\n }\n ],\n \"default\": 10,\n \"minimum\": 0,\n \"maximum\": 100,\n \"transition\": false,\n \"doc\": \"Intensity of the sun as a light source in the atmosphere (on a scale from 0 to a 100). Setting higher values will brighten up the sky.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"property-type\": \"data-constant\"\n },\n \"sky-gradient-center\": {\n \"type\": \"array\",\n \"requires\": [\n {\n \"sky-type\": \"gradient\"\n }\n ],\n \"value\": \"number\",\n \"default\": [\n 0,\n 0\n ],\n \"length\": 2,\n \"units\": \"degrees\",\n \"minimum\": [0, 0],\n \"maximum\": [360, 180],\n \"transition\": false,\n \"doc\": \"Position of the gradient center [a azimuthal angle, p polar angle]. The azimuthal angle indicates the position of the gradient center relative to 0° north, where degrees proceed clockwise. The polar angle indicates the height of the gradient center, where 0° is directly above, at zenith, and 90° at the horizon.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"sky-gradient-radius\": {\n \"type\": \"number\",\n \"requires\": [\n {\n \"sky-type\": \"gradient\"\n }\n ],\n \"default\": 90,\n \"minimum\": 0,\n \"maximum\": 180,\n \"transition\": false,\n \"doc\": \"The angular distance (measured in degrees) from `sky-gradient-center` up to which the gradient extends. A value of 180 causes the gradient to wrap around to the opposite direction from `sky-gradient-center`.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"sky-gradient\": {\n \"type\": \"color\",\n \"default\": [\n \"interpolate\",\n [\n \"linear\"\n ],\n [\n \"sky-radial-progress\"\n ],\n 0.8,\n \"#87ceeb\",\n 1,\n \"white\"\n ],\n \"doc\": \"Defines a radial color gradient with which to color the sky. The color values can be interpolated with an expression using `sky-radial-progress`. The range [0, 1] for the interpolant covers a radial distance (in degrees) of [0, `sky-gradient-radius`] centered at the position specified by `sky-gradient-center`.\",\n \"transition\": false,\n \"requires\": [\n {\n \"sky-type\": \"gradient\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n },\n \"data-driven styling\": {}\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"sky-radial-progress\"\n ]\n },\n \"property-type\": \"color-ramp\"\n },\n \"sky-atmosphere-halo-color\": {\n \"type\": \"color\",\n \"default\": \"white\",\n \"doc\": \"A color applied to the atmosphere sun halo. The alpha channel describes how strongly the sun halo is represented in an atmosphere sky layer.\",\n \"transition\": false,\n \"requires\": [\n {\n \"sky-type\": \"atmosphere\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"property-type\": \"data-constant\"\n },\n \"sky-atmosphere-color\": {\n \"type\": \"color\",\n \"default\": \"white\",\n \"doc\": \"A color used to tweak the main atmospheric scattering coefficients. Using white applies the default coefficients giving the natural blue color to the atmosphere. This color affects how heavily the corresponding wavelength is represented during scattering. The alpha channel describes the density of the atmosphere, with 1 maximum density and 0 no density.\",\n \"transition\": false,\n \"requires\": [\n {\n \"sky-type\": \"atmosphere\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"property-type\": \"data-constant\"\n },\n \"sky-opacity\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"doc\": \"The opacity of the entire sky layer.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n }\n },\n \"transition\": {\n \"duration\": {\n \"type\": \"number\",\n \"default\": 300,\n \"minimum\": 0,\n \"units\": \"milliseconds\",\n \"doc\": \"Time allotted for transitions to complete.\"\n },\n \"delay\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"units\": \"milliseconds\",\n \"doc\": \"Length of time before a transition begins.\"\n }\n },\n \"property-type\": {\n \"data-driven\": {\n \"type\": \"property-type\",\n \"doc\": \"Property is interpolable and can be represented using a property expression.\"\n },\n \"color-ramp\": {\n \"type\": \"property-type\",\n \"doc\": \"Property should be specified using a color ramp from which the output color can be sampled based on a property calculation.\"\n },\n \"data-constant\": {\n \"type\": \"property-type\",\n \"doc\": \"Property is interpolable but cannot be represented using a property expression.\"\n },\n \"constant\": {\n \"type\": \"property-type\",\n \"doc\": \"Property is constant across all zoom levels and property values.\"\n }\n },\n \"promoteId\": {\n \"*\": {\n \"type\": \"string\",\n \"doc\": \"A name of a feature property to use as ID for feature state.\"\n }\n }\n}\n","// @flow\n\nimport {createExpression} from '../expression/index.js';\nimport {isFeatureConstant} from '../expression/is_constant.js';\nimport {deepUnbundle} from '../util/unbundle_jsonlint.js';\nimport latest from '../reference/latest.js';\nimport type {GlobalProperties, Feature} from '../expression/index.js';\nimport type {CanonicalTileID} from '../../source/tile_id.js';\nimport type Point from '@mapbox/point-geometry';\n\nexport type FeatureDistanceData = {bearing: [number, number], center: [number, number], scale: number};\nexport type FilterExpression = (globalProperties: GlobalProperties, feature: Feature, canonical?: CanonicalTileID, featureTileCoord?: Point, featureDistanceData?: FeatureDistanceData) => boolean;\nexport type FeatureFilter = {filter: FilterExpression, dynamicFilter?: FilterExpression, needGeometry: boolean, needFeature: boolean};\n\nexport default createFilter;\nexport {isExpressionFilter, isDynamicFilter, extractStaticFilter};\n\nfunction isExpressionFilter(filter: any): boolean {\n if (filter === true || filter === false) {\n return true;\n }\n\n if (!Array.isArray(filter) || filter.length === 0) {\n return false;\n }\n switch (filter[0]) {\n case 'has':\n return filter.length >= 2 && filter[1] !== '$id' && filter[1] !== '$type';\n\n case 'in':\n return filter.length >= 3 && (typeof filter[1] !== 'string' || Array.isArray(filter[2]));\n\n case '!in':\n case '!has':\n case 'none':\n return false;\n\n case '==':\n case '!=':\n case '>':\n case '>=':\n case '<':\n case '<=':\n return filter.length !== 3 || (Array.isArray(filter[1]) || Array.isArray(filter[2]));\n\n case 'any':\n case 'all':\n for (const f of filter.slice(1)) {\n if (!isExpressionFilter(f) && typeof f !== 'boolean') {\n return false;\n }\n }\n return true;\n\n default:\n return true;\n }\n}\n\n/**\n * Given a filter expressed as nested arrays, return a new function\n * that evaluates whether a given feature (with a .properties or .tags property)\n * passes its test.\n *\n * @private\n * @param {Array} filter mapbox gl filter\n * @param {string} layerType the type of the layer this filter will be applied to.\n * @returns {Function} filter-evaluating function\n */\nfunction createFilter(filter: any, layerType?: string = 'fill'): FeatureFilter {\n if (filter === null || filter === undefined) {\n return {filter: () => true, needGeometry: false, needFeature: false};\n }\n\n if (!isExpressionFilter(filter)) {\n filter = convertFilter(filter);\n }\n const filterExp = ((filter: any): string[] | string | boolean);\n\n let staticFilter = true;\n try {\n staticFilter = extractStaticFilter(filterExp);\n } catch (e) {\n console.warn(\n`Failed to extract static filter. Filter will continue working, but at higher memory usage and slower framerate.\nThis is most likely a bug, please report this via https://github.com/mapbox/mapbox-gl-js/issues/new?assignees=&labels=&template=Bug_report.md\nand paste the contents of this message in the report.\nThank you!\nFilter Expression:\n${JSON.stringify(filterExp, null, 2)}\n `);\n }\n\n // Compile the static component of the filter\n const filterSpec = latest[`filter_${layerType}`];\n const compiledStaticFilter = createExpression(staticFilter, filterSpec);\n\n let filterFunc = null;\n if (compiledStaticFilter.result === 'error') {\n throw new Error(compiledStaticFilter.value.map(err => `${err.key}: ${err.message}`).join(', '));\n } else {\n filterFunc = (globalProperties: GlobalProperties, feature: Feature, canonical?: CanonicalTileID) => compiledStaticFilter.value.evaluate(globalProperties, feature, {}, canonical);\n }\n\n // If the static component is not equal to the entire filter then we have a dynamic component\n // Compile the dynamic component separately\n let dynamicFilterFunc = null;\n let needFeature = null;\n if (staticFilter !== filterExp) {\n const compiledDynamicFilter = createExpression(filterExp, filterSpec);\n\n if (compiledDynamicFilter.result === 'error') {\n throw new Error(compiledDynamicFilter.value.map(err => `${err.key}: ${err.message}`).join(', '));\n } else {\n dynamicFilterFunc = (globalProperties: GlobalProperties, feature: Feature, canonical?: CanonicalTileID, featureTileCoord?: Point, featureDistanceData?: FeatureDistanceData) => compiledDynamicFilter.value.evaluate(globalProperties, feature, {}, canonical, undefined, undefined, featureTileCoord, featureDistanceData);\n needFeature = !isFeatureConstant(compiledDynamicFilter.value.expression);\n }\n }\n\n filterFunc = ((filterFunc: any): FilterExpression);\n const needGeometry = geometryNeeded(staticFilter);\n\n return {\n filter: filterFunc,\n dynamicFilter: dynamicFilterFunc ? dynamicFilterFunc : undefined,\n needGeometry,\n needFeature: !!needFeature\n };\n}\n\nfunction extractStaticFilter(filter: any): any {\n if (!isDynamicFilter(filter)) {\n return filter;\n }\n\n // Shallow copy so we can replace expressions in-place\n let result = deepUnbundle(filter);\n\n // 1. Union branches\n unionDynamicBranches(result);\n\n // 2. Collapse dynamic conditions to `true`\n result = collapseDynamicBooleanExpressions(result);\n\n return result;\n}\n\nfunction collapseDynamicBooleanExpressions(expression: any): any {\n if (!Array.isArray(expression)) {\n return expression;\n }\n\n const collapsed = collapsedExpression(expression);\n if (collapsed === true) {\n return collapsed;\n } else {\n return collapsed.map((subExpression) => collapseDynamicBooleanExpressions(subExpression));\n }\n}\n\n/**\n * Traverses the expression and replaces all instances of branching on a\n * `dynamic` conditional (such as `['pitch']` or `['distance-from-center']`)\n * into an `any` expression.\n * This ensures that all possible outcomes of a `dynamic` branch are considered\n * when evaluating the expression upfront during filtering.\n *\n * @param {Array} filter the filter expression mutated in-place.\n */\nfunction unionDynamicBranches(filter: any) {\n let isBranchingDynamically = false;\n const branches = [];\n\n if (filter[0] === 'case') {\n for (let i = 1; i < filter.length - 1; i += 2) {\n isBranchingDynamically = isBranchingDynamically || isDynamicFilter(filter[i]);\n branches.push(filter[i + 1]);\n }\n\n branches.push(filter[filter.length - 1]);\n } else if (filter[0] === 'match') {\n isBranchingDynamically = isBranchingDynamically || isDynamicFilter(filter[1]);\n\n for (let i = 2; i < filter.length - 1; i += 2) {\n branches.push(filter[i + 1]);\n }\n branches.push(filter[filter.length - 1]);\n } else if (filter[0] === 'step') {\n isBranchingDynamically = isBranchingDynamically || isDynamicFilter(filter[1]);\n\n for (let i = 1; i < filter.length - 1; i += 2) {\n branches.push(filter[i + 1]);\n }\n }\n\n if (isBranchingDynamically) {\n filter.length = 0;\n filter.push('any', ...branches);\n }\n\n // traverse and recurse into children\n for (let i = 1; i < filter.length; i++) {\n unionDynamicBranches(filter[i]);\n }\n}\n\nfunction isDynamicFilter(filter: any): boolean {\n // Base Cases\n if (!Array.isArray(filter)) {\n return false;\n }\n if (isRootExpressionDynamic(filter[0])) {\n return true;\n }\n\n for (let i = 1; i < filter.length; i++) {\n const child = filter[i];\n if (isDynamicFilter(child)) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction isRootExpressionDynamic(expression: string): boolean {\n return expression === 'pitch' ||\n expression === 'distance-from-center';\n}\n\nconst dynamicConditionExpressions = new Set([\n 'in',\n '==',\n '!=',\n '>',\n '>=',\n '<',\n '<=',\n 'to-boolean'\n]);\n\nfunction collapsedExpression(expression: any): any {\n if (dynamicConditionExpressions.has(expression[0])) {\n\n for (let i = 1; i < expression.length; i++) {\n const param = expression[i];\n if (isDynamicFilter(param)) {\n return true;\n }\n }\n }\n return expression;\n}\n\n// Comparison function to sort numbers and strings\nfunction compare(a, b) {\n return a < b ? -1 : a > b ? 1 : 0;\n}\n\nfunction geometryNeeded(filter) {\n if (!Array.isArray(filter)) return false;\n if (filter[0] === 'within') return true;\n for (let index = 1; index < filter.length; index++) {\n if (geometryNeeded(filter[index])) return true;\n }\n return false;\n}\n\nfunction convertFilter(filter: ?Array): mixed {\n if (!filter) return true;\n const op = filter[0];\n if (filter.length <= 1) return (op !== 'any');\n const converted =\n op === '==' ? convertComparisonOp(filter[1], filter[2], '==') :\n op === '!=' ? convertNegation(convertComparisonOp(filter[1], filter[2], '==')) :\n op === '<' ||\n op === '>' ||\n op === '<=' ||\n op === '>=' ? convertComparisonOp(filter[1], filter[2], op) :\n op === 'any' ? convertDisjunctionOp(filter.slice(1)) :\n op === 'all' ? ['all'].concat(filter.slice(1).map(convertFilter)) :\n op === 'none' ? ['all'].concat(filter.slice(1).map(convertFilter).map(convertNegation)) :\n op === 'in' ? convertInOp(filter[1], filter.slice(2)) :\n op === '!in' ? convertNegation(convertInOp(filter[1], filter.slice(2))) :\n op === 'has' ? convertHasOp(filter[1]) :\n op === '!has' ? convertNegation(convertHasOp(filter[1])) :\n op === 'within' ? filter :\n true;\n return converted;\n}\n\nfunction convertComparisonOp(property: string, value: any, op: string) {\n switch (property) {\n case '$type':\n return [`filter-type-${op}`, value];\n case '$id':\n return [`filter-id-${op}`, value];\n default:\n return [`filter-${op}`, property, value];\n }\n}\n\nfunction convertDisjunctionOp(filters: Array>) {\n return ['any'].concat(filters.map(convertFilter));\n}\n\nfunction convertInOp(property: string, values: Array) {\n if (values.length === 0) { return false; }\n switch (property) {\n case '$type':\n return [`filter-type-in`, ['literal', values]];\n case '$id':\n return [`filter-id-in`, ['literal', values]];\n default:\n if (values.length > 200 && !values.some(v => typeof v !== typeof values[0])) {\n return ['filter-in-large', property, ['literal', values.sort(compare)]];\n } else {\n return ['filter-in-small', property, ['literal', values]];\n }\n }\n}\n\nfunction convertHasOp(property: string) {\n switch (property) {\n case '$type':\n return true;\n case '$id':\n return [`filter-has-id`];\n default:\n return [`filter-has`, property];\n }\n}\n\nfunction convertNegation(filter: mixed) {\n return ['!', filter];\n}\n","// @flow\nexport default ['type', 'source', 'source-layer', 'minzoom', 'maxzoom', 'filter', 'layout'];\n","// @flow\n\nimport refProperties from './util/ref_properties.js';\n\nimport type {LayerSpecification} from './types.js';\n\nfunction deref(layer: LayerSpecification, parent: LayerSpecification): LayerSpecification {\n const result = {};\n\n for (const k in layer) {\n if (k !== 'ref') {\n result[k] = layer[k];\n }\n }\n\n refProperties.forEach((k) => {\n if (k in parent) {\n result[k] = (parent: any)[k];\n }\n });\n\n return ((result: any): LayerSpecification);\n}\n\n/**\n * Given an array of layers, some of which may contain `ref` properties\n * whose value is the `id` of another property, return a new array where\n * such layers have been augmented with the 'type', 'source', etc. properties\n * from the parent layer, and the `ref` property has been removed.\n *\n * The input is not modified. The output may contain references to portions\n * of the input.\n *\n * @private\n * @param {Array} layers\n * @returns {Array}\n */\nexport default function derefLayers(layers: Array): Array {\n layers = layers.slice();\n\n const map = Object.create(null);\n for (let i = 0; i < layers.length; i++) {\n map[layers[i].id] = layers[i];\n }\n\n for (let i = 0; i < layers.length; i++) {\n if ('ref' in layers[i]) {\n layers[i] = deref(layers[i], map[(layers[i]: any).ref]);\n }\n }\n\n return layers;\n}\n","var fontWeights = {\n thin: 100,\n hairline: 100,\n 'ultra-light': 200,\n 'extra-light': 200,\n light: 300,\n book: 300,\n regular: 400,\n normal: 400,\n plain: 400,\n roman: 400,\n standard: 400,\n medium: 500,\n 'semi-bold': 600,\n 'demi-bold': 600,\n bold: 700,\n 'extra-bold': 800,\n 'ultra-bold': 800,\n heavy: 900,\n black: 900,\n 'heavy-black': 900,\n fat: 900,\n poster: 900,\n 'ultra-black': 950,\n 'extra-black': 950\n};\nvar sp = ' ';\nvar italicRE = /(italic|oblique)$/i;\n\nvar fontCache = {};\n\nmodule.exports = function(fonts, size, lineHeight) {\n var cssData = fontCache[fonts];\n if (!cssData) {\n if (!Array.isArray(fonts)) {\n fonts = [fonts];\n }\n var weight = 400;\n var style = 'normal';\n var fontFamilies = [];\n var haveWeight, haveStyle;\n for (var i = 0, ii = fonts.length; i < ii; ++i) {\n var font = fonts[i];\n var parts = font.split(' ');\n var maybeWeight = parts[parts.length - 1].toLowerCase();\n if (maybeWeight == 'normal' || maybeWeight == 'italic' || maybeWeight == 'oblique') {\n style = haveStyle ? style : maybeWeight;\n haveStyle = true;\n parts.pop();\n maybeWeight = parts[parts.length - 1].toLowerCase();\n } else if (italicRE.test(maybeWeight)) {\n maybeWeight = maybeWeight.replace(italicRE, '');\n style = haveStyle ? style : parts[parts.length - 1].replace(maybeWeight, '');\n haveStyle = true;\n }\n for (var w in fontWeights) {\n var previousPart = parts.length > 1 ? parts[parts.length - 2].toLowerCase() : '';\n if (maybeWeight == w || maybeWeight == w.replace('-', '') || previousPart + '-' + maybeWeight == w) {\n weight = haveWeight ? weight : fontWeights[w];\n parts.pop();\n if (previousPart && w.startsWith(previousPart)) {\n parts.pop();\n }\n break;\n }\n }\n if (!haveWeight && typeof maybeWeight == 'number') {\n weight = maybeWeight;\n haveWeight = true;\n }\n var fontFamily = parts.join(sp)\n .replace('Klokantech Noto Sans', 'Noto Sans');\n if (fontFamily.indexOf(sp) !== -1) {\n fontFamily = '\"' + fontFamily + '\"';\n }\n fontFamilies.push(fontFamily);\n }\n // CSS font property: font-style font-weight font-size/line-height font-family\n cssData = fontCache[fonts] = [style, weight, fontFamilies];\n }\n return cssData[0] + sp + cssData[1] + sp + size + 'px' + (lineHeight ? '/' + lineHeight : '') + sp + cssData[2];\n};\n","const mapboxBaseUrl = 'https://api.mapbox.com';\n\n/**\n * Gets the path from a mapbox:// URL.\n * @param {string} url The Mapbox URL.\n * @return {string} The path.\n * @private\n */\nexport function getMapboxPath(url) {\n const startsWith = 'mapbox://';\n if (url.indexOf(startsWith) !== 0) {\n return '';\n }\n return url.slice(startsWith.length);\n}\n\n/**\n * Turns mapbox:// sprite URLs into resolvable URLs.\n * @param {string} url The sprite URL.\n * @param {string} token The access token.\n * @param {string} styleUrl The style URL.\n * @return {string} A resolvable URL.\n * @private\n */\nexport function normalizeSpriteUrl(url, token, styleUrl) {\n const mapboxPath = getMapboxPath(url);\n if (!mapboxPath) {\n return decodeURI(new URL(url, styleUrl).href);\n }\n const startsWith = 'sprites/';\n if (mapboxPath.indexOf(startsWith) !== 0) {\n throw new Error(`unexpected sprites url: ${url}`);\n }\n const sprite = mapboxPath.slice(startsWith.length);\n\n return `${mapboxBaseUrl}/styles/v1/${sprite}/sprite?access_token=${token}`;\n}\n\n/**\n * Turns mapbox:// style URLs into resolvable URLs.\n * @param {string} url The style URL.\n * @param {string} token The access token.\n * @return {string} A resolvable URL.\n * @private\n */\nexport function normalizeStyleUrl(url, token) {\n const mapboxPath = getMapboxPath(url);\n if (!mapboxPath) {\n return decodeURI(new URL(url, location.href).href);\n }\n const startsWith = 'styles/';\n if (mapboxPath.indexOf(startsWith) !== 0) {\n throw new Error(`unexpected style url: ${url}`);\n }\n const style = mapboxPath.slice(startsWith.length);\n\n return `${mapboxBaseUrl}/styles/v1/${style}?&access_token=${token}`;\n}\n\nconst mapboxSubdomains = ['a', 'b', 'c', 'd'];\n\n/**\n * Turns mapbox:// source URLs into vector tile URL templates.\n * @param {string} url The source URL.\n * @param {string} token The access token.\n * @param {string} tokenParam The access token key.\n * @param {string} styleUrl The style URL.\n * @return {Array} A vector tile template.\n * @private\n */\nexport function normalizeSourceUrl(url, token, tokenParam, styleUrl) {\n const urlObject = new URL(url, styleUrl);\n const mapboxPath = getMapboxPath(url);\n if (!mapboxPath) {\n if (!token) {\n return [decodeURI(urlObject.href)];\n }\n if (!urlObject.searchParams.has(tokenParam)) {\n urlObject.searchParams.set(tokenParam, token);\n }\n return [decodeURI(urlObject.href)];\n }\n\n if (mapboxPath === 'mapbox.satellite') {\n const sizeFactor = window.devicePixelRatio >= 1.5 ? '@2x' : '';\n return [\n `https://api.mapbox.com/v4/${mapboxPath}/{z}/{x}/{y}${sizeFactor}.webp?access_token=${token}`,\n ];\n }\n return mapboxSubdomains.map(\n (sub) =>\n `https://${sub}.tiles.mapbox.com/v4/${mapboxPath}/{z}/{x}/{y}.vector.pbf?access_token=${token}`,\n );\n}\n","import TileState from 'ol/TileState.js';\nimport {VectorTile} from 'ol';\nimport {getUid} from 'ol/util.js';\nimport {normalizeSourceUrl, normalizeStyleUrl} from './mapbox.js';\nimport {toPromise} from 'ol/functions.js';\n\n/** @typedef {'Style'|'Source'|'Sprite'|'SpriteImage'|'Tiles'|'GeoJSON'} ResourceType */\n\n/** @typedef {import(\"ol\").Map} Map */\n/** @typedef {import(\"ol/layer\").Layer} Layer */\n/** @typedef {import(\"ol/layer\").Group} LayerGroup */\n/** @typedef {import(\"ol/layer\").Vector} VectorLayer */\n/** @typedef {import(\"ol/layer\").VectorTile} VectorTileLayer */\n/** @typedef {import(\"ol/source\").Source} Source */\n\nconst functionCacheByStyleId = {};\nconst filterCacheByStyleId = {};\n\nlet styleId = 0;\nexport function getStyleId(glStyle) {\n if (!glStyle.id) {\n glStyle.id = styleId++;\n }\n return glStyle.id;\n}\n\nexport function getStyleFunctionKey(glStyle, olLayer) {\n return getStyleId(glStyle) + '.' + getUid(olLayer);\n}\n\n/**\n * @param {Object} glStyle Mapboox style object.\n * @return {Object} Function cache.\n */\nexport function getFunctionCache(glStyle) {\n let functionCache = functionCacheByStyleId[glStyle.id];\n if (!functionCache) {\n functionCache = {};\n functionCacheByStyleId[getStyleId(glStyle)] = functionCache;\n }\n return functionCache;\n}\n\nexport function clearFunctionCache() {\n for (const key in functionCacheByStyleId) {\n delete functionCacheByStyleId[key];\n }\n}\n\n/**\n * @param {Object} glStyle Mapboox style object.\n * @return {Object} Filter cache.\n */\nexport function getFilterCache(glStyle) {\n let filterCache = filterCacheByStyleId[glStyle.id];\n if (!filterCache) {\n filterCache = {};\n filterCacheByStyleId[getStyleId(glStyle)] = filterCache;\n }\n return filterCache;\n}\n\nexport function deg2rad(degrees) {\n return (degrees * Math.PI) / 180;\n}\n\nexport const defaultResolutions = (function () {\n const resolutions = [];\n for (let res = 78271.51696402048; resolutions.length <= 24; res /= 2) {\n resolutions.push(res);\n }\n return resolutions;\n})();\n\n/**\n * @param {number} width Width of the canvas.\n * @param {number} height Height of the canvas.\n * @return {HTMLCanvasElement} Canvas.\n */\nexport function createCanvas(width, height) {\n if (typeof WorkerGlobalScope !== 'undefined' && self instanceof WorkerGlobalScope && typeof OffscreenCanvas !== 'undefined') { // eslint-disable-line\n return /** @type {?} */ (new OffscreenCanvas(width, height));\n }\n const canvas = document.createElement('canvas');\n canvas.width = width;\n canvas.height = height;\n return canvas;\n}\n\nexport function getZoomForResolution(resolution, resolutions) {\n let i = 0;\n const ii = resolutions.length;\n for (; i < ii; ++i) {\n const candidate = resolutions[i];\n if (candidate < resolution && i + 1 < ii) {\n const zoomFactor = resolutions[i] / resolutions[i + 1];\n return i + Math.log(resolutions[i] / resolution) / Math.log(zoomFactor);\n }\n }\n return ii - 1;\n}\n\nexport function getResolutionForZoom(zoom, resolutions) {\n const base = Math.floor(zoom);\n const factor = Math.pow(2, zoom - base);\n return resolutions[base] / factor;\n}\n\nconst pendingRequests = {};\n/**\n * @param {ResourceType} resourceType Type of resource to load.\n * @param {string} url Url of the resource.\n * @param {Options} [options={}] Options.\n * @param {{request?: Request}} [metadata] Object to be filled with the request.\n * @return {Promise} Promise that resolves with the loaded resource\n * or rejects with the Response object.\n * @private\n */\nexport function fetchResource(resourceType, url, options = {}, metadata) {\n if (url in pendingRequests) {\n if (metadata) {\n metadata.request = pendingRequests[url][0];\n }\n return pendingRequests[url][1];\n }\n const transformedRequest = options.transformRequest\n ? options.transformRequest(url, resourceType) || url\n : url;\n const pendingRequest = toPromise(() => transformedRequest).then(\n (transformedRequest) => {\n if (!(transformedRequest instanceof Request)) {\n transformedRequest = new Request(transformedRequest);\n }\n if (!transformedRequest.headers.get('Accept')) {\n transformedRequest.headers.set('Accept', 'application/json');\n }\n if (metadata) {\n metadata.request = transformedRequest;\n }\n return fetch(transformedRequest)\n .then(function (response) {\n delete pendingRequests[url];\n return response.ok\n ? response.json()\n : Promise.reject(new Error('Error fetching source ' + url));\n })\n .catch(function (error) {\n delete pendingRequests[url];\n return Promise.reject(new Error('Error fetching source ' + url));\n });\n },\n );\n pendingRequests[url] = [transformedRequest, pendingRequest];\n return pendingRequest;\n}\n\nexport function getGlStyle(glStyleOrUrl, options) {\n if (typeof glStyleOrUrl === 'string') {\n if (glStyleOrUrl.trim().startsWith('{')) {\n try {\n const glStyle = JSON.parse(glStyleOrUrl);\n return Promise.resolve(glStyle);\n } catch (error) {\n return Promise.reject(error);\n }\n } else {\n glStyleOrUrl = normalizeStyleUrl(glStyleOrUrl, options.accessToken);\n return fetchResource('Style', glStyleOrUrl, options);\n }\n } else {\n return Promise.resolve(glStyleOrUrl);\n }\n}\n\nconst tilejsonCache = {};\n/**\n * @param {Object} glSource glStyle source object.\n * @param {string} styleUrl Style URL.\n * @param {Options} options Options.\n * @return {Promise<{tileJson: Object, tileLoadFunction: import('ol/Tile.js').LoadFunction}?>} TileJson and load function\n */\nexport function getTileJson(glSource, styleUrl, options = {}) {\n const cacheKey = [styleUrl, JSON.stringify(glSource)].toString();\n let promise = tilejsonCache[cacheKey];\n if (!promise || options.transformRequest) {\n let tileLoadFunction;\n if (options.transformRequest) {\n tileLoadFunction = (tile, src) => {\n const transformedRequest = options.transformRequest\n ? options.transformRequest(src, 'Tiles') || src\n : src;\n if (tile instanceof VectorTile) {\n tile.setLoader((extent, resolution, projection) => {\n toPromise(() => transformedRequest).then((transformedRequest) => {\n fetch(transformedRequest)\n .then((response) => response.arrayBuffer())\n .then((data) => {\n const format = tile.getFormat();\n const features = format.readFeatures(data, {\n extent: extent,\n featureProjection: projection,\n });\n // @ts-ignore\n tile.setFeatures(features);\n })\n .catch((e) => tile.setState(TileState.ERROR));\n });\n });\n } else {\n const img = tile.getImage();\n toPromise(() => transformedRequest).then((transformedRequest) => {\n if (transformedRequest instanceof Request) {\n fetch(transformedRequest)\n .then((response) => response.blob())\n .then((blob) => {\n const url = URL.createObjectURL(blob);\n img.addEventListener('load', () => URL.revokeObjectURL(url));\n img.addEventListener('error', () => URL.revokeObjectURL(url));\n img.src = url;\n })\n .catch((e) => tile.setState(TileState.ERROR));\n } else {\n img.src = transformedRequest;\n }\n });\n }\n };\n }\n const url = glSource.url;\n if (url && !glSource.tiles) {\n const normalizedSourceUrl = normalizeSourceUrl(\n url,\n options.accessToken,\n options.accessTokenParam || 'access_token',\n styleUrl || location.href,\n );\n if (url.startsWith('mapbox://')) {\n promise = Promise.resolve({\n tileJson: Object.assign({}, glSource, {\n url: undefined,\n tiles: normalizedSourceUrl,\n }),\n tileLoadFunction,\n });\n } else {\n const metadata = {};\n promise = fetchResource(\n 'Source',\n normalizedSourceUrl[0],\n options,\n metadata,\n ).then(function (tileJson) {\n tileJson.tiles = tileJson.tiles.map(function (tileUrl) {\n if (tileJson.scheme === 'tms') {\n tileUrl = tileUrl.replace('{y}', '{-y}');\n }\n return normalizeSourceUrl(\n tileUrl,\n options.accessToken,\n options.accessTokenParam || 'access_token',\n metadata.request.url,\n )[0];\n });\n return Promise.resolve({tileJson, tileLoadFunction});\n });\n }\n } else {\n glSource = Object.assign({}, glSource, {\n tiles: glSource.tiles.map(function (tileUrl) {\n if (glSource.scheme === 'tms') {\n tileUrl = tileUrl.replace('{y}', '{-y}');\n }\n return normalizeSourceUrl(\n tileUrl,\n options.accessToken,\n options.accessTokenParam || 'access_token',\n styleUrl || location.href,\n )[0];\n }),\n });\n promise = Promise.resolve({\n tileJson: Object.assign({}, glSource),\n tileLoadFunction,\n });\n }\n tilejsonCache[cacheKey] = promise;\n }\n return promise;\n}\n\n/**\n * @param {HTMLImageElement|HTMLCanvasElement} spriteImage Sprite image id.\n * @param {{x: number, y: number, width: number, height: number, pixelRatio: number}} spriteImageData Sprite image data.\n * @param {number} haloWidth Halo width.\n * @param {{r: number, g: number, b: number, a: number}} haloColor Halo color.\n * @return {HTMLCanvasElement} Canvas element with the halo.\n */\nexport function drawIconHalo(\n spriteImage,\n spriteImageData,\n haloWidth,\n haloColor,\n) {\n const imgSize = [\n 2 * haloWidth * spriteImageData.pixelRatio + spriteImageData.width,\n 2 * haloWidth * spriteImageData.pixelRatio + spriteImageData.height,\n ];\n const imageCanvas = createCanvas(imgSize[0], imgSize[1]);\n const imageContext = imageCanvas.getContext('2d');\n imageContext.drawImage(\n spriteImage,\n spriteImageData.x,\n spriteImageData.y,\n spriteImageData.width,\n spriteImageData.height,\n haloWidth * spriteImageData.pixelRatio,\n haloWidth * spriteImageData.pixelRatio,\n spriteImageData.width,\n spriteImageData.height,\n );\n const imageData = imageContext.getImageData(0, 0, imgSize[0], imgSize[1]);\n imageContext.globalCompositeOperation = 'destination-over';\n imageContext.fillStyle = `rgba(${haloColor.r * 255},${haloColor.g * 255},${\n haloColor.b * 255\n },${haloColor.a})`;\n const data = imageData.data;\n for (let i = 0, ii = imageData.width; i < ii; ++i) {\n for (let j = 0, jj = imageData.height; j < jj; ++j) {\n const index = (j * ii + i) * 4;\n const alpha = data[index + 3];\n if (alpha > 0) {\n imageContext.arc(\n i,\n j,\n haloWidth * spriteImageData.pixelRatio,\n 0,\n 2 * Math.PI,\n );\n }\n }\n }\n imageContext.fill();\n return imageCanvas;\n}\n\nfunction smoothstep(min, max, value) {\n const x = Math.max(0, Math.min(1, (value - min) / (max - min)));\n return x * x * (3 - 2 * x);\n}\n\n/**\n * @param {HTMLImageElement} image SDF image\n * @param {{x: number, y: number, width: number, height: number}} area Area to unSDF\n * @param {{r: number, g: number, b: number, a: number}} color Color to use\n * @return {HTMLCanvasElement} Regular image\n */\nexport function drawSDF(image, area, color) {\n const imageCanvas = createCanvas(area.width, area.height);\n const imageContext = imageCanvas.getContext('2d');\n imageContext.drawImage(\n image,\n area.x,\n area.y,\n area.width,\n area.height,\n 0,\n 0,\n area.width,\n area.height,\n );\n const imageData = imageContext.getImageData(0, 0, area.width, area.height);\n const data = imageData.data;\n for (let i = 0, ii = imageData.width; i < ii; ++i) {\n for (let j = 0, jj = imageData.height; j < jj; ++j) {\n const index = (j * ii + i) * 4;\n const dist = data[index + 3] / 255;\n\n const buffer = 0.75;\n const gamma = 0.1;\n\n const alpha = smoothstep(buffer - gamma, buffer + gamma, dist);\n if (alpha > 0) {\n data[index + 0] = Math.round(255 * color.r * alpha);\n data[index + 1] = Math.round(255 * color.g * alpha);\n data[index + 2] = Math.round(255 * color.b * alpha);\n data[index + 3] = Math.round(255 * alpha);\n } else {\n data[index + 3] = 0;\n }\n }\n }\n imageContext.putImageData(imageData, 0, 0);\n return imageCanvas;\n}\n\n/**\n * @typedef {import(\"./apply.js\").Options} Options\n * @private\n */\n","import mb2css from 'mapbox-to-css-font';\nimport {checkedFonts, registerFont} from 'ol/render/canvas.js';\nimport {createCanvas} from './util.js';\n\nconst hairSpacePool = Array(256).join('\\u200A');\nexport function applyLetterSpacing(text, letterSpacing) {\n if (letterSpacing >= 0.05) {\n let textWithLetterSpacing = '';\n const lines = text.split('\\n');\n const joinSpaceString = hairSpacePool.slice(\n 0,\n Math.round(letterSpacing / 0.1),\n );\n for (let l = 0, ll = lines.length; l < ll; ++l) {\n if (l > 0) {\n textWithLetterSpacing += '\\n';\n }\n textWithLetterSpacing += lines[l].split('').join(joinSpaceString);\n }\n return textWithLetterSpacing;\n }\n return text;\n}\n\nlet measureContext;\nfunction getMeasureContext() {\n if (!measureContext) {\n measureContext = createCanvas(1, 1).getContext('2d');\n }\n return measureContext;\n}\n\nfunction measureText(text, letterSpacing) {\n return (\n getMeasureContext().measureText(text).width +\n (text.length - 1) * letterSpacing\n );\n}\n\nconst measureCache = {};\nexport function wrapText(text, font, em, letterSpacing) {\n if (text.indexOf('\\n') !== -1) {\n const hardLines = text.split('\\n');\n const lines = [];\n for (let i = 0, ii = hardLines.length; i < ii; ++i) {\n lines.push(wrapText(hardLines[i], font, em, letterSpacing));\n }\n return lines.join('\\n');\n }\n const key = em + ',' + font + ',' + text + ',' + letterSpacing;\n let wrappedText = measureCache[key];\n if (!wrappedText) {\n const words = text.split(' ');\n if (words.length > 1) {\n const ctx = getMeasureContext();\n ctx.font = font;\n const oneEm = ctx.measureText('M').width;\n const maxWidth = oneEm * em;\n let line = '';\n const lines = [];\n // Pass 1 - wrap lines to not exceed maxWidth\n for (let i = 0, ii = words.length; i < ii; ++i) {\n const word = words[i];\n const testLine = line + (line ? ' ' : '') + word;\n if (measureText(testLine, letterSpacing) <= maxWidth) {\n line = testLine;\n } else {\n if (line) {\n lines.push(line);\n }\n line = word;\n }\n }\n if (line) {\n lines.push(line);\n }\n // Pass 2 - add lines with a width of less than 30% of maxWidth to the previous or next line\n for (let i = 0, ii = lines.length; i < ii && ii > 1; ++i) {\n const line = lines[i];\n if (measureText(line, letterSpacing) < maxWidth * 0.35) {\n const prevWidth =\n i > 0 ? measureText(lines[i - 1], letterSpacing) : Infinity;\n const nextWidth =\n i < ii - 1 ? measureText(lines[i + 1], letterSpacing) : Infinity;\n lines.splice(i, 1);\n ii -= 1;\n if (prevWidth < nextWidth) {\n lines[i - 1] += ' ' + line;\n i -= 1;\n } else {\n lines[i] = line + ' ' + lines[i];\n }\n }\n }\n // Pass 3 - try to fill 80% of maxWidth for each line\n for (let i = 0, ii = lines.length - 1; i < ii; ++i) {\n const line = lines[i];\n const next = lines[i + 1];\n if (\n measureText(line, letterSpacing) > maxWidth * 0.7 &&\n measureText(next, letterSpacing) < maxWidth * 0.6\n ) {\n const lineWords = line.split(' ');\n const lastWord = lineWords.pop();\n if (measureText(lastWord, letterSpacing) < maxWidth * 0.2) {\n lines[i] = lineWords.join(' ');\n lines[i + 1] = lastWord + ' ' + next;\n }\n ii -= 1;\n }\n }\n wrappedText = lines.join('\\n');\n } else {\n wrappedText = text;\n }\n wrappedText = applyLetterSpacing(wrappedText, letterSpacing);\n measureCache[key] = wrappedText;\n }\n return wrappedText;\n}\n\nconst fontFamilyRegEx = /font-family: ?([^;]*);/;\nconst stripQuotesRegEx = /(\"|')/g;\nlet loadedFontFamilies;\nfunction hasFontFamily(family) {\n if (!loadedFontFamilies) {\n loadedFontFamilies = {};\n const styleSheets = document.styleSheets;\n for (let i = 0, ii = styleSheets.length; i < ii; ++i) {\n const styleSheet = /** @type {CSSStyleSheet} */ (styleSheets[i]);\n try {\n const cssRules = styleSheet.rules || styleSheet.cssRules;\n if (cssRules) {\n for (let j = 0, jj = cssRules.length; j < jj; ++j) {\n const cssRule = cssRules[j];\n if (cssRule.type == 5) {\n const match = cssRule.cssText.match(fontFamilyRegEx);\n loadedFontFamilies[match[1].replace(stripQuotesRegEx, '')] = true;\n }\n }\n }\n } catch (e) {\n // empty catch block\n }\n }\n }\n return family in loadedFontFamilies;\n}\n\nconst processedFontFamilies = {};\n\n/**\n * @param {Array} fonts Fonts.\n * @param {string} [templateUrl] Template URL.\n * @return {Array} Processed fonts.\n * @private\n */\nexport function getFonts(\n fonts,\n templateUrl = 'https://cdn.jsdelivr.net/npm/@fontsource/{font-family}/{fontweight}{-fontstyle}.css',\n) {\n const fontsKey = fonts.toString();\n if (fontsKey in processedFontFamilies) {\n return processedFontFamilies[fontsKey];\n }\n const fontDescriptions = [];\n for (let i = 0, ii = fonts.length; i < ii; ++i) {\n fonts[i] = fonts[i].replace('Arial Unicode MS', 'Arial');\n const font = fonts[i];\n const cssFont = mb2css(font, 1);\n registerFont(cssFont);\n const parts = cssFont.split(' ');\n fontDescriptions.push([\n parts.slice(3).join(' ').replace(/\"/g, ''),\n parts[1],\n parts[0],\n ]);\n }\n for (let i = 0, ii = fontDescriptions.length; i < ii; ++i) {\n const fontDescription = fontDescriptions[i];\n const family = fontDescription[0];\n if (!hasFontFamily(family)) {\n if (\n checkedFonts.get(\n `${fontDescription[2]}\\n${fontDescription[1]} \\n${family}`,\n ) !== 100\n ) {\n const fontUrl = templateUrl\n .replace('{font-family}', family.replace(/ /g, '-').toLowerCase())\n .replace('{Font+Family}', family.replace(/ /g, '+'))\n .replace('{fontweight}', fontDescription[1])\n .replace(\n '{-fontstyle}',\n fontDescription[2].replace('normal', '').replace(/(.+)/, '-$1'),\n )\n .replace('{fontstyle}', fontDescription[2]);\n if (!document.querySelector('link[href=\"' + fontUrl + '\"]')) {\n const markup = document.createElement('link');\n markup.href = fontUrl;\n markup.rel = 'stylesheet';\n document.head.appendChild(markup);\n }\n }\n }\n }\n processedFontFamilies[fontsKey] = fonts;\n return fonts;\n}\n","/*\nol-mapbox-style - Use Mapbox/MapLibre Style objects with OpenLayers\nCopyright 2016-present ol-mapbox-style contributors\nLicense: https://raw.githubusercontent.com/openlayers/ol-mapbox-style/master/LICENSE\n*/\n\nimport Circle from 'ol/style/Circle.js';\nimport Fill from 'ol/style/Fill.js';\nimport Icon from 'ol/style/Icon.js';\nimport RenderFeature from 'ol/render/Feature.js';\nimport Stroke from 'ol/style/Stroke.js';\nimport Style from 'ol/style/Style.js';\nimport Text from 'ol/style/Text.js';\nimport {toPromise} from 'ol/functions.js';\n\nimport Color from '@mapbox/mapbox-gl-style-spec/util/color.js';\nimport convertFunction from '@mapbox/mapbox-gl-style-spec/function/convert.js';\nimport createFilter from '@mapbox/mapbox-gl-style-spec/feature_filter/index.js';\nimport derefLayers from '@mapbox/mapbox-gl-style-spec/deref.js';\nimport mb2css from 'mapbox-to-css-font';\nimport spec from '@mapbox/mapbox-gl-style-spec/reference/v8.json';\nimport {applyLetterSpacing, wrapText} from './text.js';\nimport {\n clearFunctionCache,\n createCanvas,\n defaultResolutions,\n deg2rad,\n drawIconHalo,\n drawSDF,\n getFilterCache,\n getFunctionCache,\n getStyleFunctionKey,\n getZoomForResolution,\n} from './util.js';\nimport {\n createPropertyExpression,\n isExpression,\n} from '@mapbox/mapbox-gl-style-spec/expression/index.js';\nimport {isFunction} from '@mapbox/mapbox-gl-style-spec/function/index.js';\n\n/**\n * @typedef {import(\"ol/layer/Vector\").default} VectorLayer\n * @typedef {import(\"ol/layer/VectorTile\").default} VectorTileLayer\n * @typedef {import(\"ol/style/Style\").StyleFunction} StyleFunction\n * @typedef {import('./util.js').ResourceType} ResourceType\n */\n\nconst types = {\n 'Point': 1,\n 'MultiPoint': 1,\n 'LineString': 2,\n 'MultiLineString': 2,\n 'Polygon': 3,\n 'MultiPolygon': 3,\n};\nconst anchor = {\n 'center': [0.5, 0.5],\n 'left': [0, 0.5],\n 'right': [1, 0.5],\n 'top': [0.5, 0],\n 'bottom': [0.5, 1],\n 'top-left': [0, 0],\n 'top-right': [1, 0],\n 'bottom-left': [0, 1],\n 'bottom-right': [1, 1],\n};\n\nconst expressionData = function (rawExpression, propertySpec) {\n const compiledExpression = createPropertyExpression(\n rawExpression,\n propertySpec,\n );\n if (compiledExpression.result === 'error') {\n throw new Error(\n compiledExpression.value\n .map((err) => `${err.key}: ${err.message}`)\n .join(', '),\n );\n }\n return compiledExpression.value;\n};\n\nconst emptyObj = {};\nconst zoomObj = {zoom: 0};\nlet renderFeatureCoordinates, renderFeature;\n\n/**\n * @private\n * @param {Object} layer Gl object layer.\n * @param {string} layoutOrPaint 'layout' or 'paint'.\n * @param {string} property Feature property.\n * @param {number} zoom Zoom.\n * @param {Object} feature Gl feature.\n * @param {Object} [functionCache] Function cache.\n * @param {Object} [featureState] Feature state.\n * @return {?} Value.\n */\nexport function getValue(\n layer,\n layoutOrPaint,\n property,\n zoom,\n feature,\n functionCache,\n featureState,\n) {\n const layerId = layer.id;\n if (!functionCache) {\n functionCache = {};\n console.warn('No functionCache provided to getValue()'); //eslint-disable-line no-console\n }\n if (!functionCache[layerId]) {\n functionCache[layerId] = {};\n }\n const functions = functionCache[layerId];\n if (!functions[property]) {\n let value = (layer[layoutOrPaint] || emptyObj)[property];\n const propertySpec = spec[`${layoutOrPaint}_${layer.type}`][property];\n if (value === undefined) {\n value = propertySpec.default;\n }\n let isExpr = isExpression(value);\n if (!isExpr && isFunction(value)) {\n value = convertFunction(value, propertySpec);\n isExpr = true;\n }\n if (isExpr) {\n const compiledExpression = expressionData(value, propertySpec);\n functions[property] =\n compiledExpression.evaluate.bind(compiledExpression);\n } else {\n if (propertySpec.type == 'color') {\n value = Color.parse(value);\n }\n functions[property] = function () {\n return value;\n };\n }\n }\n zoomObj.zoom = zoom;\n return functions[property](zoomObj, feature, featureState);\n}\n\n/**\n * @private\n * @param {Object} layer Gl object layer.\n * @param {number} zoom Zoom.\n * @param {Object} feature Gl feature.\n * @param {\"icon\"|\"text\"} prefix Style property prefix.\n * @param {Object} [functionCache] Function cache.\n * @return {\"declutter\"|\"obstacle\"|\"none\"} Value.\n */\nfunction getDeclutterMode(layer, zoom, feature, prefix, functionCache) {\n const allowOverlap = getValue(\n layer,\n 'layout',\n `${prefix}-allow-overlap`,\n zoom,\n feature,\n functionCache,\n );\n if (!allowOverlap) {\n return 'declutter';\n }\n const ignorePlacement = getValue(\n layer,\n 'layout',\n `${prefix}-ignore-placement`,\n zoom,\n feature,\n functionCache,\n );\n if (!ignorePlacement) {\n return 'obstacle';\n }\n return 'none';\n}\n\n/**\n * @private\n * @param {string} layerId Layer id.\n * @param {?} filter Filter.\n * @param {Object} feature Feature.\n * @param {number} zoom Zoom.\n * @param {Object} [filterCache] Filter cache.\n * @return {boolean} Filter result.\n */\nfunction evaluateFilter(layerId, filter, feature, zoom, filterCache) {\n if (!filterCache) {\n console.warn('No filterCache provided to evaluateFilter()'); //eslint-disable-line no-console\n }\n if (!(layerId in filterCache)) {\n filterCache[layerId] = createFilter(filter).filter;\n }\n zoomObj.zoom = zoom;\n return filterCache[layerId](zoomObj, feature);\n}\n\nlet renderTransparentEnabled = false;\n\n/**\n * Configure whether features with a transparent style should be rendered. When\n * set to `true`, it will be possible to hit detect content that is not visible,\n * like transparent fills of polygons, using `ol/layer/Layer#getFeatures()` or\n * `ol/Map#getFeaturesAtPixel()`\n * @param {boolean} enabled Rendering of transparent elements is enabled.\n * Default is `false`.\n */\nexport function renderTransparent(enabled) {\n if (enabled !== renderTransparentEnabled) {\n clearFunctionCache();\n renderTransparentEnabled = enabled;\n }\n}\n\n/**\n * @private\n * @param {?} color Color.\n * @param {number} [opacity] Opacity.\n * @return {string} Color.\n */\nfunction colorWithOpacity(color, opacity) {\n if (color) {\n if (!renderTransparentEnabled && (color.a === 0 || opacity === 0)) {\n return undefined;\n }\n const a = color.a;\n opacity = opacity === undefined ? 1 : opacity;\n return a === 0\n ? 'transparent'\n : 'rgba(' +\n Math.round((color.r * 255) / a) +\n ',' +\n Math.round((color.g * 255) / a) +\n ',' +\n Math.round((color.b * 255) / a) +\n ',' +\n a * opacity +\n ')';\n }\n return color;\n}\n\nconst templateRegEx = /\\{[^{}}]*\\}/g;\n\n/**\n * @private\n * @param {string} text Text.\n * @param {Object} properties Properties.\n * @return {string} Text.\n */\nfunction fromTemplate(text, properties) {\n return text.replace(templateRegEx, function (match) {\n return properties[match.slice(1, -1)] || '';\n });\n}\n\nlet recordLayer = false;\n\n/**\n * Turns recording of the Mapbox/MapLibre Style's `layer` on and off. When turned on,\n * the layer that a rendered feature belongs to will be set as the feature's\n * `mapbox-layer` property.\n * @param {boolean} record Recording of the style layer is on.\n */\nexport function recordStyleLayer(record = false) {\n recordLayer = record;\n}\n\nexport const styleFunctionArgs = {};\n\n/**\n * Creates a style function from the `glStyle` object for all layers that use\n * the specified `source`, which needs to be a `\"type\": \"vector\"` or\n * `\"type\": \"geojson\"` source and applies it to the specified OpenLayers layer.\n *\n * Two additional properties will be set on the provided layer:\n *\n * * `mapbox-source`: The `id` of the Mapbox/MapLibre Style document's source that the\n * OpenLayers layer was created from. Usually `apply()` creates one\n * OpenLayers layer per Mapbox/MapLibre Style source, unless the layer stack has\n * layers from different sources in between.\n * * `mapbox-layers`: The `id`s of the Mapbox/MapLibre Style document's layers that are\n * included in the OpenLayers layer.\n *\n * This function also works in a web worker. In worker mode, the main thread needs\n * to listen to messages from the worker and respond with another message to make\n * sure that sprite image loading works:\n *\n * ```js\n * worker.addEventListener('message', event => {\n * if (event.data.action === 'loadImage') {\n * const image = new Image();\n * image.crossOrigin = 'anonymous';\n * image.addEventListener('load', function() {\n * createImageBitmap(image, 0, 0, image.width, image.height).then(imageBitmap => {\n * worker.postMessage({\n * action: 'imageLoaded',\n * image: imageBitmap,\n * src: event.data.src\n * }, [imageBitmap]);\n * });\n * });\n * image.src = event.data.src;\n * }\n * });\n * ```\n *\n * @param {VectorLayer|VectorTileLayer} olLayer OpenLayers layer to\n * apply the style to. In addition to the style, the layer will get two\n * properties: `mapbox-source` will be the `id` of the `glStyle`'s source used\n * for the layer, and `mapbox-layers` will be an array of the `id`s of the\n * `glStyle`'s layers.\n * @param {string|Object} glStyle Mapbox/MapLibre Style object.\n * @param {string|Array} sourceOrLayers `source` key or an array of layer `id`s\n * from the Mapbox/MapLibre Style object. When a `source` key is provided, all layers for\n * the specified source will be included in the style function. When layer `id`s\n * are provided, they must be from layers that use the same source.\n * @param {Array} resolutions\n * Resolutions for mapping resolution to zoom level.\n * @param {Object} spriteData Sprite data from the url specified in\n * the Mapbox/MapLibre Style object's `sprite` property. Only required if a `sprite`\n * property is specified in the Mapbox/MapLibre Style object.\n * @param {string|Request|Promise} spriteImageUrl Sprite image url for the sprite\n * specified in the Mapbox/MapLibre Style object's `sprite` property. Only required if a\n * `sprite` property is specified in the Mapbox/MapLibre Style object.\n * @param {function(Array, string=):Array} getFonts Function that\n * receives a font stack and the url template from the GL style's `metadata['ol:webfonts']`\n * property (if set) as arguments, and returns a (modified) font stack that\n * is available. Font names are the names used in the Mapbox/MapLibre Style object. If\n * not provided, the font stack will be used as-is. This function can also be\n * used for loading web fonts.\n * @param {function(VectorLayer|VectorTileLayer, string):HTMLImageElement|HTMLCanvasElement|string|undefined} [getImage=undefined]\n * Function that returns an image or a URL for an image name. If the result is an HTMLImageElement, it must already be\n * loaded. The layer can be used to call layer.changed() when the loading and processing of the image has finished.\n * This function can be used for icons not in the sprite or to override sprite icons.\n * @return {StyleFunction} Style function for use in\n * `ol.layer.Vector` or `ol.layer.VectorTile`.\n */\nexport function stylefunction(\n olLayer,\n glStyle,\n sourceOrLayers,\n resolutions = defaultResolutions,\n spriteData = undefined,\n spriteImageUrl = undefined,\n getFonts = undefined,\n getImage = undefined,\n) {\n if (typeof glStyle == 'string') {\n glStyle = JSON.parse(glStyle);\n }\n if (glStyle.version != 8) {\n throw new Error('glStyle version 8 required.');\n }\n styleFunctionArgs[getStyleFunctionKey(glStyle, olLayer)] =\n Array.from(arguments);\n\n let spriteImage, spriteImageSize;\n let spriteImageUnSDFed;\n\n if (spriteImageUrl) {\n if (typeof Image !== 'undefined') {\n const img = new Image();\n let blobUrl;\n toPromise(() => spriteImageUrl).then((spriteImageUrl) => {\n if (spriteImageUrl instanceof Request) {\n fetch(spriteImageUrl)\n .then((response) => response.blob())\n .then((blob) => {\n blobUrl = URL.createObjectURL(blob);\n img.src = blobUrl;\n })\n .catch(() => {});\n } else {\n img.crossOrigin = 'anonymous';\n img.src = spriteImageUrl;\n if (blobUrl) {\n URL.revokeObjectURL(blobUrl);\n }\n }\n });\n img.onload = function () {\n spriteImage = img;\n spriteImageSize = [img.width, img.height];\n olLayer.changed();\n img.onload = null;\n };\n } else if (typeof WorkerGlobalScope !== 'undefined' && self instanceof WorkerGlobalScope) { //eslint-disable-line\n const worker = /** @type {*} */ (self);\n // Main thread needs to handle 'loadImage' and dispatch 'imageLoaded'\n worker.postMessage({\n action: 'loadImage',\n src: spriteImageUrl,\n });\n worker.addEventListener('message', function handler(event) {\n if (\n event.data.action === 'imageLoaded' &&\n event.data.src === spriteImageUrl\n ) {\n spriteImage = event.data.image;\n spriteImageSize = [spriteImage.width, spriteImage.height];\n }\n });\n }\n }\n\n const allLayers = derefLayers(glStyle.layers);\n\n const layersBySourceLayer = {};\n const mapboxLayers = [];\n\n const iconImageCache = {};\n const patternCache = {};\n const functionCache = getFunctionCache(glStyle);\n const filterCache = getFilterCache(glStyle);\n\n let mapboxSource;\n for (let i = 0, ii = allLayers.length; i < ii; ++i) {\n const layer = allLayers[i];\n const layerId = layer.id;\n if (\n (typeof sourceOrLayers == 'string' && layer.source == sourceOrLayers) ||\n (Array.isArray(sourceOrLayers) && sourceOrLayers.indexOf(layerId) !== -1)\n ) {\n const sourceLayer = layer['source-layer'];\n if (!mapboxSource) {\n mapboxSource = layer.source;\n const source = glStyle.sources[mapboxSource];\n if (!source) {\n throw new Error(`Source \"${mapboxSource}\" is not defined`);\n }\n const type = source.type;\n if (type !== 'vector' && type !== 'geojson') {\n throw new Error(\n `Source \"${mapboxSource}\" is not of type \"vector\" or \"geojson\", but \"${type}\"`,\n );\n }\n } else if (layer.source !== mapboxSource) {\n throw new Error(\n `Layer \"${layerId}\" does not use source \"${mapboxSource}`,\n );\n }\n let layers = layersBySourceLayer[sourceLayer];\n if (!layers) {\n layers = [];\n layersBySourceLayer[sourceLayer] = layers;\n }\n layers.push({\n layer: layer,\n index: i,\n });\n mapboxLayers.push(layerId);\n }\n }\n\n const textHalo = new Stroke();\n const textColor = new Fill();\n\n const styles = [];\n\n /**\n * @param {import(\"ol/Feature\").default|import(\"ol/render/Feature\").default} feature Feature.\n * @param {number} resolution Resolution.\n * @param {string} [onlyLayer] Calculate style for this layer only.\n * @return {Array} Style.\n */\n const styleFunction = function (feature, resolution, onlyLayer) {\n const properties = feature.getProperties();\n const layers = layersBySourceLayer[properties.layer];\n if (!layers) {\n return undefined;\n }\n let zoom = resolutions.indexOf(resolution);\n if (zoom == -1) {\n zoom = getZoomForResolution(resolution, resolutions);\n }\n const type = types[feature.getGeometry().getType()];\n const f = {\n id: feature.getId(),\n properties: properties,\n type: type,\n };\n const featureState = olLayer.get('mapbox-featurestate')[feature.getId()];\n let stylesLength = -1;\n let featureBelongsToLayer;\n for (let i = 0, ii = layers.length; i < ii; ++i) {\n const layerData = layers[i];\n const layer = layerData.layer;\n const layerId = layer.id;\n if (onlyLayer !== undefined && onlyLayer !== layerId) {\n continue;\n }\n\n const layout = layer.layout || emptyObj;\n const paint = layer.paint || emptyObj;\n if (\n layout.visibility === 'none' ||\n ('minzoom' in layer && zoom < layer.minzoom) ||\n ('maxzoom' in layer && zoom >= layer.maxzoom)\n ) {\n continue;\n }\n const filter = layer.filter;\n if (!filter || evaluateFilter(layerId, filter, f, zoom, filterCache)) {\n featureBelongsToLayer = layer;\n let color, opacity, fill, stroke, strokeColor, style;\n const index = layerData.index;\n if (\n type == 3 &&\n (layer.type == 'fill' || layer.type == 'fill-extrusion')\n ) {\n opacity = getValue(\n layer,\n 'paint',\n layer.type + '-opacity',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (layer.type + '-pattern' in paint) {\n const fillIcon = getValue(\n layer,\n 'paint',\n layer.type + '-pattern',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (fillIcon) {\n const icon =\n typeof fillIcon === 'string'\n ? fromTemplate(fillIcon, properties)\n : fillIcon.toString();\n if (spriteImage && spriteData && spriteData[icon]) {\n ++stylesLength;\n style = styles[stylesLength];\n if (\n !style ||\n !style.getFill() ||\n style.getStroke() ||\n style.getText()\n ) {\n style = new Style({\n fill: new Fill(),\n });\n styles[stylesLength] = style;\n }\n fill = style.getFill();\n style.setZIndex(index);\n const icon_cache_key = icon + '.' + opacity;\n let pattern = patternCache[icon_cache_key];\n if (!pattern) {\n const spriteImageData = spriteData[icon];\n const canvas = createCanvas(\n spriteImageData.width,\n spriteImageData.height,\n );\n const ctx = /** @type {CanvasRenderingContext2D} */ (\n canvas.getContext('2d')\n );\n ctx.globalAlpha = opacity;\n ctx.drawImage(\n spriteImage,\n spriteImageData.x,\n spriteImageData.y,\n spriteImageData.width,\n spriteImageData.height,\n 0,\n 0,\n spriteImageData.width,\n spriteImageData.height,\n );\n pattern = ctx.createPattern(canvas, 'repeat');\n patternCache[icon_cache_key] = pattern;\n }\n fill.setColor(pattern);\n }\n }\n } else {\n color = colorWithOpacity(\n getValue(\n layer,\n 'paint',\n layer.type + '-color',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n opacity,\n );\n if (layer.type + '-outline-color' in paint) {\n strokeColor = colorWithOpacity(\n getValue(\n layer,\n 'paint',\n layer.type + '-outline-color',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n opacity,\n );\n }\n if (!strokeColor) {\n strokeColor = color;\n }\n if (color || strokeColor) {\n ++stylesLength;\n style = styles[stylesLength];\n if (\n !style ||\n (color && !style.getFill()) ||\n (!color && style.getFill()) ||\n (strokeColor && !style.getStroke()) ||\n (!strokeColor && style.getStroke()) ||\n style.getText()\n ) {\n style = new Style({\n fill: color ? new Fill() : undefined,\n stroke: strokeColor ? new Stroke() : undefined,\n });\n styles[stylesLength] = style;\n }\n if (color) {\n fill = style.getFill();\n fill.setColor(color);\n }\n if (strokeColor) {\n stroke = style.getStroke();\n stroke.setColor(strokeColor);\n stroke.setWidth(0.5);\n }\n style.setZIndex(index);\n }\n }\n }\n if (type != 1 && layer.type == 'line') {\n if (!('line-pattern' in paint)) {\n color = colorWithOpacity(\n getValue(\n layer,\n 'paint',\n 'line-color',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n getValue(\n layer,\n 'paint',\n 'line-opacity',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n } else {\n color = undefined;\n }\n const width = getValue(\n layer,\n 'paint',\n 'line-width',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (color && width > 0) {\n ++stylesLength;\n style = styles[stylesLength];\n if (\n !style ||\n !style.getStroke() ||\n style.getFill() ||\n style.getText()\n ) {\n style = new Style({\n stroke: new Stroke(),\n });\n styles[stylesLength] = style;\n }\n stroke = style.getStroke();\n stroke.setLineCap(\n getValue(\n layer,\n 'layout',\n 'line-cap',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n stroke.setLineJoin(\n getValue(\n layer,\n 'layout',\n 'line-join',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n stroke.setMiterLimit(\n getValue(\n layer,\n 'layout',\n 'line-miter-limit',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n stroke.setColor(color);\n stroke.setWidth(width);\n stroke.setLineDash(\n paint['line-dasharray']\n ? getValue(\n layer,\n 'paint',\n 'line-dasharray',\n zoom,\n f,\n functionCache,\n featureState,\n ).map(function (x) {\n return x * width;\n })\n : null,\n );\n style.setZIndex(index);\n }\n }\n\n let hasImage = false;\n let text = null;\n let placementAngle = 0;\n let icon, iconImg, skipLabel;\n if ((type == 1 || type == 2) && 'icon-image' in layout) {\n const iconImage = getValue(\n layer,\n 'layout',\n 'icon-image',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (iconImage) {\n icon =\n typeof iconImage === 'string'\n ? fromTemplate(iconImage, properties)\n : iconImage.toString();\n let styleGeom = undefined;\n const imageElement = getImage ? getImage(olLayer, icon) : undefined;\n if (\n (spriteImage && spriteData && spriteData[icon]) ||\n imageElement\n ) {\n const iconRotationAlignment = getValue(\n layer,\n 'layout',\n 'icon-rotation-alignment',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (type == 2) {\n const geom = /** @type {*} */ (feature.getGeometry());\n // ol package and ol-debug.js only\n if (geom.getFlatMidpoint || geom.getFlatMidpoints) {\n const extent = geom.getExtent();\n const size = Math.sqrt(\n Math.max(\n Math.pow((extent[2] - extent[0]) / resolution, 2),\n Math.pow((extent[3] - extent[1]) / resolution, 2),\n ),\n );\n if (size > 150) {\n //FIXME Do not hard-code a size of 150\n const midpoint =\n geom.getType() === 'MultiLineString'\n ? geom.getFlatMidpoints()\n : geom.getFlatMidpoint();\n if (!renderFeature) {\n renderFeatureCoordinates = [NaN, NaN];\n renderFeature = new RenderFeature(\n 'Point',\n renderFeatureCoordinates,\n [],\n 2,\n {},\n undefined,\n );\n }\n styleGeom = renderFeature;\n renderFeatureCoordinates[0] = midpoint[0];\n renderFeatureCoordinates[1] = midpoint[1];\n const placement = getValue(\n layer,\n 'layout',\n 'symbol-placement',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (\n placement === 'line' &&\n iconRotationAlignment === 'map'\n ) {\n const stride = geom.getStride();\n const coordinates = geom.getFlatCoordinates();\n for (\n let i = 0, ii = coordinates.length - stride;\n i < ii;\n i += stride\n ) {\n const x1 = coordinates[i];\n const y1 = coordinates[i + 1];\n const x2 = coordinates[i + stride];\n const y2 = coordinates[i + stride + 1];\n const minX = Math.min(x1, x2);\n const maxX = Math.max(x1, x2);\n const xM = midpoint[0];\n const yM = midpoint[1];\n const dotProduct =\n (y2 - y1) * (xM - x1) - (x2 - x1) * (yM - y1);\n if (\n Math.abs(dotProduct) < 0.001 && //midpoint is aligned with the segment\n xM <= maxX &&\n xM >= minX //midpoint is on the segment and not outside it\n ) {\n placementAngle = Math.atan2(y1 - y2, x2 - x1);\n break;\n }\n }\n }\n }\n }\n }\n if (type !== 2 || styleGeom) {\n const iconSize = getValue(\n layer,\n 'layout',\n 'icon-size',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const iconColor =\n paint['icon-color'] !== undefined\n ? getValue(\n layer,\n 'paint',\n 'icon-color',\n zoom,\n f,\n functionCache,\n featureState,\n )\n : null;\n if (!iconColor || iconColor.a !== 0) {\n const haloColor = getValue(\n layer,\n 'paint',\n 'icon-halo-color',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const haloWidth = getValue(\n layer,\n 'paint',\n 'icon-halo-width',\n zoom,\n f,\n functionCache,\n featureState,\n );\n let iconCacheKey = `${icon}.${iconSize}.${haloWidth}.${haloColor}`;\n if (iconColor !== null) {\n iconCacheKey += `.${iconColor}`;\n }\n iconImg = iconImageCache[iconCacheKey];\n if (!iconImg) {\n const declutterMode = getDeclutterMode(\n layer,\n zoom,\n f,\n 'icon',\n functionCache,\n );\n let displacement;\n if ('icon-offset' in layout) {\n displacement = getValue(\n layer,\n 'layout',\n 'icon-offset',\n zoom,\n f,\n functionCache,\n featureState,\n ).slice(0);\n displacement[0] *= iconSize;\n displacement[1] *= -iconSize;\n }\n let color = iconColor\n ? [\n iconColor.r * 255,\n iconColor.g * 255,\n iconColor.b * 255,\n iconColor.a,\n ]\n : undefined;\n if (imageElement) {\n const iconOptions = {\n color: color,\n rotateWithView: iconRotationAlignment === 'map',\n displacement: displacement,\n declutterMode: declutterMode,\n scale: iconSize,\n };\n if (typeof imageElement === 'string') {\n // it is a src URL\n iconOptions.src = imageElement;\n } else {\n iconOptions.img = imageElement;\n iconOptions.imgSize = [\n imageElement.width,\n imageElement.height,\n ];\n }\n iconImg = new Icon(iconOptions);\n } else {\n const spriteImageData = spriteData[icon];\n let img, size, offset;\n if (haloWidth) {\n if (spriteImageData.sdf) {\n img = drawIconHalo(\n drawSDF(\n spriteImage,\n spriteImageData,\n iconColor || [0, 0, 0, 1],\n ),\n {\n x: 0,\n y: 0,\n width: spriteImageData.width,\n height: spriteImageData.height,\n pixelRatio: spriteImageData.pixelRatio,\n },\n haloWidth,\n haloColor,\n );\n color = undefined; // do not tint haloed icons\n } else {\n img = drawIconHalo(\n spriteImage,\n spriteImageData,\n haloWidth,\n haloColor,\n );\n }\n } else {\n if (spriteImageData.sdf) {\n if (!spriteImageUnSDFed) {\n spriteImageUnSDFed = drawSDF(\n spriteImage,\n {\n x: 0,\n y: 0,\n width: spriteImageSize[0],\n height: spriteImageSize[1],\n },\n {r: 1, g: 1, b: 1, a: 1},\n );\n }\n img = spriteImageUnSDFed;\n } else {\n img = spriteImage;\n }\n size = [spriteImageData.width, spriteImageData.height];\n offset = [spriteImageData.x, spriteImageData.y];\n }\n iconImg = new Icon({\n color: color,\n img: img,\n // @ts-ignore\n imgSize: spriteImageSize,\n size: size,\n offset: offset,\n rotateWithView: iconRotationAlignment === 'map',\n scale: iconSize / spriteImageData.pixelRatio,\n displacement: displacement,\n declutterMode: declutterMode,\n });\n }\n iconImageCache[iconCacheKey] = iconImg;\n }\n }\n if (iconImg) {\n ++stylesLength;\n style = styles[stylesLength];\n if (\n !style ||\n !style.getImage() ||\n style.getFill() ||\n style.getStroke()\n ) {\n style = new Style();\n styles[stylesLength] = style;\n }\n style.setGeometry(styleGeom);\n iconImg.setRotation(\n placementAngle +\n deg2rad(\n getValue(\n layer,\n 'layout',\n 'icon-rotate',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n ),\n );\n iconImg.setOpacity(\n getValue(\n layer,\n 'paint',\n 'icon-opacity',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n iconImg.setAnchor(\n anchor[\n getValue(\n layer,\n 'layout',\n 'icon-anchor',\n zoom,\n f,\n functionCache,\n featureState,\n )\n ],\n );\n style.setImage(iconImg);\n text = style.getText();\n style.setText(undefined);\n style.setZIndex(index);\n hasImage = true;\n skipLabel = false;\n }\n } else {\n skipLabel = true;\n }\n }\n }\n }\n\n if (type == 1 && layer.type === 'circle') {\n ++stylesLength;\n style = styles[stylesLength];\n if (\n !style ||\n !style.getImage() ||\n style.getFill() ||\n style.getStroke()\n ) {\n style = new Style();\n styles[stylesLength] = style;\n }\n const circleRadius =\n 'circle-radius' in paint\n ? getValue(\n layer,\n 'paint',\n 'circle-radius',\n zoom,\n f,\n functionCache,\n featureState,\n )\n : 5;\n const circleStrokeColor = colorWithOpacity(\n getValue(\n layer,\n 'paint',\n 'circle-stroke-color',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n getValue(\n layer,\n 'paint',\n 'circle-stroke-opacity',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n\n const circleTranslate = getValue(\n layer,\n 'paint',\n 'circle-translate',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const circleColor = colorWithOpacity(\n getValue(\n layer,\n 'paint',\n 'circle-color',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n getValue(\n layer,\n 'paint',\n 'circle-opacity',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n const circleStrokeWidth = getValue(\n layer,\n 'paint',\n 'circle-stroke-width',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const cache_key =\n circleRadius +\n '.' +\n circleStrokeColor +\n '.' +\n circleColor +\n '.' +\n circleStrokeWidth +\n '.' +\n circleTranslate[0] +\n '.' +\n circleTranslate[1];\n\n iconImg = iconImageCache[cache_key];\n if (!iconImg) {\n iconImg = new Circle({\n radius: circleRadius,\n displacement: [circleTranslate[0], -circleTranslate[1]],\n stroke:\n circleStrokeColor && circleStrokeWidth > 0\n ? new Stroke({\n width: circleStrokeWidth,\n color: circleStrokeColor,\n })\n : undefined,\n fill: circleColor\n ? new Fill({\n color: circleColor,\n })\n : undefined,\n declutterMode: 'none',\n });\n iconImageCache[cache_key] = iconImg;\n }\n style.setImage(iconImg);\n text = style.getText();\n style.setText(undefined);\n style.setGeometry(undefined);\n style.setZIndex(index);\n hasImage = true;\n }\n\n let label, font, textLineHeight, textSize, letterSpacing, maxTextWidth;\n if ('text-field' in layout) {\n textSize = Math.round(\n getValue(\n layer,\n 'layout',\n 'text-size',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n const fontArray = getValue(\n layer,\n 'layout',\n 'text-font',\n zoom,\n f,\n functionCache,\n featureState,\n );\n textLineHeight = getValue(\n layer,\n 'layout',\n 'text-line-height',\n zoom,\n f,\n functionCache,\n featureState,\n );\n font = mb2css(\n getFonts\n ? getFonts(\n fontArray,\n glStyle.metadata\n ? glStyle.metadata['ol:webfonts']\n : undefined,\n )\n : fontArray,\n textSize,\n textLineHeight,\n );\n if (!font.includes('sans-serif')) {\n font += ',sans-serif';\n }\n letterSpacing = getValue(\n layer,\n 'layout',\n 'text-letter-spacing',\n zoom,\n f,\n functionCache,\n featureState,\n );\n maxTextWidth = getValue(\n layer,\n 'layout',\n 'text-max-width',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const textField = getValue(\n layer,\n 'layout',\n 'text-field',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (typeof textField === 'object' && textField.sections) {\n if (textField.sections.length === 1) {\n label = textField.toString();\n } else {\n label = textField.sections.reduce((acc, chunk, i) => {\n const fonts = chunk.fontStack\n ? chunk.fontStack.split(',')\n : fontArray;\n const chunkFont = mb2css(\n getFonts ? getFonts(fonts) : fonts,\n textSize * (chunk.scale || 1),\n textLineHeight,\n );\n let text = chunk.text;\n if (text === '\\n') {\n acc.push('\\n', '');\n return acc;\n }\n if (type == 2) {\n acc.push(applyLetterSpacing(text, letterSpacing), chunkFont);\n return acc;\n }\n text = wrapText(\n text,\n chunkFont,\n maxTextWidth,\n letterSpacing,\n ).split('\\n');\n for (let i = 0, ii = text.length; i < ii; ++i) {\n if (i > 0) {\n acc.push('\\n', '');\n }\n acc.push(text[i], chunkFont);\n }\n return acc;\n }, []);\n }\n } else {\n label = fromTemplate(textField, properties).trim();\n }\n opacity = getValue(\n layer,\n 'paint',\n 'text-opacity',\n zoom,\n f,\n functionCache,\n featureState,\n );\n }\n if (label && opacity && !skipLabel) {\n if (!hasImage) {\n ++stylesLength;\n style = styles[stylesLength];\n if (\n !style ||\n !style.getText() ||\n style.getFill() ||\n style.getStroke()\n ) {\n style = new Style();\n styles[stylesLength] = style;\n }\n style.setImage(undefined);\n style.setGeometry(undefined);\n }\n const declutterMode = getDeclutterMode(\n layer,\n zoom,\n f,\n 'text',\n functionCache,\n );\n if (!style.getText()) {\n style.setText(text);\n }\n text = style.getText();\n if (\n !text ||\n ('getDeclutterMode' in text &&\n text.getDeclutterMode() !== declutterMode)\n ) {\n text = new Text({\n padding: [2, 2, 2, 2],\n // @ts-ignore\n declutterMode: declutterMode,\n });\n style.setText(text);\n }\n const textTransform = getValue(\n layer,\n 'layout',\n 'text-transform',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (textTransform == 'uppercase') {\n label = Array.isArray(label)\n ? label.map((t, i) => (i % 2 ? t : t.toUpperCase()))\n : label.toUpperCase();\n } else if (textTransform == 'lowercase') {\n label = Array.isArray(label)\n ? label.map((t, i) => (i % 2 ? t : t.toLowerCase()))\n : label.toLowerCase();\n }\n const wrappedLabel = Array.isArray(label)\n ? label\n : type == 2\n ? applyLetterSpacing(label, letterSpacing)\n : wrapText(label, font, maxTextWidth, letterSpacing);\n text.setText(wrappedLabel);\n text.setFont(font);\n text.setRotation(\n deg2rad(\n getValue(\n layer,\n 'layout',\n 'text-rotate',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n ),\n );\n if (typeof text.setKeepUpright === 'function') {\n const keepUpright = getValue(\n layer,\n 'layout',\n 'text-keep-upright',\n zoom,\n f,\n functionCache,\n featureState,\n );\n text.setKeepUpright(keepUpright);\n }\n const textAnchor = getValue(\n layer,\n 'layout',\n 'text-anchor',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const placement =\n hasImage || type == 1\n ? 'point'\n : getValue(\n layer,\n 'layout',\n 'symbol-placement',\n zoom,\n f,\n functionCache,\n featureState,\n );\n let textAlign;\n if (placement === 'line-center') {\n text.setPlacement('line');\n textAlign = 'center';\n } else {\n text.setPlacement(placement);\n }\n if (placement === 'line' && typeof text.setRepeat === 'function') {\n const symbolSpacing = getValue(\n layer,\n 'layout',\n 'symbol-spacing',\n zoom,\n f,\n functionCache,\n featureState,\n );\n text.setRepeat(symbolSpacing * 2);\n }\n text.setOverflow(placement === 'point');\n let textHaloWidth = getValue(\n layer,\n 'paint',\n 'text-halo-width',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const textOffset = getValue(\n layer,\n 'layout',\n 'text-offset',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const textTranslate = getValue(\n layer,\n 'paint',\n 'text-translate',\n zoom,\n f,\n functionCache,\n featureState,\n );\n // Text offset has to take halo width and line height into account\n let vOffset = 0;\n let hOffset = 0;\n if (placement == 'point') {\n textAlign = 'center';\n if (textAnchor.indexOf('left') !== -1) {\n textAlign = 'left';\n hOffset = textHaloWidth;\n } else if (textAnchor.indexOf('right') !== -1) {\n textAlign = 'right';\n hOffset = -textHaloWidth;\n }\n const textRotationAlignment = getValue(\n layer,\n 'layout',\n 'text-rotation-alignment',\n zoom,\n f,\n functionCache,\n featureState,\n );\n text.setRotateWithView(textRotationAlignment == 'map');\n } else {\n text.setMaxAngle(\n (deg2rad(\n getValue(\n layer,\n 'layout',\n 'text-max-angle',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n ) *\n label.length) /\n wrappedLabel.length,\n );\n text.setRotateWithView(false);\n }\n text.setTextAlign(textAlign);\n let textBaseline = 'middle';\n if (textAnchor.indexOf('bottom') == 0) {\n textBaseline = 'bottom';\n vOffset = -textHaloWidth - 0.5 * (textLineHeight - 1) * textSize;\n } else if (textAnchor.indexOf('top') == 0) {\n textBaseline = 'top';\n vOffset = textHaloWidth + 0.5 * (textLineHeight - 1) * textSize;\n }\n text.setTextBaseline(textBaseline);\n const textJustify = getValue(\n layer,\n 'layout',\n 'text-justify',\n zoom,\n f,\n functionCache,\n featureState,\n );\n text.setJustify(textJustify === 'auto' ? undefined : textJustify);\n text.setOffsetX(\n textOffset[0] * textSize + hOffset + textTranslate[0],\n );\n text.setOffsetY(\n textOffset[1] * textSize + vOffset + textTranslate[1],\n );\n textColor.setColor(\n colorWithOpacity(\n getValue(\n layer,\n 'paint',\n 'text-color',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n opacity,\n ),\n );\n text.setFill(textColor);\n const haloColor = colorWithOpacity(\n getValue(\n layer,\n 'paint',\n 'text-halo-color',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n opacity,\n );\n if (haloColor && textHaloWidth > 0) {\n textHalo.setColor(haloColor);\n // spec here : https://docs.mapbox.com/mapbox-gl-js/style-spec/#paint-symbol-text-halo-width\n // Halo width must be doubled because it is applied around the center of the text outline\n textHaloWidth *= 2;\n // 1/4 of text size (spec) x 2\n const halfTextSize = 0.5 * textSize;\n textHalo.setWidth(\n textHaloWidth <= halfTextSize ? textHaloWidth : halfTextSize,\n );\n text.setStroke(textHalo);\n } else {\n text.setStroke(undefined);\n }\n const textPadding = getValue(\n layer,\n 'layout',\n 'text-padding',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const padding = text.getPadding();\n if (textPadding !== padding[0]) {\n padding[0] = textPadding;\n padding[1] = textPadding;\n padding[2] = textPadding;\n padding[3] = textPadding;\n }\n style.setZIndex(index);\n }\n }\n }\n\n if (stylesLength > -1) {\n styles.length = stylesLength + 1;\n if (recordLayer) {\n if ('set' in feature) {\n // ol/Feature\n feature.set('mapbox-layer', featureBelongsToLayer);\n } else {\n // ol/render/Feature\n feature.getProperties()['mapbox-layer'] = featureBelongsToLayer;\n }\n }\n return styles;\n }\n return undefined;\n };\n\n olLayer.setStyle(styleFunction);\n olLayer.set('mapbox-source', mapboxSource);\n olLayer.set('mapbox-layers', mapboxLayers);\n olLayer.set('mapbox-featurestate', olLayer.get('mapbox-featurestate') || {});\n return styleFunction;\n}\n\n/**\n * Get the the style for a specific Mapbox layer only. This can be useful for creating a legend.\n * @param {import(\"ol/Feature\").default|import(\"ol/render/Feature\").default} feature OpenLayers feature.\n * @param {number} resolution View resolution.\n * @param {import(\"ol/layer\").Vector|import(\"ol/layer\").VectorTile} olLayer OpenLayers layer.\n * @param {string} layerId Id of the Mapbox layer to get the style for\n * @return {Array} Styles for the provided Mapbox layer.\n */\nexport function getStyleForLayer(feature, resolution, olLayer, layerId) {\n const evaluateStyle = olLayer.getStyleFunction();\n if (evaluateStyle.length === 3) {\n // @ts-ignore\n return evaluateStyle(feature, resolution, layerId);\n }\n return undefined;\n}\n\nexport {\n colorWithOpacity as _colorWithOpacity,\n evaluateFilter as _evaluateFilter,\n fromTemplate as _fromTemplate,\n getValue as _getValue,\n};\n","/**\n * Generates a shaded relief image given elevation data. Uses a 3x3\n * neighborhood for determining slope and aspect.\n * @param {Array} inputs Array of input images.\n * @param {Object} data Data added in the \"beforeoperations\" event.\n * @return {ImageData} Output image.\n */\nexport function hillshade(inputs, data) {\n const elevationImage = inputs[0];\n const width = elevationImage.width;\n const height = elevationImage.height;\n const elevationData = elevationImage.data;\n const shadeData = new Uint8ClampedArray(elevationData.length);\n const dp = data.resolution * 2;\n const maxX = width - 1;\n const maxY = height - 1;\n const pixel = [0, 0, 0, 0];\n const twoPi = 2 * Math.PI;\n const halfPi = Math.PI / 2;\n const sunEl = (Math.PI * data.sunEl) / 180;\n const sunAz = (Math.PI * data.sunAz) / 180;\n const cosSunEl = Math.cos(sunEl);\n const sinSunEl = Math.sin(sunEl);\n const highlightColor = data.highlightColor;\n const shadowColor = data.shadowColor;\n const accentColor = data.accentColor;\n const encoding = data.encoding;\n\n let pixelX,\n pixelY,\n x0,\n x1,\n y0,\n y1,\n offset,\n z0,\n z1,\n dzdx,\n dzdy,\n slope,\n aspect,\n accent,\n scaled,\n shade,\n scaledAccentColor,\n compositeShadeColor,\n clamp,\n slopeScaleBase,\n scaledSlope,\n cosIncidence;\n\n function calculateElevation(pixel, encoding = 'mapbox') {\n // The method used to extract elevations from the DEM.\n //\n // The supported methods are the Mapbox format\n // (red * 256 * 256 + green * 256 + blue) * 0.1 - 10000\n // and the Terrarium format\n // (red * 256 + green + blue / 256) - 32768\n //\n if (encoding === 'mapbox') {\n return (pixel[0] * 256 * 256 + pixel[1] * 256 + pixel[2]) * 0.1 - 10000;\n }\n if (encoding === 'terrarium') {\n return pixel[0] * 256 + pixel[1] + pixel[2] / 256 - 32768;\n }\n }\n for (pixelY = 0; pixelY <= maxY; ++pixelY) {\n y0 = pixelY === 0 ? 0 : pixelY - 1;\n y1 = pixelY === maxY ? maxY : pixelY + 1;\n for (pixelX = 0; pixelX <= maxX; ++pixelX) {\n x0 = pixelX === 0 ? 0 : pixelX - 1;\n x1 = pixelX === maxX ? maxX : pixelX + 1;\n\n // determine elevation for (x0, pixelY)\n offset = (pixelY * width + x0) * 4;\n pixel[0] = elevationData[offset];\n pixel[1] = elevationData[offset + 1];\n pixel[2] = elevationData[offset + 2];\n pixel[3] = elevationData[offset + 3];\n z0 = data.vert * calculateElevation(pixel, encoding);\n\n // determine elevation for (x1, pixelY)\n offset = (pixelY * width + x1) * 4;\n pixel[0] = elevationData[offset];\n pixel[1] = elevationData[offset + 1];\n pixel[2] = elevationData[offset + 2];\n pixel[3] = elevationData[offset + 3];\n z1 = data.vert * calculateElevation(pixel, encoding);\n\n dzdx = (z1 - z0) / dp;\n\n // determine elevation for (pixelX, y0)\n offset = (y0 * width + pixelX) * 4;\n pixel[0] = elevationData[offset];\n pixel[1] = elevationData[offset + 1];\n pixel[2] = elevationData[offset + 2];\n pixel[3] = elevationData[offset + 3];\n z0 = data.vert * calculateElevation(pixel, encoding);\n\n // determine elevation for (pixelX, y1)\n offset = (y1 * width + pixelX) * 4;\n pixel[0] = elevationData[offset];\n pixel[1] = elevationData[offset + 1];\n pixel[2] = elevationData[offset + 2];\n pixel[3] = elevationData[offset + 3];\n z1 = data.vert * calculateElevation(pixel, encoding);\n\n dzdy = (z1 - z0) / dp;\n\n aspect = Math.atan2(dzdy, -dzdx);\n if (aspect < 0) {\n aspect = halfPi - aspect;\n } else if (aspect > halfPi) {\n aspect = twoPi - aspect + halfPi;\n } else {\n aspect = halfPi - aspect;\n }\n\n // Bootstrap slope and corresponding incident values\n slope = Math.atan(Math.sqrt(dzdx * dzdx + dzdy * dzdy));\n cosIncidence =\n sinSunEl * Math.cos(slope) +\n cosSunEl * Math.sin(slope) * Math.cos(sunAz - aspect);\n accent = Math.cos(slope);\n // 255 for Hex colors\n scaled = 255 * cosIncidence;\n\n /*\n * The following is heavily inspired\n * by [Maplibre's equivalent WebGL shader](https://github.com/maplibre/maplibre-gl-js/blob/main/src/shaders/hillshade.fragment.glsl)\n */\n\n // Forces given value to stay between two given extremes\n clamp = Math.min(Math.max(2 * data.sunEl, 0), 1);\n\n // Intensity basis for hillshade opacity\n slopeScaleBase = 1.875 - data.opacity * 1.75;\n // Intensity interpolation so that higher intensity values create more opaque hillshading\n scaledSlope =\n data.opacity !== 0.5\n ? halfPi *\n ((Math.pow(slopeScaleBase, slope) - 1) /\n (Math.pow(slopeScaleBase, halfPi) - 1))\n : slope;\n\n // Accent hillshade color with given accentColor to emphasize rougher terrain\n scaledAccentColor = {\n r: (1 - accent) * accentColor.r * clamp * 255,\n g: (1 - accent) * accentColor.g * clamp * 255,\n b: (1 - accent) * accentColor.b * clamp * 255,\n a: (1 - accent) * accentColor.a * clamp * 255,\n };\n\n // Allows highlight vs shadow discrimination\n shade = Math.abs((((aspect + sunAz) / Math.PI + 0.5) % 2) - 1);\n // Creates a composite color mix between highlight & shadow colors to emphasize slopes\n compositeShadeColor = {\n r: (highlightColor.r * (1 - shade) + shadowColor.r * shade) * scaled,\n g: (highlightColor.g * (1 - shade) + shadowColor.g * shade) * scaled,\n b: (highlightColor.b * (1 - shade) + shadowColor.b * shade) * scaled,\n a: (highlightColor.a * (1 - shade) + shadowColor.a * shade) * scaled,\n };\n\n // Fill in result color value\n offset = (pixelY * width + pixelX) * 4;\n shadeData[offset] =\n scaledAccentColor.r * (1 - shade) + compositeShadeColor.r;\n shadeData[offset + 1] =\n scaledAccentColor.g * (1 - shade) + compositeShadeColor.g;\n shadeData[offset + 2] =\n scaledAccentColor.b * (1 - shade) + compositeShadeColor.b;\n // Key opacity on the scaledSlope to improve legibility by increasing higher elevation rates' contrast\n shadeData[offset + 3] =\n elevationData[offset + 3] *\n data.opacity *\n clamp *\n Math.sin(scaledSlope);\n }\n }\n\n return new ImageData(shadeData, width, height);\n}\n","/*\nol-mapbox-style - Use Mapbox/MapLibre Style objects with OpenLayers\nCopyright 2016-present ol-mapbox-style contributors\nLicense: https://raw.githubusercontent.com/openlayers/ol-mapbox-style/master/LICENSE\n*/\n\nimport GeoJSON from 'ol/format/GeoJSON.js';\nimport ImageLayer from 'ol/layer/Image.js';\nimport Layer from 'ol/layer/Layer.js';\nimport LayerGroup from 'ol/layer/Group.js';\nimport MVT from 'ol/format/MVT.js';\nimport Map from 'ol/Map.js';\nimport Raster from 'ol/source/Raster.js';\nimport Source from 'ol/source/Source.js';\nimport TileGrid from 'ol/tilegrid/TileGrid.js';\nimport TileJSON from 'ol/source/TileJSON.js';\nimport TileLayer from 'ol/layer/Tile.js';\nimport VectorLayer from 'ol/layer/Vector.js';\nimport VectorSource from 'ol/source/Vector.js';\nimport VectorTileLayer from 'ol/layer/VectorTile.js';\nimport VectorTileSource, {defaultLoadFunction} from 'ol/source/VectorTile.js';\nimport View from 'ol/View.js';\nimport derefLayers from '@mapbox/mapbox-gl-style-spec/deref.js';\nimport {METERS_PER_UNIT} from 'ol/proj/Units.js';\nimport {\n _colorWithOpacity,\n stylefunction as applyStylefunction,\n getValue,\n styleFunctionArgs,\n} from './stylefunction.js';\nimport {bbox as bboxStrategy} from 'ol/loadingstrategy.js';\nimport {createXYZ} from 'ol/tilegrid.js';\nimport {\n defaultResolutions,\n fetchResource,\n getFilterCache,\n getFunctionCache,\n getGlStyle,\n getResolutionForZoom,\n getStyleFunctionKey,\n getTileJson,\n getZoomForResolution,\n} from './util.js';\nimport {\n equivalent,\n fromLonLat,\n getPointResolution,\n get as getProjection,\n getUserProjection,\n} from 'ol/proj.js';\nimport {getCenter, getTopLeft} from 'ol/extent.js';\nimport {getFonts} from './text.js';\nimport {hillshade} from './shaders.js';\nimport {\n normalizeSourceUrl,\n normalizeSpriteUrl,\n normalizeStyleUrl,\n} from './mapbox.js';\n\n/**\n * @typedef {Object} FeatureIdentifier\n * @property {string|number} id The feature id.\n * @property {string} source The source id.\n */\n\n/**\n * @typedef {Object} Options\n * @property {string} [accessToken] Access token for 'mapbox://' urls.\n * @property {function(string, import(\"./util.js\").ResourceType): (Request|string|Promise|void)} [transformRequest]\n * Function for controlling how `ol-mapbox-style` fetches resources. Can be used for modifying\n * the url, adding headers or setting credentials options. Called with the url and the resource\n * type as arguments, this function is supposed to return a `Request` or a url `string`, or a promise tehereof.\n * Without a return value the original request will not be modified.\n * @property {string} [projection='EPSG:3857'] Only useful when working with non-standard projections.\n * Code of a projection registered with OpenLayers. All sources of the style must be provided in this\n * projection. The projection must also have a valid extent defined, which will be used to determine the\n * origin and resolutions of the tile grid for all tiled sources of the style. When provided, the bbox\n * placeholder in tile and geojson urls changes: the default is `{bbox-epsg-3857}`, when projection is e.g.\n * set to `EPSG:4326`, the bbox placeholder will be `{bbox-epsg-4326}`.\n * @property {Array} [resolutions] Only useful when working with non-standard projections.\n * Resolutions for mapping resolution to the `zoom` used in the Mapbox/MapLibre style.\n * @property {string} [styleUrl] URL of the Mapbox GL style. Required for styles that were provided\n * as object, when they contain a relative sprite url, or sources referencing data by relative url.\n * @property {string} [webfonts] Template for resolving webfonts. Can be used to specify where to fetch\n * web fonts when no `ol:webfonts` metadata is set in the style object. See `getFonts()` and the\n * \"Font handling\" section in `README.md` for details.\n * @property {function(VectorLayer|VectorTileLayer, string):HTMLImageElement|HTMLCanvasElement|string|undefined} [getImage=undefined]\n * Function that returns an image for an icon name. If the result is an HTMLImageElement, it must already be\n * loaded. The layer can be used to call layer.changed() when the loading and processing of the image has finished.\n * This function be used for icons not in the sprite or to override sprite icons.\n * @property {string} [accessTokenParam='access_token'] Access token param. For internal use.\n */\n\n/**\n * @typedef {Object} ApplyStyleOptions\n * @property {string} [source=''] Source. Default is `''`, which causes the first source in the\n * style to be used.\n * @property {Array} [layers] Layers. If no source is provided, the layers with the\n * provided ids will be used from the style's `layers` array. All layers need to use the same source.\n * @property {boolean} [updateSource=true] Update or create vector (tile) layer source with parameters\n * specified for the source in the mapbox style definition.\n */\n\n/**\n * @param {import(\"ol/proj/Projection.js\").default} projection Projection.\n * @param {number} [tileSize=512] Tile size.\n * @return {Array} Resolutions.\n */\nfunction getTileResolutions(projection, tileSize = 512) {\n return projection.getExtent()\n ? createXYZ({\n extent: projection.getExtent(),\n tileSize: tileSize,\n maxZoom: 22,\n }).getResolutions()\n : defaultResolutions;\n}\n\n/**\n * @param {string} styleUrl Style URL.\n * @param {Options} options Options.\n * @return {Options} Completed options with accessToken and accessTokenParam.\n */\nfunction completeOptions(styleUrl, options) {\n if (!options.accessToken) {\n options = Object.assign({}, options);\n const searchParams = new URL(styleUrl).searchParams;\n // The last search parameter is the access token\n searchParams.forEach((value, key) => {\n options.accessToken = value;\n options.accessTokenParam = key;\n });\n }\n return options;\n}\n\n/**\n * Applies a style function to an `ol/layer/VectorTile` or `ol/layer/Vector`\n * with an `ol/source/VectorTile` or an `ol/source/Vector`. If the layer does not have a source\n * yet, it will be created and populated from the information in the `glStyle` (unless `updateSource` is\n * set to `false`).\n *\n * **Example:**\n * ```js\n * import {applyStyle} from 'ol-mapbox-style';\n * import {VectorTile} from 'ol/layer.js';\n *\n * const layer = new VectorTile({declutter: true});\n * applyStyle(layer, 'https://api.maptiler.com/maps/basic/style.json?key=YOUR_OPENMAPTILES_TOKEN');\n * ```\n *\n * The style function will render all layers from the `glStyle` object that use the source\n * of the first layer, the specified `source`, or a subset of layers from the same source. The\n * source needs to be a `\"type\": \"vector\"` or `\"type\": \"geojson\"` source.\n *\n * Two additional properties will be set on the provided layer:\n *\n * * `mapbox-source`: The `id` of the Mapbox/MapLibre Style document's source that the\n * OpenLayers layer was created from. Usually `apply()` creates one\n * OpenLayers layer per Mapbox/MapLibre Style source, unless the layer stack has\n * layers from different sources in between.\n * * `mapbox-layers`: The `id`s of the Mapbox/MapLibre Style document's layers that are\n * included in the OpenLayers layer.\n *\n * @param {VectorTileLayer|VectorLayer} layer OpenLayers layer. When the layer has a source configured,\n * it will be modified to use the configuration from the glStyle's `source`. Options specified on the\n * layer's source will override those from the glStyle's `source`, except for `url` and\n * `tileUrlFunction`. When the source projection is the default (`EPSG:3857`), the `tileGrid` will\n * also be overridden. If you'd rather not have ol-mapbox-style modify the source, configure `applyStyle()`\n * with the `updateSource: false` option.\n * @param {string|Object} glStyle Mapbox/MapLibre Style object.\n * @param {string|Array|Options&ApplyStyleOptions} [sourceOrLayersOrOptions] Options or\n * `source` key or an array of layer `id`s from the Mapbox/MapLibre Style object. When a `source` key is\n * provided, all layers for the specified source will be included in the style function. When layer\n * `id`s are provided, they must be from layers that use the same source. When not provided or a falsey\n * value, all layers using the first source specified in the glStyle will be rendered.\n * @param {Options&ApplyStyleOptions|string} [optionsOrPath] **Deprecated**. Options. Alternatively the path of the style file\n * (only required when a relative path is used for the `\"sprite\"` property of the style).\n * @param {Array} [resolutions] **Deprecated**. Resolutions for mapping resolution to zoom level.\n * Only needed when working with non-standard tile grids or projections, can also be supplied with\n * options.\n * @return {Promise} Promise which will be resolved when the style can be used\n * for rendering.\n */\nexport function applyStyle(\n layer,\n glStyle,\n sourceOrLayersOrOptions = '',\n optionsOrPath = {},\n resolutions = undefined,\n) {\n let styleUrl, sourceId;\n /** @type {Options&ApplyStyleOptions} */\n let options;\n let sourceOrLayers;\n let updateSource = true;\n if (\n typeof sourceOrLayersOrOptions !== 'string' &&\n !Array.isArray(sourceOrLayersOrOptions)\n ) {\n options = sourceOrLayersOrOptions;\n sourceOrLayers = options.source || options.layers;\n optionsOrPath = options;\n } else {\n sourceOrLayers = sourceOrLayersOrOptions;\n }\n if (typeof optionsOrPath === 'string') {\n styleUrl = optionsOrPath;\n options = {};\n } else {\n styleUrl = optionsOrPath.styleUrl;\n options = optionsOrPath;\n }\n if (options.updateSource === false) {\n updateSource = false;\n }\n if (!resolutions) {\n resolutions = options.resolutions;\n }\n if (\n !styleUrl &&\n typeof glStyle === 'string' &&\n !glStyle.trim().startsWith('{')\n ) {\n styleUrl = glStyle;\n }\n if (styleUrl) {\n styleUrl = styleUrl.startsWith('data:')\n ? location.href\n : normalizeStyleUrl(styleUrl, options.accessToken);\n options = completeOptions(styleUrl, options);\n }\n\n return new Promise(function (resolve, reject) {\n // TODO: figure out where best place to check source type is\n // Note that the source arg is an array of gl layer ids and each must be\n // dereferenced to get source type to validate\n getGlStyle(glStyle, options)\n .then(function (glStyle) {\n if (glStyle.version != 8) {\n return reject(new Error('glStyle version 8 required.'));\n }\n if (\n !(layer instanceof VectorLayer || layer instanceof VectorTileLayer)\n ) {\n return reject(\n new Error('Can only apply to VectorLayer or VectorTileLayer'),\n );\n }\n\n const type = layer instanceof VectorTileLayer ? 'vector' : 'geojson';\n if (!sourceOrLayers) {\n sourceId = Object.keys(glStyle.sources).find(function (key) {\n return glStyle.sources[key].type === type;\n });\n sourceOrLayers = sourceId;\n } else if (Array.isArray(sourceOrLayers)) {\n sourceId = glStyle.layers.find(function (layer) {\n return layer.id === sourceOrLayers[0];\n }).source;\n } else {\n sourceId = sourceOrLayers;\n }\n if (!sourceId) {\n return reject(new Error(`No ${type} source found in the glStyle.`));\n }\n\n function assignSource() {\n if (!updateSource) {\n return Promise.resolve();\n }\n if (layer instanceof VectorTileLayer) {\n return setupVectorSource(\n glStyle.sources[sourceId],\n styleUrl,\n options,\n ).then(function (source) {\n const targetSource = layer.getSource();\n if (!targetSource) {\n layer.setSource(source);\n } else if (source !== targetSource) {\n targetSource.setTileUrlFunction(source.getTileUrlFunction());\n if (\n typeof targetSource.setUrls === 'function' &&\n typeof source.getUrls === 'function'\n ) {\n // to get correct keys for tile cache and queue\n targetSource.setUrls(source.getUrls());\n }\n //@ts-ignore\n if (!targetSource.format_) {\n //@ts-ignore\n targetSource.format_ = source.format_;\n }\n if (!targetSource.getAttributions()) {\n targetSource.setAttributions(source.getAttributions());\n }\n if (\n targetSource.getTileLoadFunction() === defaultLoadFunction\n ) {\n targetSource.setTileLoadFunction(\n source.getTileLoadFunction(),\n );\n }\n if (\n equivalent(\n targetSource.getProjection(),\n source.getProjection(),\n )\n ) {\n targetSource.tileGrid = source.getTileGrid();\n }\n }\n const tileGrid = layer.getSource().getTileGrid();\n if (\n !isFinite(layer.getMaxResolution()) &&\n !isFinite(layer.getMinZoom()) &&\n tileGrid.getMinZoom() > 0\n ) {\n layer.setMaxResolution(\n getResolutionForZoom(\n Math.max(0, tileGrid.getMinZoom() - 1e-12),\n tileGrid.getResolutions(),\n ),\n );\n }\n });\n }\n const glSource = glStyle.sources[sourceId];\n let source = layer.getSource();\n if (!source || source.get('mapbox-source') !== glSource) {\n source = setupGeoJSONSource(glSource, styleUrl, options);\n }\n const targetSource = /** @type {VectorSource} */ (layer.getSource());\n if (!targetSource) {\n layer.setSource(source);\n } else if (source !== targetSource) {\n if (!targetSource.getAttributions()) {\n targetSource.setAttributions(source.getAttributions());\n }\n //@ts-ignore\n if (!targetSource.format_) {\n //@ts-ignore\n targetSource.format_ = source.getFormat();\n }\n //@ts-ignore\n targetSource.url_ = source.getUrl();\n }\n return Promise.resolve();\n }\n\n let spriteScale, spriteData, spriteImageUrl, style;\n function onChange() {\n if (!style && (!glStyle.sprite || spriteData)) {\n if (options.projection && !resolutions) {\n const projection = getProjection(options.projection);\n const units = projection.getUnits();\n if (units !== 'm') {\n resolutions = defaultResolutions.map(\n (resolution) => resolution / METERS_PER_UNIT[units],\n );\n }\n }\n style = applyStylefunction(\n layer,\n glStyle,\n sourceOrLayers,\n resolutions,\n spriteData,\n spriteImageUrl,\n (fonts, templateUrl = options.webfonts) =>\n getFonts(fonts, templateUrl),\n options.getImage,\n );\n if (!layer.getStyle()) {\n reject(new Error(`Nothing to show for source [${sourceId}]`));\n } else {\n assignSource().then(resolve).catch(reject);\n }\n } else if (style) {\n layer.setStyle(style);\n assignSource().then(resolve).catch(reject);\n } else {\n reject(new Error('Something went wrong trying to apply style.'));\n }\n }\n\n if (glStyle.sprite) {\n const sprite = new URL(\n normalizeSpriteUrl(\n glStyle.sprite,\n options.accessToken,\n styleUrl || location.href,\n ),\n );\n spriteScale = window.devicePixelRatio >= 1.5 ? 0.5 : 1;\n const sizeFactor = spriteScale == 0.5 ? '@2x' : '';\n let spriteUrl =\n sprite.origin +\n sprite.pathname +\n sizeFactor +\n '.json' +\n sprite.search;\n\n new Promise(function (resolve, reject) {\n fetchResource('Sprite', spriteUrl, options)\n .then(resolve)\n .catch(function (error) {\n spriteUrl =\n sprite.origin + sprite.pathname + '.json' + sprite.search;\n fetchResource('Sprite', spriteUrl, options)\n .then(resolve)\n .catch(reject);\n });\n })\n .then(function (spritesJson) {\n if (spritesJson === undefined) {\n reject(new Error('No sprites found.'));\n }\n spriteData = spritesJson;\n spriteImageUrl =\n sprite.origin +\n sprite.pathname +\n sizeFactor +\n '.png' +\n sprite.search;\n if (options.transformRequest) {\n const transformed =\n options.transformRequest(spriteImageUrl, 'SpriteImage') ||\n spriteImageUrl;\n if (\n transformed instanceof Request ||\n transformed instanceof Promise\n ) {\n spriteImageUrl = transformed;\n }\n }\n onChange();\n })\n .catch(function (err) {\n reject(\n new Error(\n `Sprites cannot be loaded: ${spriteUrl}: ${err.message}`,\n ),\n );\n });\n } else {\n onChange();\n }\n })\n .catch(reject);\n });\n}\n\nconst emptyObj = {};\n\nfunction setFirstBackground(mapOrLayer, glStyle, options) {\n glStyle.layers.some(function (layer) {\n if (layer.type === 'background') {\n if (mapOrLayer instanceof Layer) {\n mapOrLayer.setBackground(function (resolution) {\n return getBackgroundColor(layer, resolution, options, {});\n });\n return true;\n }\n if (mapOrLayer instanceof Map || mapOrLayer instanceof LayerGroup) {\n mapOrLayer\n .getLayers()\n .insertAt(0, setupBackgroundLayer(layer, options, {}));\n return true;\n }\n }\n });\n}\n\n/**\n * Applies properties of the Mapbox/MapLibre Style's first `background` layer to the\n * provided map or layer (group).\n *\n * **Example:**\n * ```js\n * import {applyBackground} from 'ol-mapbox-style';\n * import {Map} from 'ol';\n *\n * const map = new Map({target: 'map'});\n * applyBackground(map, 'https://api.maptiler.com/maps/basic/style.json?key=YOUR_OPENMAPTILES_TOKEN');\n * ```\n * @param {Map|import(\"ol/layer/Base.js\").default} mapOrLayer OpenLayers Map or layer (group).\n * @param {Object|string} glStyle Mapbox/MapLibre Style object or url.\n * @param {Options} options Options.\n * @return {Promise} Promise that resolves when the background is applied.\n */\nexport function applyBackground(mapOrLayer, glStyle, options = {}) {\n return getGlStyle(glStyle, options).then(function (glStyle) {\n setFirstBackground(mapOrLayer, glStyle, options);\n });\n}\n\nfunction getSourceIdByRef(layers, ref) {\n let sourceId;\n layers.some(function (layer) {\n if (layer.id == ref) {\n sourceId = layer.source;\n return true;\n }\n });\n return sourceId;\n}\n\nfunction extentFromTileJSON(tileJSON, projection) {\n const bounds = tileJSON.bounds;\n if (bounds) {\n const ll = fromLonLat([bounds[0], bounds[1]], projection);\n const tr = fromLonLat([bounds[2], bounds[3]], projection);\n return [ll[0], ll[1], tr[0], tr[1]];\n }\n return getProjection(projection).getExtent();\n}\n\nfunction sourceOptionsFromTileJSON(glSource, tileJSON, options) {\n const tileJSONSource = new TileJSON({\n tileJSON: tileJSON,\n tileSize: glSource.tileSize || tileJSON.tileSize || 512,\n });\n const tileJSONDoc = tileJSONSource.getTileJSON();\n const tileGrid = tileJSONSource.getTileGrid();\n const projection = getProjection(options.projection || 'EPSG:3857');\n const extent = extentFromTileJSON(tileJSONDoc, projection);\n const projectionExtent = projection.getExtent();\n const minZoom = tileJSONDoc.minzoom || 0;\n const maxZoom = tileJSONDoc.maxzoom || 22;\n /** @type {import(\"ol/source/VectorTile.js\").Options} */\n const sourceOptions = {\n attributions: tileJSONSource.getAttributions(),\n projection: projection,\n tileGrid: new TileGrid({\n origin: projectionExtent\n ? getTopLeft(projectionExtent)\n : tileGrid.getOrigin(0),\n extent: extent || tileGrid.getExtent(),\n minZoom: minZoom,\n resolutions: getTileResolutions(projection, tileJSON.tileSize).slice(\n 0,\n maxZoom + 1,\n ),\n tileSize: tileGrid.getTileSize(0),\n }),\n };\n if (Array.isArray(tileJSONDoc.tiles)) {\n sourceOptions.urls = tileJSONDoc.tiles;\n } else {\n sourceOptions.url = tileJSONDoc.tiles;\n }\n return sourceOptions;\n}\n\nfunction getBackgroundColor(glLayer, resolution, options, functionCache) {\n const background = {\n id: glLayer.id,\n type: glLayer.type,\n };\n const layout = glLayer.layout || {};\n const paint = glLayer.paint || {};\n background['paint'] = paint;\n const zoom = getZoomForResolution(\n resolution,\n options.resolutions || defaultResolutions,\n );\n let opacity;\n const bg = getValue(\n background,\n 'paint',\n 'background-color',\n zoom,\n emptyObj,\n functionCache,\n );\n if (paint['background-opacity'] !== undefined) {\n opacity = getValue(\n background,\n 'paint',\n 'background-opacity',\n zoom,\n emptyObj,\n functionCache,\n );\n }\n return layout.visibility == 'none'\n ? undefined\n : _colorWithOpacity(bg, opacity);\n}\n\n/**\n * @param {Object} glLayer Mapbox/MapLibre Style layer object.\n * @param {Options} options Options.\n * @param {Object} functionCache Cache for functions.\n * @return {Layer} OpenLayers layer.\n */\nfunction setupBackgroundLayer(glLayer, options, functionCache) {\n const div = document.createElement('div');\n div.className = 'ol-mapbox-style-background';\n div.style.position = 'absolute';\n div.style.width = '100%';\n div.style.height = '100%';\n return new Layer({\n source: new Source({}),\n render(frameState) {\n const color = getBackgroundColor(\n glLayer,\n frameState.viewState.resolution,\n options,\n functionCache,\n );\n div.style.backgroundColor = color;\n return div;\n },\n });\n}\n\n/**\n * Creates an OpenLayers VectorTile source for a gl source entry.\n * @param {Object} glSource \"source\" entry from a Mapbox/MapLibre Style object.\n * @param {string|undefined} styleUrl URL to use for the source. This is expected to be the complete http(s) url,\n * with access key applied.\n * @param {Options} options Options.\n * @return {Promise} Promise resolving to a VectorTile source.\n * @private\n */\nexport function setupVectorSource(glSource, styleUrl, options) {\n return new Promise(function (resolve, reject) {\n getTileJson(glSource, styleUrl, options)\n .then(function ({tileJson, tileLoadFunction}) {\n const sourceOptions = sourceOptionsFromTileJSON(\n glSource,\n tileJson,\n options,\n );\n sourceOptions.tileLoadFunction = tileLoadFunction;\n sourceOptions.format = new MVT();\n resolve(new VectorTileSource(sourceOptions));\n })\n .catch(reject);\n });\n}\n\nfunction setupVectorLayer(glSource, styleUrl, options) {\n const layer = new VectorTileLayer({\n declutter: true,\n visible: false,\n });\n setupVectorSource(glSource, styleUrl, options)\n .then(function (source) {\n source.set('mapbox-source', glSource);\n layer.setSource(source);\n })\n .catch(function (error) {\n layer.setSource(undefined);\n });\n return layer;\n}\n\nfunction getBboxTemplate(projection) {\n const projCode = projection ? projection.getCode() : 'EPSG:3857';\n return `{bbox-${projCode.toLowerCase().replace(/[^a-z0-9]/g, '-')}}`;\n}\n\nfunction setupRasterSource(glSource, styleUrl, options) {\n return new Promise(function (resolve, reject) {\n getTileJson(glSource, styleUrl, options)\n .then(function ({tileJson, tileLoadFunction}) {\n const source = new TileJSON({\n interpolate:\n options.interpolate === undefined ? true : options.interpolate,\n transition: 0,\n crossOrigin: 'anonymous',\n tileJSON: tileJson,\n });\n source.tileGrid = sourceOptionsFromTileJSON(\n glSource,\n tileJson,\n options,\n ).tileGrid;\n if (options.projection) {\n //@ts-ignore\n source.projection = getProjection(options.projection);\n }\n const getTileUrl = source.getTileUrlFunction();\n if (tileLoadFunction) {\n source.setTileLoadFunction(tileLoadFunction);\n }\n source.setTileUrlFunction(function (tileCoord, pixelRatio, projection) {\n const bboxTemplate = getBboxTemplate(projection);\n let src = getTileUrl(tileCoord, pixelRatio, projection);\n if (src.indexOf(bboxTemplate) != -1) {\n const bbox = source.getTileGrid().getTileCoordExtent(tileCoord);\n src = src.replace(bboxTemplate, bbox.toString());\n }\n return src;\n });\n source.set('mapbox-source', glSource);\n resolve(source);\n })\n .catch(function (error) {\n reject(error);\n });\n });\n}\n\nfunction setupRasterLayer(glSource, styleUrl, options) {\n const layer = new TileLayer();\n setupRasterSource(glSource, styleUrl, options)\n .then(function (source) {\n layer.setSource(source);\n })\n .catch(function () {\n layer.setSource(undefined);\n });\n return layer;\n}\n\n/**\n *\n * @param {Object} glSource \"source\" entry from a Mapbox/MapLibre Style object.\n * @param {string} styleUrl Style url\n * @param {Options} options ol-mapbox-style options.\n * @return {ImageLayer} The raster layer\n */\nfunction setupHillshadeLayer(glSource, styleUrl, options) {\n const tileLayer = setupRasterLayer(glSource, styleUrl, options);\n /** @type {ImageLayer} */\n const layer = new ImageLayer({\n source: new Raster({\n operationType: 'image',\n operation: hillshade,\n sources: [tileLayer],\n }),\n });\n return layer;\n}\n\n/**\n * @param {Object} glSource glStyle source.\n * @param {string} styleUrl Style URL.\n * @param {Options} options Options.\n * @return {VectorSource} Configured vector source.\n */\nfunction setupGeoJSONSource(glSource, styleUrl, options) {\n const geoJsonFormat = options.projection\n ? new GeoJSON({dataProjection: options.projection})\n : new GeoJSON();\n const data = glSource.data;\n const sourceOptions = {};\n if (typeof data == 'string') {\n const [geoJsonUrl] = normalizeSourceUrl(\n data,\n options.accessToken,\n options.accessTokenParam || 'access_token',\n styleUrl || location.href,\n );\n if (/\\{bbox-[0-9a-z-]+\\}/.test(geoJsonUrl)) {\n const extentUrl = (extent, resolution, projection) => {\n const bboxTemplate = getBboxTemplate(projection);\n return geoJsonUrl.replace(bboxTemplate, `${extent.join(',')}`);\n };\n const source = new VectorSource({\n attributions: glSource.attribution,\n format: geoJsonFormat,\n loader: (extent, resolution, projection, success, failure) => {\n const url =\n typeof extentUrl === 'function'\n ? extentUrl(extent, resolution, projection)\n : extentUrl;\n fetchResource('GeoJSON', url, options)\n .then((json) => {\n const features = /** @type {*} */ (\n source\n .getFormat()\n .readFeatures(json, {featureProjection: projection})\n );\n source.addFeatures(features);\n success(features);\n })\n .catch((response) => {\n source.removeLoadedExtent(extent);\n failure();\n });\n },\n strategy: bboxStrategy,\n });\n source.set('mapbox-source', glSource);\n return source;\n }\n const source = new VectorSource({\n attributions: glSource.attribution,\n format: geoJsonFormat,\n url: geoJsonUrl,\n loader: (extent, resolution, projection, success, failure) => {\n fetchResource('GeoJSON', geoJsonUrl, options)\n .then((json) => {\n const features = /** @type {*} */ (\n source\n .getFormat()\n .readFeatures(json, {featureProjection: projection})\n );\n source.addFeatures(features);\n success(features);\n })\n .catch((response) => {\n source.removeLoadedExtent(extent);\n failure();\n });\n },\n });\n return source;\n }\n sourceOptions.features = geoJsonFormat.readFeatures(data, {\n featureProjection: getUserProjection() || 'EPSG:3857',\n });\n\n const source = new VectorSource(\n Object.assign(\n {\n attributions: glSource.attribution,\n format: geoJsonFormat,\n },\n sourceOptions,\n ),\n );\n source.set('mapbox-source', glSource);\n return /** @type {VectorSource} */ (source);\n}\n\nfunction setupGeoJSONLayer(glSource, styleUrl, options) {\n return new VectorLayer({\n declutter: true,\n source: setupGeoJSONSource(glSource, styleUrl, options),\n visible: false,\n });\n}\n\nfunction prerenderRasterLayer(glLayer, layer, functionCache) {\n let zoom = null;\n return function (event) {\n if (\n glLayer.paint &&\n 'raster-opacity' in glLayer.paint &&\n event.frameState.viewState.zoom !== zoom\n ) {\n zoom = event.frameState.viewState.zoom;\n delete functionCache[glLayer.id];\n updateRasterLayerProperties(glLayer, layer, zoom, functionCache);\n }\n };\n}\n\nfunction updateRasterLayerProperties(glLayer, layer, zoom, functionCache) {\n const opacity = getValue(\n glLayer,\n 'paint',\n 'raster-opacity',\n zoom,\n emptyObj,\n functionCache,\n );\n layer.setOpacity(opacity);\n}\n\nfunction manageVisibility(layer, mapOrGroup) {\n function onChange() {\n const glStyle = mapOrGroup.get('mapbox-style');\n if (!glStyle) {\n return;\n }\n const mapboxLayers = derefLayers(glStyle.layers);\n const layerMapboxLayerids = layer.get('mapbox-layers');\n const visible = mapboxLayers\n .filter(function (mapboxLayer) {\n return layerMapboxLayerids.includes(mapboxLayer.id);\n })\n .some(function (mapboxLayer) {\n return (\n !mapboxLayer.layout ||\n !mapboxLayer.layout.visibility ||\n mapboxLayer.layout.visibility === 'visible'\n );\n });\n if (layer.get('visible') !== visible) {\n layer.setVisible(visible);\n }\n }\n layer.on('change', onChange);\n onChange();\n}\n\nexport function setupLayer(glStyle, styleUrl, glLayer, options) {\n const functionCache = getFunctionCache(glStyle);\n const glLayers = glStyle.layers;\n const type = glLayer.type;\n\n const id = glLayer.source || getSourceIdByRef(glLayers, glLayer.ref);\n const glSource = glStyle.sources[id];\n let layer;\n if (type == 'background') {\n layer = setupBackgroundLayer(glLayer, options, functionCache);\n } else if (glSource.type == 'vector') {\n layer = setupVectorLayer(glSource, styleUrl, options);\n } else if (glSource.type == 'raster') {\n layer = setupRasterLayer(glSource, styleUrl, options);\n layer.setVisible(\n glLayer.layout ? glLayer.layout.visibility !== 'none' : true,\n );\n layer.on('prerender', prerenderRasterLayer(glLayer, layer, functionCache));\n } else if (glSource.type == 'geojson') {\n layer = setupGeoJSONLayer(glSource, styleUrl, options);\n } else if (glSource.type == 'raster-dem' && glLayer.type == 'hillshade') {\n const hillshadeLayer = setupHillshadeLayer(glSource, styleUrl, options);\n layer = hillshadeLayer;\n hillshadeLayer.getSource().on('beforeoperations', function (event) {\n const data = event.data;\n data.resolution = getPointResolution(\n options.projection || 'EPSG:3857',\n event.resolution,\n getCenter(event.extent),\n 'm',\n );\n const zoom = getZoomForResolution(\n event.resolution,\n options.resolutions || defaultResolutions,\n );\n data.encoding = glSource.encoding;\n data.vert =\n 5 *\n getValue(\n glLayer,\n 'paint',\n 'hillshade-exaggeration',\n zoom,\n emptyObj,\n functionCache,\n );\n data.sunAz = getValue(\n glLayer,\n 'paint',\n 'hillshade-illumination-direction',\n zoom,\n emptyObj,\n functionCache,\n );\n data.sunEl = 35;\n data.opacity = 0.3;\n data.highlightColor = getValue(\n glLayer,\n 'paint',\n 'hillshade-highlight-color',\n zoom,\n emptyObj,\n functionCache,\n );\n data.shadowColor = getValue(\n glLayer,\n 'paint',\n 'hillshade-shadow-color',\n zoom,\n emptyObj,\n functionCache,\n );\n data.accentColor = getValue(\n glLayer,\n 'paint',\n 'hillshade-accent-color',\n zoom,\n emptyObj,\n functionCache,\n );\n });\n layer.setVisible(\n glLayer.layout ? glLayer.layout.visibility !== 'none' : true,\n );\n }\n const glSourceId = id;\n if (layer) {\n layer.set('mapbox-source', glSourceId);\n }\n return layer;\n}\n\n/**\n * @param {*} glStyle Mapbox/MapLibre Style.\n * @param {Map|LayerGroup} mapOrGroup Map or layer group.\n * @param {string} styleUrl Style URL.\n * @param {Options} options Options.\n * @return {Promise} Promise that resolves when the style is loaded.\n */\nfunction processStyle(glStyle, mapOrGroup, styleUrl, options) {\n const promises = [];\n\n let view = null;\n if (mapOrGroup instanceof Map) {\n view = mapOrGroup.getView();\n if (!view.isDef() && !view.getRotation() && !view.getResolutions()) {\n const projection = options.projection\n ? getProjection(options.projection)\n : view.getProjection();\n view = new View(\n Object.assign(view.getProperties(), {\n maxResolution:\n defaultResolutions[0] / METERS_PER_UNIT[projection.getUnits()],\n projection: options.projection || view.getProjection(),\n }),\n );\n mapOrGroup.setView(view);\n }\n\n if ('center' in glStyle && !view.getCenter()) {\n view.setCenter(fromLonLat(glStyle.center, view.getProjection()));\n }\n if ('zoom' in glStyle && view.getZoom() === undefined) {\n view.setResolution(\n defaultResolutions[0] /\n METERS_PER_UNIT[view.getProjection().getUnits()] /\n Math.pow(2, glStyle.zoom),\n );\n }\n if (!view.getCenter() || view.getZoom() === undefined) {\n view.fit(view.getProjection().getExtent(), {\n nearest: true,\n size: mapOrGroup.getSize(),\n });\n }\n }\n mapOrGroup.set('mapbox-style', glStyle);\n mapOrGroup.set('mapbox-metadata', {styleUrl, options});\n\n const glLayers = glStyle.layers;\n let layerIds = [];\n\n let layer, glSourceId, id;\n for (let i = 0, ii = glLayers.length; i < ii; ++i) {\n const glLayer = glLayers[i];\n const type = glLayer.type;\n if (type == 'heatmap') {\n //FIXME Unsupported layer type\n // eslint-disable-next-line no-console\n console.debug(`layers[${i}].type \"${type}\" not supported`);\n continue;\n } else {\n id = glLayer.source || getSourceIdByRef(glLayers, glLayer.ref);\n // this technique assumes gl layers will be in a particular order\n if (!id || id != glSourceId) {\n if (layerIds.length) {\n promises.push(\n finalizeLayer(\n layer,\n layerIds,\n glStyle,\n styleUrl,\n mapOrGroup,\n options,\n ),\n );\n layerIds = [];\n }\n\n layer = setupLayer(glStyle, styleUrl, glLayer, options);\n if (\n !(layer instanceof VectorLayer || layer instanceof VectorTileLayer)\n ) {\n layerIds = [];\n }\n glSourceId = layer.get('mapbox-source');\n }\n layerIds.push(glLayer.id);\n }\n }\n promises.push(\n finalizeLayer(layer, layerIds, glStyle, styleUrl, mapOrGroup, options),\n );\n return Promise.all(promises);\n}\n\n/**\n * Loads and applies a Mapbox/MapLibre Style object into an OpenLayers Map or LayerGroup.\n * This includes the map background, the layers, and for Map instances that did not\n * have a View defined yet also the center and the zoom.\n *\n * **Example:**\n * ```js\n * import apply from 'ol-mapbox-style';\n *\n * apply('map', 'mapbox://styles/mapbox/bright-v9', {accessToken: 'YOUR_MAPBOX_TOKEN'});\n * ```\n *\n * The center and zoom will only be set if present in the Mapbox/MapLibre Style document,\n * and if not already set on the OpenLayers map.\n *\n * Layers will be added to the OpenLayers map, without affecting any layers that\n * might already be set on the map.\n *\n * Layers added by `apply()` will have two additional properties:\n *\n * * `mapbox-source`: The `id` of the Mapbox/MapLibre Style document's source that the\n * OpenLayers layer was created from. Usually `apply()` creates one\n * OpenLayers layer per Mapbox/MapLibre Style source, unless the layer stack has\n * layers from different sources in between.\n * * `mapbox-layers`: The `id`s of the Mapbox/MapLibre Style document's layers that are\n * included in the OpenLayers layer.\n *\n * This function sets an additional `mapbox-style` property on the OpenLayers\n * Map or LayerGroup instance, which holds the Mapbox/MapLibre Style object.\n *\n * @param {Map|HTMLElement|string|LayerGroup} mapOrGroupOrElement Either an existing\n * OpenLayers Map instance, or a HTML element, or the id of a HTML element that will be\n * the target of a new OpenLayers Map, or a layer group. If layer group, styles\n * releated to the map and view will be ignored.\n * @param {string|Object} style JSON style object or style url pointing to a\n * Mapbox/MapLibre Style object. When using Mapbox APIs, the url is the `styleUrl`\n * shown in Mapbox Studio's \"share\" panel. In addition, the `accessToken` option\n * (see below) must be set.\n * When passed as JSON style object, all OpenLayers layers created by `apply()`\n * will be immediately available, but they may not have a source yet (i.e. when\n * they are defined by a TileJSON url in the Mapbox/MapLibre Style document). When passed\n * as style url, layers will be added to the map when the Mapbox/MapLibre Style document\n * is loaded and parsed.\n * @param {Options} options Options.\n * @return {Promise} A promise that resolves after all layers have been added to\n * the OpenLayers Map instance or LayerGroup, their sources set, and their styles applied. The\n * `resolve` callback will be called with the OpenLayers Map instance or LayerGroup as\n * argument.\n */\nexport function apply(mapOrGroupOrElement, style, options = {}) {\n let promise;\n /** @type {Map|LayerGroup} */\n let mapOrGroup;\n if (\n typeof mapOrGroupOrElement === 'string' ||\n mapOrGroupOrElement instanceof HTMLElement\n ) {\n mapOrGroup = new Map({\n target: mapOrGroupOrElement,\n });\n } else {\n mapOrGroup = mapOrGroupOrElement;\n }\n\n if (typeof style === 'string') {\n const styleUrl = style.startsWith('data:')\n ? location.href\n : normalizeStyleUrl(style, options.accessToken);\n options = completeOptions(styleUrl, options);\n\n promise = new Promise(function (resolve, reject) {\n getGlStyle(style, options)\n .then(function (glStyle) {\n processStyle(glStyle, mapOrGroup, styleUrl, options)\n .then(function () {\n resolve(mapOrGroup);\n })\n .catch(reject);\n })\n .catch(function (err) {\n reject(new Error(`Could not load ${style}: ${err.message}`));\n });\n });\n } else {\n promise = new Promise(function (resolve, reject) {\n processStyle(\n style,\n mapOrGroup,\n !options.styleUrl || options.styleUrl.startsWith('data:')\n ? location.href\n : normalizeStyleUrl(options.styleUrl, options.accessToken),\n options,\n )\n .then(function () {\n resolve(mapOrGroup);\n })\n .catch(reject);\n });\n }\n\n return promise;\n}\n\n/**\n * If layerIds is not empty, applies the style specified in glStyle to the layer,\n * and adds the layer to the map.\n *\n * The layer may not yet have a source when the function is called. If so, the style\n * is applied to the layer via a once listener on the 'change:source' event.\n *\n * @param {Layer} layer An OpenLayers layer instance.\n * @param {Array} layerIds Array containing layer ids of already-processed layers.\n * @param {Object} glStyle Style as a JSON object.\n * @param {string|undefined} styleUrl The original style URL. Only required\n * when a relative path is used with the `\"sprite\"` property of the style.\n * @param {Map|LayerGroup} mapOrGroup OpenLayers Map.\n * @param {Options} options Options.\n * @return {Promise} Returns a promise that resolves after the source has\n * been set on the specified layer, and the style has been applied.\n */\nexport function finalizeLayer(\n layer,\n layerIds,\n glStyle,\n styleUrl,\n mapOrGroup,\n options = {},\n) {\n let minZoom = 24;\n let maxZoom = 0;\n const glLayers = glStyle.layers;\n for (let i = 0, ii = glLayers.length; i < ii; ++i) {\n const glLayer = glLayers[i];\n if (layerIds.indexOf(glLayer.id) !== -1) {\n minZoom = Math.min('minzoom' in glLayer ? glLayer.minzoom : 0, minZoom);\n maxZoom = Math.max('maxzoom' in glLayer ? glLayer.maxzoom : 24, maxZoom);\n }\n }\n return new Promise(function (resolve, reject) {\n const setStyle = function () {\n const source = layer.getSource();\n if (!source || source.getState() === 'error') {\n reject(\n new Error(\n 'Error accessing data for source ' + layer.get('mapbox-source'),\n ),\n );\n return;\n }\n if ('getTileGrid' in source) {\n const tileGrid =\n /** @type {import(\"ol/source/Tile.js\").default|import(\"ol/source/VectorTile.js\").default} */ (\n source\n ).getTileGrid();\n if (tileGrid) {\n const sourceMinZoom = tileGrid.getMinZoom();\n if (minZoom > 0 || sourceMinZoom > 0) {\n layer.setMaxResolution(\n Math.min(\n getResolutionForZoom(\n Math.max(0, minZoom - 1e-12),\n defaultResolutions,\n ),\n getResolutionForZoom(\n Math.max(0, sourceMinZoom - 1e-12),\n tileGrid.getResolutions(),\n ),\n ),\n );\n }\n if (maxZoom < 24) {\n layer.setMinResolution(\n getResolutionForZoom(maxZoom, defaultResolutions),\n );\n }\n }\n } else {\n if (minZoom > 0) {\n layer.setMaxResolution(\n getResolutionForZoom(\n Math.max(0, minZoom - 1e-12),\n defaultResolutions,\n ),\n );\n }\n }\n if (\n source instanceof VectorSource ||\n source instanceof VectorTileSource\n ) {\n applyStyle(\n /** @type {import(\"ol/layer/Vector\").default|import(\"ol/layer/VectorTile\").default} */ (\n layer\n ),\n glStyle,\n layerIds,\n Object.assign({styleUrl: styleUrl}, options),\n )\n .then(function () {\n manageVisibility(layer, mapOrGroup);\n resolve();\n })\n .catch(reject);\n } else {\n resolve();\n }\n };\n\n layer.set('mapbox-layers', layerIds);\n const layers = mapOrGroup.getLayers();\n if (layers.getArray().indexOf(layer) === -1) {\n layers.push(layer);\n }\n\n if (layer.getSource()) {\n setStyle();\n } else {\n layer.once('change:source', setStyle);\n }\n });\n}\n\n/**\n * Get the Mapbox Layer object for the provided `layerId`.\n * @param {Map|LayerGroup} mapOrGroup Map or LayerGroup.\n * @param {string} layerId Mapbox Layer id.\n * @return {Object} Mapbox Layer object.\n */\nexport function getMapboxLayer(mapOrGroup, layerId) {\n const style = mapOrGroup.get('mapbox-style');\n const layerStyle = style.layers.find(function (layer) {\n return layer.id === layerId;\n });\n return layerStyle;\n}\n\n/**\n * Add a new Mapbox Layer object to the style. The map will be re-rendered.\n * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on.\n * @param {Object} mapboxLayer Mapbox Layer object.\n * @param {string} [beforeLayerId] Optional id of the Mapbox Layer before the new layer that will be added.\n * @return {Promise} Resolves when the added layer is available.\n */\nexport function addMapboxLayer(mapOrGroup, mapboxLayer, beforeLayerId) {\n const glStyle = mapOrGroup.get('mapbox-style');\n const mapboxLayers = glStyle.layers;\n let spliceIndex;\n let sourceIndex = -1;\n if (beforeLayerId !== undefined) {\n const beforeMapboxLayer = getMapboxLayer(mapOrGroup, beforeLayerId);\n if (beforeMapboxLayer === undefined) {\n throw new Error(`Layer with id \"${beforeLayerId}\" not found.`);\n }\n spliceIndex = mapboxLayers.indexOf(beforeMapboxLayer);\n } else {\n spliceIndex = mapboxLayers.length;\n }\n let sourceOffset;\n if (\n spliceIndex > 0 &&\n mapboxLayers[spliceIndex - 1].source === mapboxLayer.source\n ) {\n sourceIndex = spliceIndex - 1;\n sourceOffset = -1;\n } else if (\n spliceIndex < mapboxLayers.length &&\n mapboxLayers[spliceIndex].source === mapboxLayer.source\n ) {\n sourceIndex = spliceIndex;\n sourceOffset = 0;\n }\n if (sourceIndex === -1) {\n const {options, styleUrl} = mapOrGroup.get('mapbox-metadata');\n const layer = setupLayer(glStyle, styleUrl, mapboxLayer, options);\n if (beforeLayerId) {\n const beforeLayer = getLayer(mapOrGroup, beforeLayerId);\n const beforeLayerIndex = mapOrGroup\n .getLayers()\n .getArray()\n .indexOf(beforeLayer);\n mapOrGroup.getLayers().insertAt(beforeLayerIndex, layer);\n }\n mapboxLayers.splice(spliceIndex, 0, mapboxLayer);\n return finalizeLayer(\n layer,\n [mapboxLayer.id],\n glStyle,\n styleUrl,\n mapOrGroup,\n options,\n );\n }\n\n if (mapboxLayers.some((layer) => layer.id === mapboxLayer.id)) {\n throw new Error(`Layer with id \"${mapboxLayer.id}\" already exists.`);\n }\n const sourceLayerId = mapboxLayers[sourceIndex].id;\n const args =\n styleFunctionArgs[\n getStyleFunctionKey(\n mapOrGroup.get('mapbox-style'),\n getLayer(mapOrGroup, sourceLayerId),\n )\n ];\n mapboxLayers.splice(spliceIndex, 0, mapboxLayer);\n if (args) {\n const [\n olLayer,\n glStyle,\n sourceOrLayers,\n resolutions,\n spriteData,\n spriteImageUrl,\n getFonts,\n getImage,\n ] = args;\n if (Array.isArray(sourceOrLayers)) {\n const layerIndex = sourceOrLayers.indexOf(sourceLayerId) + sourceOffset;\n sourceOrLayers.splice(layerIndex, 0, mapboxLayer.id);\n }\n applyStylefunction(\n olLayer,\n glStyle,\n sourceOrLayers,\n resolutions,\n spriteData,\n spriteImageUrl,\n getFonts,\n getImage,\n );\n } else {\n getLayer(mapOrGroup, mapboxLayers[sourceIndex].id).changed();\n }\n return Promise.resolve();\n}\n\n/**\n * Update a Mapbox Layer object in the style. The map will be re-rendered with the new style.\n * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on.\n * @param {Object} mapboxLayer Updated Mapbox Layer object.\n */\nexport function updateMapboxLayer(mapOrGroup, mapboxLayer) {\n const glStyle = mapOrGroup.get('mapbox-style');\n const mapboxLayers = glStyle.layers;\n const index = mapboxLayers.findIndex(function (layer) {\n return layer.id === mapboxLayer.id;\n });\n if (index === -1) {\n throw new Error(`Layer with id \"${mapboxLayer.id}\" not found.`);\n }\n const oldLayer = mapboxLayers[index];\n if (oldLayer.source !== mapboxLayer.source) {\n throw new Error(\n 'Updated layer and previous version must use the same source.',\n );\n }\n delete getFunctionCache(glStyle)[mapboxLayer.id];\n delete getFilterCache(glStyle)[mapboxLayer.id];\n mapboxLayers[index] = mapboxLayer;\n const args =\n styleFunctionArgs[\n getStyleFunctionKey(\n mapOrGroup.get('mapbox-style'),\n getLayer(mapOrGroup, mapboxLayer.id),\n )\n ];\n if (args) {\n applyStylefunction.apply(undefined, args);\n } else {\n getLayer(mapOrGroup, mapboxLayer.id).changed();\n }\n}\n\n/**\n * Updates a Mapbox source object in the style. The according OpenLayers source will be replaced\n * and the map will be re-rendered.\n * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on.\n * @param {string} id Key of the source in the `sources` object literal.\n * @param {Object} mapboxSource Mapbox source object.\n * @return {Promise} Promise that resolves when the source has been updated.\n */\nexport function updateMapboxSource(mapOrGroup, id, mapboxSource) {\n const currentSource = getSource(mapOrGroup, id);\n const layers = /** @type {Array} */ (\n mapOrGroup\n .getLayers()\n .getArray()\n .filter(function (layer) {\n return (\n (layer instanceof VectorLayer ||\n layer instanceof TileLayer ||\n layer instanceof VectorTileLayer) &&\n layer.getSource() === currentSource\n );\n })\n );\n const metadata = mapOrGroup.get('mapbox-metadata');\n let newSourcePromise;\n switch (mapboxSource.type) {\n case 'vector':\n newSourcePromise = setupVectorSource(\n mapboxSource,\n metadata.styleUrl,\n metadata.options,\n );\n break;\n case 'geojson':\n newSourcePromise = Promise.resolve(\n setupGeoJSONSource(mapboxSource, metadata.styleUrl, metadata.options),\n );\n break;\n case 'raster':\n case 'raster-dem':\n newSourcePromise = setupRasterSource(\n mapboxSource,\n metadata.styleUrl,\n metadata.options,\n );\n break;\n default:\n return Promise.reject(\n new Error('Unsupported source type ' + mapboxSource.type),\n );\n }\n newSourcePromise.then(function (newSource) {\n layers.forEach(function (layer) {\n layer.setSource(newSource);\n });\n });\n return newSourcePromise;\n}\n\n/**\n * Remove a Mapbox Layer object from the style. The map will be re-rendered.\n * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on.\n * @param {string|Object} mapboxLayerIdOrLayer Mapbox Layer id or Mapbox Layer object.\n */\nexport function removeMapboxLayer(mapOrGroup, mapboxLayerIdOrLayer) {\n const mapboxLayerId =\n typeof mapboxLayerIdOrLayer === 'string'\n ? mapboxLayerIdOrLayer\n : mapboxLayerIdOrLayer.id;\n const layer = getLayer(mapOrGroup, mapboxLayerId);\n /** @type {Array} */\n const layerMapboxLayers = layer.get('mapbox-layers');\n if (layerMapboxLayers.length === 1) {\n throw new Error(\n 'Cannot remove last Mapbox layer from an OpenLayers layer.',\n );\n }\n layerMapboxLayers.splice(layerMapboxLayers.indexOf(mapboxLayerId), 1);\n const glStyle = mapOrGroup.get('mapbox-style');\n const layers = glStyle.layers;\n layers.splice(\n layers.findIndex((layer) => layer.id === mapboxLayerId),\n 1,\n );\n const args = styleFunctionArgs[getStyleFunctionKey(glStyle, layer)];\n if (args) {\n const [\n olLayer,\n glStyle,\n sourceOrLayers,\n resolutions,\n spriteData,\n spriteImageUrl,\n getFonts,\n getImage,\n ] = args;\n if (Array.isArray(sourceOrLayers)) {\n sourceOrLayers.splice(\n sourceOrLayers.findIndex((layer) => layer === mapboxLayerId),\n 1,\n );\n }\n applyStylefunction(\n olLayer,\n glStyle,\n sourceOrLayers,\n resolutions,\n spriteData,\n spriteImageUrl,\n getFonts,\n getImage,\n );\n } else {\n getLayer(mapOrGroup, mapboxLayerId).changed();\n }\n}\n\n/**\n * Get the OpenLayers layer instance that contains the provided Mapbox/MapLibre Style\n * `layer`. Note that multiple Mapbox/MapLibre Style layers are combined in a single\n * OpenLayers layer instance when they use the same Mapbox/MapLibre Style `source`.\n * @param {Map|LayerGroup} map OpenLayers Map or LayerGroup.\n * @param {string} layerId Mapbox/MapLibre Style layer id.\n * @return {Layer} OpenLayers layer instance.\n */\nexport function getLayer(map, layerId) {\n const layers = map.getLayers().getArray();\n for (let i = 0, ii = layers.length; i < ii; ++i) {\n const mapboxLayers = layers[i].get('mapbox-layers');\n if (mapboxLayers && mapboxLayers.indexOf(layerId) !== -1) {\n return /** @type {Layer} */ (layers[i]);\n }\n }\n return undefined;\n}\n\n/**\n * Get the OpenLayers layer instances for the provided Mapbox/MapLibre Style `source`.\n * @param {Map|LayerGroup} map OpenLayers Map or LayerGroup.\n * @param {string} sourceId Mapbox/MapLibre Style source id.\n * @return {Array} OpenLayers layer instances.\n */\nexport function getLayers(map, sourceId) {\n const result = [];\n const layers = map.getLayers().getArray();\n for (let i = 0, ii = layers.length; i < ii; ++i) {\n if (layers[i].get('mapbox-source') === sourceId) {\n result.push(/** @type {Layer} */ (layers[i]));\n }\n }\n return result;\n}\n\n/**\n * Get the OpenLayers source instance for the provided Mapbox/MapLibre Style `source`.\n * @param {Map|LayerGroup} map OpenLayers Map or LayerGroup.\n * @param {string} sourceId Mapbox/MapLibre Style source id.\n * @return {Source} OpenLayers source instance.\n */\nexport function getSource(map, sourceId) {\n const layers = map.getLayers().getArray();\n for (let i = 0, ii = layers.length; i < ii; ++i) {\n const source = /** @type {Layer} */ (layers[i]).getSource();\n if (layers[i].get('mapbox-source') === sourceId) {\n return source;\n }\n }\n return undefined;\n}\n\n/**\n * Sets or removes a feature state. The feature state is taken into account for styling,\n * just like the feature's properties, and can be used e.g. to conditionally render selected\n * features differently.\n *\n * The feature state will be stored on the OpenLayers layer matching the feature identifier, in the\n * `mapbox-featurestate` property.\n * @param {Map|VectorLayer|VectorTileLayer} mapOrLayer OpenLayers Map or layer to set the feature\n * state on.\n * @param {FeatureIdentifier} feature Feature identifier.\n * @param {Object|null} state Feature state. Set to `null` to remove the feature state.\n */\nexport function setFeatureState(mapOrLayer, feature, state) {\n const layers =\n 'getLayers' in mapOrLayer\n ? getLayers(mapOrLayer, feature.source)\n : [mapOrLayer];\n for (let i = 0, ii = layers.length; i < ii; ++i) {\n const featureState = layers[i].get('mapbox-featurestate');\n if (featureState) {\n if (state) {\n featureState[feature.id] = state;\n } else {\n delete featureState[feature.id];\n }\n layers[i].changed();\n } else {\n throw new Error(`Map or layer for source \"${feature.source}\" not found.`);\n }\n }\n}\n\n/**\n * Sets or removes a feature state. The feature state is taken into account for styling,\n * just like the feature's properties, and can be used e.g. to conditionally render selected\n * features differently.\n * @param {Map|VectorLayer|VectorTileLayer} mapOrLayer Map or layer to set the feature state on.\n * @param {FeatureIdentifier} feature Feature identifier.\n * @return {Object|null} Feature state or `null` when no feature state is set for the given\n * feature identifier.\n */\nexport function getFeatureState(mapOrLayer, feature) {\n const layers =\n 'getLayers' in mapOrLayer\n ? getLayers(mapOrLayer, feature.source)\n : [mapOrLayer];\n for (let i = 0, ii = layers.length; i < ii; ++i) {\n const featureState = layers[i].get('mapbox-featurestate');\n if (featureState && featureState[feature.id]) {\n return featureState[feature.id];\n }\n }\n return undefined;\n}\n","import BaseEvent from 'ol/events/Event.js';\nimport EventType from 'ol/events/EventType.js';\nimport MVT from 'ol/format/MVT.js';\nimport VectorTileLayer from 'ol/layer/VectorTile.js';\nimport VectorTileSource from 'ol/source/VectorTile.js';\nimport {applyBackground, applyStyle} from './apply.js';\n\n/** @typedef {import(\"ol/Map.js\").default} Map */\n\n/**\n * @classdesc\n * Event emitted on configuration or loading error.\n */\nclass ErrorEvent extends BaseEvent {\n /**\n * @param {Error} error error object.\n */\n constructor(error) {\n super(EventType.ERROR);\n\n /**\n * @type {Error}\n */\n this.error = error;\n }\n}\n\n/**\n * @typedef {Object} Options\n * @property {string} styleUrl The URL of the Mapbox/MapLibre Style object to use for this layer. For a\n * style created with Mapbox Studio and hosted on Mapbox, this will look like\n * 'mapbox://styles/you/your-style'.\n * @property {string} [accessToken] The access token for your Mapbox/MapLibre style. This has to be provided\n * for `mapbox://` style urls. For `https://` and other urls, any access key must be the last query\n * parameter of the style url.\n * @property {string} [source] If your style uses more than one source, you need to use either the\n * `source` property or the `layers` property to limit rendering to a single vector source. The\n * `source` property corresponds to the id of a vector source in your Mapbox/MapLibre style.\n * @property {Array} [layers] Limit rendering to the list of included layers. All layers\n * must share the same vector source. If your style uses more than one source, you need to use\n * either the `source` property or the `layers` property to limit rendering to a single vector\n * source.\n * @property {boolean} [declutter=true] Declutter images and text. Decluttering is applied to all\n * image and text styles of all Vector and VectorTile layers that have set this to `true`. The priority\n * is defined by the z-index of the layer, the `zIndex` of the style and the render order of features.\n * Higher z-index means higher priority. Within the same z-index, a feature rendered before another has\n * higher priority.\n *\n * As an optimization decluttered features from layers with the same `className` are rendered above\n * the fill and stroke styles of all of those layers regardless of z-index. To opt out of this\n * behavior and place declutterd features with their own layer configure the layer with a `className`\n * other than `ol-layer`.\n * @property {import(\"ol/layer/Base.js\").BackgroundColor|false} [background] Background color for the layer.\n * If not specified, the background from the Mapbox/MapLibre Style object will be used. Set to `false` to prevent\n * the Mapbox/MapLibre style's background from being used.\n * @property {string} [className='ol-layer'] A CSS class name to set to the layer element.\n * @property {number} [opacity=1] Opacity (0, 1).\n * @property {boolean} [visible=true] Visibility.\n * @property {import(\"ol/extent.js\").Extent} [extent] The bounding extent for layer rendering. The layer will not be\n * rendered outside of this extent.\n * @property {number} [zIndex] The z-index for layer rendering. At rendering time, the layers\n * will be ordered, first by Z-index and then by position. When `undefined`, a `zIndex` of 0 is assumed\n * for layers that are added to the map's `layers` collection, or `Infinity` when the layer's `setMap()`\n * method was used.\n * @property {number} [minResolution] The minimum resolution (inclusive) at which this layer will be\n * visible.\n * @property {number} [maxResolution] The maximum resolution (exclusive) below which this layer will\n * be visible. If neither `maxResolution` nor `minZoom` are defined, the layer's `maxResolution` will\n * match the style source's `minzoom`.\n * @property {number} [minZoom] The minimum view zoom level (exclusive) above which this layer will\n * be visible. If neither `maxResolution` nor `minZoom` are defined, the layer's `minZoom` will match\n * the style source's `minzoom`.\n * @property {number} [maxZoom] The maximum view zoom level (inclusive) at which this layer will\n * be visible.\n * @property {import(\"ol/render.js\").OrderFunction} [renderOrder] Render order. Function to be used when sorting\n * features before rendering. By default features are drawn in the order that they are created. Use\n * `null` to avoid the sort, but get an undefined draw order.\n * @property {number} [renderBuffer=100] The buffer in pixels around the tile extent used by the\n * renderer when getting features from the vector tile for the rendering or hit-detection.\n * Recommended value: Vector tiles are usually generated with a buffer, so this value should match\n * the largest possible buffer of the used tiles. It should be at least the size of the largest\n * point symbol or line width.\n * @property {import(\"ol/layer/VectorTile.js\").VectorTileRenderType} [renderMode='hybrid'] Render mode for vector tiles:\n * * `'hybrid'`: Polygon and line elements are rendered as images, so pixels are scaled during zoom\n * animations. Point symbols and texts are accurately rendered as vectors and can stay upright on\n * rotated views.\n * * `'vector'`: Everything is rendered as vectors. Use this mode for improved performance on vector\n * tile layers with only a few rendered features (e.g. for highlighting a subset of features of\n * another layer with the same source).\n * @property {import(\"ol/Map.js\").default} [map] Sets the layer as overlay on a map. The map will not manage\n * this layer in its layers collection, and the layer will be rendered on top. This is useful for\n * temporary layers. The standard way to add a layer to a map and have it managed by the map is to\n * use `map.addLayer()`.\n * @property {boolean} [updateWhileAnimating=false] When set to `true`, feature batches will be\n * recreated during animations. This means that no vectors will be shown clipped, but the setting\n * will have a performance impact for large amounts of vector data. When set to `false`, batches\n * will be recreated when no animation is active.\n * @property {boolean} [updateWhileInteracting=false] When set to `true`, feature batches will be\n * recreated during interactions. See also `updateWhileAnimating`.\n * @property {number} [preload=0] Preload. Load low-resolution tiles up to `preload` levels. `0`\n * means no preloading.\n * @property {boolean} [useInterimTilesOnError=true] Use interim tiles on error.\n * @property {Object} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @classdesc\n * ```js\n * import {MapboxVectorLayer} from 'ol-mapbox-style';\n * ```\n * A vector tile layer based on a Mapbox/MapLibre style that uses a single vector source. Configure\n * the layer with the `styleUrl` and `accessToken` shown in Mapbox Studio's share panel.\n * If the style uses more than one source, use the `source` property to choose a single\n * vector source. If you want to render a subset of the layers in the style, use the `layers`\n * property (all layers must share the same vector source). See the constructor options for\n * more detail.\n *\n * const map = new Map({\n * view: new View({\n * center: [0, 0],\n * zoom: 1,\n * }),\n * layers: [\n * new MapboxVectorLayer({\n * styleUrl: 'mapbox://styles/mapbox/bright-v9',\n * accessToken: 'your-mapbox-access-token-here',\n * }),\n * ],\n * target: 'map',\n * });\n *\n * On configuration or loading error, the layer will trigger an `'error'` event. Listeners\n * will receive an object with an `error` property that can be used to diagnose the problem.\n *\n * **Note for users of the full build**: The `MapboxVectorLayer` requires the\n * [ol-mapbox-style](https://github.com/openlayers/ol-mapbox-style) library to be loaded as well.\n *\n * @param {Options} options Options.\n * @extends {VectorTileLayer}\n * @fires module:ol/events/Event~BaseEvent#event:error\n * @api\n */\nexport default class MapboxVectorLayer extends VectorTileLayer {\n /**\n * @param {Options} options Layer options. At a minimum, `styleUrl` and `accessToken`\n * must be provided.\n */\n constructor(options) {\n const declutter = 'declutter' in options ? options.declutter : true;\n const source = new VectorTileSource({\n state: 'loading',\n format: new MVT(),\n });\n\n super({\n source: source,\n background: options.background === false ? null : options.background,\n declutter: declutter,\n className: options.className,\n opacity: options.opacity,\n visible: options.visible,\n zIndex: options.zIndex,\n minResolution: options.minResolution,\n maxResolution: options.maxResolution,\n minZoom: options.minZoom,\n maxZoom: options.maxZoom,\n renderOrder: options.renderOrder,\n renderBuffer: options.renderBuffer,\n renderMode: options.renderMode,\n map: options.map,\n updateWhileAnimating: options.updateWhileAnimating,\n updateWhileInteracting: options.updateWhileInteracting,\n preload: options.preload,\n useInterimTilesOnError: options.useInterimTilesOnError,\n properties: options.properties,\n });\n\n if (options.accessToken) {\n this.accessToken = options.accessToken;\n }\n const url = options.styleUrl;\n const promises = [\n applyStyle(this, url, options.layers || options.source, {\n accessToken: this.accessToken,\n }),\n ];\n if (this.getBackground() === undefined) {\n promises.push(\n applyBackground(this, options.styleUrl, {\n accessToken: this.accessToken,\n }),\n );\n }\n Promise.all(promises)\n .then(() => {\n source.setState('ready');\n })\n .catch((error) => {\n this.dispatchEvent(new ErrorEvent(error));\n const source = this.getSource();\n source.setState('error');\n });\n }\n}\n"],"names":["kCSSColorTable","clamp_css_byte","i","Math","round","clamp_css_float","f","parse_css_int","str","length","parseFloat","parseInt","parse_css_float","css_hue_to_rgb","m1","m2","h","parseCSSColor","css_str","replace","toLowerCase","slice","iv","substr","op","indexOf","ep","fname","params","split","alpha","pop","s","l","exports","e","Color","constructor","r","g","b","a","parse","input","undefined","rgba","toString","toArray","toArray01","toArray01PremultipliedAlpha","black","white","transparent","red","blue","convertLiteral","value","convertFunction","parameters","propertySpec","stops","convertIdentityFunction","zoomAndFeatureDependent","featureDependent","property","zoomDependent","map","stop","tokens","convertTokenString","convertZoomAndPropertyFunction","convertZoomFunction","convertPropertyFunction","get","default","type","Object","keys","values","expression","splice","getInterpolateOperator","colorSpace","featureFunctionParameters","featureFunctionStops","zoomStops","zoom","push","functionType","getFunctionType","z","output","appendStopPair","fixupDegenerateStepCurve","coalesce","getFallback","defaultValue","base","Error","isStep","curve","interpolated","result","re","pos","match","exec","literal","lastIndex","ParsingError","key","message","Scope","parent","bindings","name","concat","has","NullType","kind","NumberType","StringType","BooleanType","ColorType","ObjectType","ValueType","ErrorType","CollatorType","FormattedType","ResolvedImageType","array","itemType","N","valueMemberTypes","checkSubtype","expected","t","memberType","isValidType","provided","allowedTypes","some","isValidNativeType","Array","isArray","Collator","caseSensitive","diacriticSensitive","locale","sensitivity","collator","Intl","usage","compare","lhs","rhs","resolvedLocale","resolvedOptions","FormattedSection","text","image","scale","fontStack","textColor","normalize","Formatted","sections","fromString","unformatted","isEmpty","section","factory","join","serialize","serialized","options","ResolvedImage","available","validateRGBA","isValue","mixed","item","typeOf","String","JSON","stringify","Literal","args","context","error","expectedType","evaluate","eachChild","outputDefined","RuntimeError","toJSON","types","string","number","boolean","object","Assertion","floor","parsed","ctx","fn","forEach","every","arg","FormatExpression","firstArg","nextTokenMayBeObject","font","lastExpression","content","evaluateSection","evaluatedContent","ImageExpression","evaluatedImageName","availableImages","Coercion","Boolean","c","parseColor","num","Number","isNaN","valueToString","child","geometryTypes","EvaluationContext","globals","feature","featureState","formattedSection","_parseColorCache","canonical","featureTileCoord","featureDistanceData","id","geometryType","geometry","canonicalID","properties","distanceFromCenter","center","x","y","dX","dY","bX","bearing","bY","dist","cached","CompoundExpression","_evaluate","definition","definitions","availableOverloads","overloads","filter","signature","signatureContext","ParsingContext","registry","path","scope","parsedArgs","argParseFailed","errors","signatures","stringifySignature","actualTypes","register","CollatorExpression","EXTENT","updateBBox","bbox","coord","min","max","mercatorXfromLng","lng","mercatorYfromLat","lat","PI","log","tan","boxWithinBox","bbox1","bbox2","getTileCoordinates","p","tilesAtZoom","pow","onBoundary","p1","p2","x1","y1","x2","y2","rayIntersect","pointWithinPolygon","point","rings","inside","len","ring","j","len2","pointWithinPolygons","polygons","perp","v1","v2","twoSided","q1","q2","x3","y3","det1","det2","lineIntersectLine","d","vectorP","vectorQ","lineIntersectPolygon","polygon","lineStringWithinPolygon","line","lineStringWithinPolygons","getTilePolygon","coordinates","getTilePolygons","updatePoint","polyBBox","worldSize","halfWorldSize","shift","resetBBox","Infinity","getTilePoints","pointBBox","shifts","tilePoints","points","getTileLines","lineBBox","tileLines","tileLine","pointsWithinPolygons","polygonGeometry","tilePolygon","tilePolygons","linesWithinPolygons","Within","geojson","geometries","features","isFeatureConstant","test","isStateConstant","isGlobalPropertyConstant","Var","boundExpression","part","expr","index","_parse","annotate","typeAnnotation","Expr","actual","isConstant","ec","k","isTypeAnnotation","childrenConstant","findStopLessThanOrEqualTo","lowerIndex","upperIndex","currentIndex","currentValue","nextValue","Step","labels","outputs","label","outputType","labelKey","valueKey","stopCount","out","module","UnitBezier","p1x","p1y","p2x","p2y","cx","bx","ax","cy","by","ay","prototype","sampleCurveX","sampleCurveY","sampleCurveDerivativeX","solveCurveX","epsilon","t0","t1","t2","abs","d2","solve","color","from","to","Xn","Yn","Zn","t3","deg2rad","rad2deg","xyz2lab","lab2xyz","xyz2rgb","rgb2xyz","rgbToLab","rgbColor","labToRgb","labColor","interpolateLab","interpolateNumber","rgbToHcl","atan2","sqrt","hclToRgb","hclColor","cos","sin","interpolateHue","interpolateHcl","lab","forward","reverse","interpolate","hcl","Interpolate","operator","interpolation","interpolationFactor","lower","upper","exponentialInterpolation","controlPoints","ub","rest","outputLower","outputUpper","lowerValue","upperValue","difference","progress","Coalesce","needsAnnotation","argCount","firstImage","Let","binding","At","In","needle","haystack","IndexOf","fromIndex","Match","inputType","cases","otherwise","labelContext","MAX_SAFE_INTEGER","sortedLabels","sort","groupedByOutput","outputLookup","outputIndex","coerceLabel","Case","branches","_","Slice","beginIndex","endIndex","isComparableType","eq","neq","lt","gt","lteq","gteq","eqCollate","neqCollate","ltCollate","gtCollate","lteqCollate","gteqCollate","makeComparison","compareBasic","compareWithCollator","isOrderComparison","Comparison","hasUntypedArgument","rt","Equals","NotEquals","LessThan","GreaterThan","LessThanOrEqual","GreaterThanOrEqual","NumberFormat","currency","unit","minFractionDigits","maxFractionDigits","style","minimumFractionDigits","maximumFractionDigits","format","Length","expressions","obj","v","binarySearch","m","varargs","typeToString","pitch","heatmapDensity","lineProgress","skyRadialProgress","accumulated","LN2","E","n","LN10","asin","acos","atan","ceil","isSupportedScript","toUpperCase","success","supportsPropertyExpression","spec","supportsZoomExpression","supportsInterpolation","isFunction","StyleExpression","_warningHistory","_evaluator","_defaultValue","getDefaultValue","_enumValues","evaluateWithoutErrorHandling","val","console","warn","isExpression","createExpression","parser","getExpectedType","ZoomConstantExpression","_styleExpression","isStateDependent","ZoomDependentExpression","interpolationType","createPropertyExpression","isZoomConstant","zoomCurve","findZoomCurve","childResult","enum","formatted","resolvedImage","unbundle","valueOf","deepUnbundle","unbundledValue","isExpressionFilter","createFilter","layerType","needGeometry","needFeature","convertFilter","filterExp","staticFilter","extractStaticFilter","filterSpec","latest","compiledStaticFilter","filterFunc","err","globalProperties","dynamicFilterFunc","compiledDynamicFilter","geometryNeeded","dynamicFilter","isDynamicFilter","unionDynamicBranches","collapseDynamicBooleanExpressions","collapsed","collapsedExpression","subExpression","isBranchingDynamically","isRootExpressionDynamic","dynamicConditionExpressions","Set","param","converted","convertComparisonOp","convertNegation","convertDisjunctionOp","convertInOp","convertHasOp","filters","deref","layer","refProperties","derefLayers","layers","create","ref","fontWeights","thin","hairline","light","book","regular","normal","plain","roman","standard","medium","bold","heavy","fat","poster","sp","italicRE","fontCache","fonts","size","lineHeight","cssData","weight","fontFamilies","haveWeight","haveStyle","ii","parts","maybeWeight","w","previousPart","startsWith","fontFamily","mapboxBaseUrl","getMapboxPath","url","normalizeSpriteUrl","token","styleUrl","mapboxPath","decodeURI","URL","href","sprite","normalizeStyleUrl","location","mapboxSubdomains","normalizeSourceUrl","tokenParam","urlObject","searchParams","set","sizeFactor","window","devicePixelRatio","sub","functionCacheByStyleId","filterCacheByStyleId","styleId","getStyleId","glStyle","getStyleFunctionKey","olLayer","getUid","getFunctionCache","functionCache","clearFunctionCache","getFilterCache","filterCache","degrees","defaultResolutions","resolutions","res","createCanvas","width","height","WorkerGlobalScope","self","OffscreenCanvas","canvas","document","createElement","getZoomForResolution","resolution","candidate","zoomFactor","getResolutionForZoom","factor","pendingRequests","fetchResource","resourceType","metadata","request","transformedRequest","transformRequest","pendingRequest","toPromise","then","Request","headers","fetch","response","ok","json","Promise","reject","catch","getGlStyle","glStyleOrUrl","trim","resolve","accessToken","tilejsonCache","getTileJson","glSource","cacheKey","promise","tileLoadFunction","tile","src","VectorTile","setLoader","extent","projection","arrayBuffer","data","getFormat","readFeatures","featureProjection","setFeatures","setState","TileState","ERROR","img","getImage","blob","createObjectURL","addEventListener","revokeObjectURL","tiles","normalizedSourceUrl","accessTokenParam","tileJson","assign","tileUrl","scheme","drawIconHalo","spriteImage","spriteImageData","haloWidth","haloColor","imgSize","pixelRatio","imageCanvas","imageContext","getContext","drawImage","imageData","getImageData","globalCompositeOperation","fillStyle","jj","arc","fill","smoothstep","drawSDF","area","buffer","gamma","putImageData","hairSpacePool","applyLetterSpacing","letterSpacing","textWithLetterSpacing","lines","joinSpaceString","ll","measureContext","getMeasureContext","measureText","measureCache","wrapText","em","hardLines","wrappedText","words","oneEm","maxWidth","word","testLine","prevWidth","nextWidth","next","lineWords","lastWord","fontFamilyRegEx","stripQuotesRegEx","loadedFontFamilies","hasFontFamily","family","styleSheets","styleSheet","cssRules","rules","cssRule","cssText","processedFontFamilies","getFonts","templateUrl","fontsKey","fontDescriptions","cssFont","mb2css","registerFont","fontDescription","checkedFonts","fontUrl","querySelector","markup","rel","head","appendChild","anchor","expressionData","rawExpression","compiledExpression","emptyObj","zoomObj","renderFeatureCoordinates","renderFeature","getValue","layoutOrPaint","layerId","functions","isExpr","bind","getDeclutterMode","prefix","allowOverlap","ignorePlacement","evaluateFilter","renderTransparentEnabled","renderTransparent","enabled","colorWithOpacity","opacity","templateRegEx","fromTemplate","recordLayer","recordStyleLayer","record","styleFunctionArgs","stylefunction","sourceOrLayers","spriteData","spriteImageUrl","version","arguments","spriteImageSize","spriteImageUnSDFed","Image","blobUrl","crossOrigin","onload","changed","worker","postMessage","action","handler","event","allLayers","layersBySourceLayer","mapboxLayers","iconImageCache","patternCache","mapboxSource","source","sourceLayer","sources","textHalo","Stroke","Fill","styles","styleFunction","onlyLayer","getProperties","getGeometry","getType","getId","stylesLength","featureBelongsToLayer","layerData","layout","paint","visibility","minzoom","maxzoom","stroke","strokeColor","fillIcon","icon","getFill","getStroke","getText","Style","setZIndex","icon_cache_key","pattern","globalAlpha","createPattern","setColor","setWidth","setLineCap","setLineJoin","setMiterLimit","setLineDash","hasImage","placementAngle","iconImg","skipLabel","iconImage","styleGeom","imageElement","iconRotationAlignment","geom","getFlatMidpoint","getFlatMidpoints","getExtent","midpoint","NaN","RenderFeature","placement","stride","getStride","getFlatCoordinates","minX","maxX","xM","yM","dotProduct","iconSize","iconColor","iconCacheKey","declutterMode","displacement","iconOptions","rotateWithView","Icon","offset","sdf","setGeometry","setRotation","setOpacity","setAnchor","setImage","setText","circleRadius","circleStrokeColor","circleTranslate","circleColor","circleStrokeWidth","cache_key","Circle","radius","textLineHeight","textSize","maxTextWidth","fontArray","includes","textField","reduce","acc","chunk","chunkFont","Text","padding","textTransform","wrappedLabel","setFont","setKeepUpright","keepUpright","textAnchor","textAlign","setPlacement","setRepeat","symbolSpacing","setOverflow","textHaloWidth","textOffset","textTranslate","vOffset","hOffset","textRotationAlignment","setRotateWithView","setMaxAngle","setTextAlign","textBaseline","setTextBaseline","textJustify","setJustify","setOffsetX","setOffsetY","setFill","halfTextSize","setStroke","textPadding","getPadding","setStyle","getStyleForLayer","evaluateStyle","getStyleFunction","hillshade","inputs","elevationImage","elevationData","shadeData","Uint8ClampedArray","dp","maxY","pixel","twoPi","halfPi","sunEl","sunAz","cosSunEl","sinSunEl","highlightColor","shadowColor","accentColor","encoding","pixelX","pixelY","x0","y0","z0","z1","dzdx","dzdy","slope","aspect","accent","scaled","shade","scaledAccentColor","compositeShadeColor","clamp","slopeScaleBase","scaledSlope","cosIncidence","calculateElevation","vert","ImageData","getTileResolutions","tileSize","createXYZ","maxZoom","getResolutions","completeOptions","applyStyle","sourceOrLayersOrOptions","optionsOrPath","sourceId","updateSource","VectorLayer","VectorTileLayer","find","assignSource","setupVectorSource","targetSource","getSource","setSource","setTileUrlFunction","getTileUrlFunction","setUrls","getUrls","format_","getAttributions","setAttributions","getTileLoadFunction","defaultLoadFunction","setTileLoadFunction","equivalent","getProjection","tileGrid","getTileGrid","isFinite","getMaxResolution","getMinZoom","setMaxResolution","setupGeoJSONSource","url_","getUrl","spriteScale","onChange","units","getUnits","METERS_PER_UNIT","applyStylefunction","webfonts","getStyle","spriteUrl","origin","pathname","search","spritesJson","transformed","setFirstBackground","mapOrLayer","Layer","setBackground","getBackgroundColor","Map","LayerGroup","getLayers","insertAt","setupBackgroundLayer","applyBackground","getSourceIdByRef","extentFromTileJSON","tileJSON","bounds","fromLonLat","tr","sourceOptionsFromTileJSON","tileJSONSource","TileJSON","tileJSONDoc","getTileJSON","projectionExtent","minZoom","sourceOptions","attributions","TileGrid","getTopLeft","getOrigin","getTileSize","urls","glLayer","background","bg","_colorWithOpacity","div","className","position","Source","render","frameState","viewState","backgroundColor","MVT","VectorTileSource","setupVectorLayer","declutter","visible","getBboxTemplate","projCode","getCode","setupRasterSource","transition","getTileUrl","tileCoord","bboxTemplate","getTileCoordExtent","setupRasterLayer","TileLayer","setupHillshadeLayer","tileLayer","ImageLayer","Raster","operationType","operation","geoJsonFormat","GeoJSON","dataProjection","geoJsonUrl","extentUrl","VectorSource","attribution","loader","failure","addFeatures","removeLoadedExtent","strategy","bboxStrategy","getUserProjection","setupGeoJSONLayer","prerenderRasterLayer","updateRasterLayerProperties","manageVisibility","mapOrGroup","layerMapboxLayerids","mapboxLayer","setVisible","on","setupLayer","glLayers","hillshadeLayer","getPointResolution","getCenter","glSourceId","processStyle","promises","view","getView","isDef","getRotation","View","maxResolution","setView","setCenter","getZoom","setResolution","fit","nearest","getSize","layerIds","debug","finalizeLayer","all","apply","mapOrGroupOrElement","HTMLElement","target","getState","sourceMinZoom","setMinResolution","getArray","once","getMapboxLayer","layerStyle","addMapboxLayer","beforeLayerId","spliceIndex","sourceIndex","beforeMapboxLayer","sourceOffset","beforeLayer","getLayer","beforeLayerIndex","sourceLayerId","layerIndex","updateMapboxLayer","findIndex","oldLayer","updateMapboxSource","currentSource","newSourcePromise","newSource","removeMapboxLayer","mapboxLayerIdOrLayer","mapboxLayerId","layerMapboxLayers","setFeatureState","state","getFeatureState","ErrorEvent","BaseEvent","EventType","MapboxVectorLayer","zIndex","minResolution","renderOrder","renderBuffer","renderMode","updateWhileAnimating","updateWhileInteracting","preload","useInterimTilesOnError","getBackground","dispatchEvent"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuBA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAIA,cAAA,GAAiB;AAAA,IACnB,aAAe,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,CAAH;AAAA,QAAK,CAAL;AAAA,QAAO,CAAP;AAAA,KADI;AAAA,IACO,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KADpB;AAAA,IAEnB,cAAgB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAFG;AAAA,IAEc,MAAQ,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,GAAH;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KAFtB;AAAA,IAGnB,YAAc,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAHK;AAAA,IAGY,OAAS,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAHrB;AAAA,IAInB,OAAS,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAJU;AAAA,IAIO,QAAU,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAJjB;AAAA,IAKnB,OAAS,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,CAAH;AAAA,QAAK,CAAL;AAAA,QAAO,CAAP;AAAA,KALU;AAAA,IAKC,gBAAkB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KALnB;AAAA,IAMnB,MAAQ,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,CAAH;AAAA,QAAK,GAAL;AAAA,QAAS,CAAT;AAAA,KANW;AAAA,IAME,YAAc,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KANhB;AAAA,IAOnB,OAAS,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,EAAR;AAAA,QAAW,CAAX;AAAA,KAPU;AAAA,IAOK,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAPlB;AAAA,IAQnB,WAAa,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,GAAJ;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KARM;AAAA,IAQU,YAAc,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,CAAT;AAAA,QAAW,CAAX;AAAA,KARxB;AAAA,IASnB,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,EAAT;AAAA,QAAY,CAAZ;AAAA,KATM;AAAA,IASU,OAAS,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,EAAT;AAAA,QAAY,CAAZ;AAAA,KATnB;AAAA,IAUnB,gBAAkB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAVC;AAAA,IAUgB,UAAY,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAV5B;AAAA,IAWnB,SAAW,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,EAAR;AAAA,QAAW,CAAX;AAAA,KAXQ;AAAA,IAWO,MAAQ,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,GAAH;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KAXf;AAAA,IAYnB,UAAY,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,CAAH;AAAA,QAAK,GAAL;AAAA,QAAS,CAAT;AAAA,KAZO;AAAA,IAYM,UAAY,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,GAAH;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KAZlB;AAAA,IAanB,eAAiB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,EAAT;AAAA,QAAY,CAAZ;AAAA,KAbE;AAAA,IAac,UAAY,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAb1B;AAAA,IAcnB,WAAa,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,GAAH;AAAA,QAAO,CAAP;AAAA,QAAS,CAAT;AAAA,KAdM;AAAA,IAcO,UAAY,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAdnB;AAAA,IAenB,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAfM;AAAA,IAeW,aAAe,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,CAAL;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KAf1B;AAAA,IAgBnB,gBAAkB,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,GAAJ;AAAA,QAAQ,EAAR;AAAA,QAAW,CAAX;AAAA,KAhBC;AAAA,IAgBc,YAAc,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,CAAT;AAAA,QAAW,CAAX;AAAA,KAhB5B;AAAA,IAiBnB,YAAc,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KAjBK;AAAA,IAiBW,SAAW,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,CAAL;AAAA,QAAO,CAAP;AAAA,QAAS,CAAT;AAAA,KAjBtB;AAAA,IAkBnB,YAAc,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAlBK;AAAA,IAkBY,cAAgB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAlB5B;AAAA,IAmBnB,eAAiB,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,EAAJ;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KAnBE;AAAA,IAmBa,eAAiB,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,EAAJ;AAAA,QAAO,EAAP;AAAA,QAAU,CAAV;AAAA,KAnB9B;AAAA,IAoBnB,eAAiB,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,EAAJ;AAAA,QAAO,EAAP;AAAA,QAAU,CAAV;AAAA,KApBE;AAAA,IAoBY,eAAiB,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,GAAH;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KApB7B;AAAA,IAqBnB,YAAc,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,CAAL;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KArBK;AAAA,IAqBU,UAAY,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KArBtB;AAAA,IAsBnB,aAAe,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,GAAH;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KAtBI;AAAA,IAsBW,SAAW,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAtBtB;AAAA,IAuBnB,SAAW,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAvBQ;AAAA,IAuBS,YAAc,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,GAAJ;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KAvBvB;AAAA,IAwBnB,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,EAAR;AAAA,QAAW,CAAX;AAAA,KAxBM;AAAA,IAwBS,aAAe,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAxBxB;AAAA,IAyBnB,aAAe,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,GAAJ;AAAA,QAAQ,EAAR;AAAA,QAAW,CAAX;AAAA,KAzBI;AAAA,IAyBW,SAAW,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,CAAL;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KAzBtB;AAAA,IA0BnB,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA1BM;AAAA,IA0BW,YAAc,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA1BzB;AAAA,IA2BnB,MAAQ,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,CAAT;AAAA,QAAW,CAAX;AAAA,KA3BW;AAAA,IA2BI,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,EAAT;AAAA,QAAY,CAAZ;AAAA,KA3BjB;AAAA,IA4BnB,MAAQ,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA5BW;AAAA,IA4BM,OAAS,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,GAAH;AAAA,QAAO,CAAP;AAAA,QAAS,CAAT;AAAA,KA5Bf;AAAA,IA6BnB,aAAe,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,EAAT;AAAA,QAAY,CAAZ;AAAA,KA7BI;AAAA,IA6BY,MAAQ,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA7BpB;AAAA,IA8BnB,UAAY,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA9BO;AAAA,IA8BU,SAAW,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA9BrB;AAAA,IA+BnB,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,EAAR;AAAA,QAAW,CAAX;AAAA,KA/BM;AAAA,IA+BS,QAAU,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,CAAJ;AAAA,QAAM,GAAN;AAAA,QAAU,CAAV;AAAA,KA/BnB;AAAA,IAgCnB,OAAS,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAhCU;AAAA,IAgCO,OAAS,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAhChB;AAAA,IAiCnB,UAAY,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAjCO;AAAA,IAiCU,eAAiB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAjC3B;AAAA,IAkCnB,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,CAAT;AAAA,QAAW,CAAX;AAAA,KAlCM;AAAA,IAkCS,cAAgB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAlCzB;AAAA,IAmCnB,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAnCM;AAAA,IAmCW,YAAc,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAnCzB;AAAA,IAoCnB,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KApCM;AAAA,IAoCW,sBAAwB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KApCnC;AAAA,IAqCnB,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KArCM;AAAA,IAqCW,YAAc,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KArCzB;AAAA,IAsCnB,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAtCM;AAAA,IAsCW,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAtCxB;AAAA,IAuCnB,aAAe,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAvCI;AAAA,IAuCa,eAAiB,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,GAAJ;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KAvC9B;AAAA,IAwCnB,cAAgB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAxCG;AAAA,IAwCc,gBAAkB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAxChC;AAAA,IAyCnB,gBAAkB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAzCC;AAAA,IAyCgB,gBAAkB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAzClC;AAAA,IA0CnB,aAAe,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA1CI;AAAA,IA0Ca,MAAQ,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,GAAH;AAAA,QAAO,CAAP;AAAA,QAAS,CAAT;AAAA,KA1CrB;AAAA,IA2CnB,WAAa,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,GAAJ;AAAA,QAAQ,EAAR;AAAA,QAAW,CAAX;AAAA,KA3CM;AAAA,IA2CS,OAAS,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA3ClB;AAAA,IA4CnB,SAAW,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,CAAL;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KA5CQ;AAAA,IA4CO,QAAU,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,CAAL;AAAA,QAAO,CAAP;AAAA,QAAS,CAAT;AAAA,KA5CjB;AAAA,IA6CnB,kBAAoB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA7CD;AAAA,IA6CkB,YAAc,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,CAAH;AAAA,QAAK,GAAL;AAAA,QAAS,CAAT;AAAA,KA7ChC;AAAA,IA8CnB,cAAgB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KA9CG;AAAA,IA8Ca,cAAgB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA9C7B;AAAA,IA+CnB,gBAAkB,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,GAAJ;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KA/CC;AAAA,IA+Ce,iBAAmB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA/ClC;AAAA,IAgDnB,mBAAqB,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,GAAH;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KAhDF;AAAA,IAgDiB,iBAAmB,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,GAAJ;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KAhDpC;AAAA,IAiDnB,iBAAmB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KAjDA;AAAA,IAiDgB,cAAgB,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,EAAJ;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KAjDhC;AAAA,IAkDnB,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAlDM;AAAA,IAkDW,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAlDxB;AAAA,IAmDnB,UAAY,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAnDO;AAAA,IAmDU,aAAe,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAnDzB;AAAA,IAoDnB,MAAQ,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,CAAH;AAAA,QAAK,GAAL;AAAA,QAAS,CAAT;AAAA,KApDW;AAAA,IAoDE,SAAW,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KApDb;AAAA,IAqDnB,OAAS,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,CAAT;AAAA,QAAW,CAAX;AAAA,KArDU;AAAA,IAqDK,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,EAAT;AAAA,QAAY,CAAZ;AAAA,KArDlB;AAAA,IAsDnB,QAAU,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,CAAT;AAAA,QAAW,CAAX;AAAA,KAtDS;AAAA,IAsDM,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,CAAR;AAAA,QAAU,CAAV;AAAA,KAtDnB;AAAA,IAuDnB,QAAU,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAvDS;AAAA,IAuDQ,eAAiB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAvDzB;AAAA,IAwDnB,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAxDM;AAAA,IAwDW,eAAiB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAxD5B;AAAA,IAyDnB,eAAiB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAzDE;AAAA,IAyDe,YAAc,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAzD7B;AAAA,IA0DnB,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA1DM;AAAA,IA0DW,MAAQ,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,EAAT;AAAA,QAAY,CAAZ;AAAA,KA1DnB;AAAA,IA2DnB,MAAQ,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA3DW;AAAA,IA2DM,MAAQ,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA3Dd;AAAA,IA4DnB,YAAc,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA5DK;AAAA,IA4DY,QAAU,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,CAAL;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KA5DtB;AAAA,IA6DnB,eAAiB,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KA7DE;AAAA,IA8DnB,KAAO,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,CAAL;AAAA,QAAO,CAAP;AAAA,QAAS,CAAT;AAAA,KA9DY;AAAA,IA8DC,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA9Dd;AAAA,IA+DnB,WAAa,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,GAAJ;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KA/DM;AAAA,IA+DU,aAAe,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,EAAR;AAAA,QAAW,CAAX;AAAA,KA/DzB;AAAA,IAgEnB,QAAU,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAhES;AAAA,IAgEQ,YAAc,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,EAAT;AAAA,QAAY,CAAZ;AAAA,KAhEtB;AAAA,IAiEnB,UAAY,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,GAAJ;AAAA,QAAQ,EAAR;AAAA,QAAW,CAAX;AAAA,KAjEO;AAAA,IAiEQ,UAAY,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAjEpB;AAAA,IAkEnB,QAAU,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,EAAR;AAAA,QAAW,CAAX;AAAA,KAlES;AAAA,IAkEM,QAAU,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAlEhB;AAAA,IAmEnB,SAAW,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAnEQ;AAAA,IAmES,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KAnEtB;AAAA,IAoEnB,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KApEM;AAAA,IAoEW,WAAa,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KApExB;AAAA,IAqEnB,MAAQ,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KArEW;AAAA,IAqEM,aAAe,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,GAAH;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KArErB;AAAA,IAsEnB,WAAa,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,GAAJ;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KAtEM;AAAA,IAsEU,KAAO,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAtEjB;AAAA,IAuEnB,MAAQ,EAAA;AAAA,QAAC,CAAD;AAAA,QAAG,GAAH;AAAA,QAAO,GAAP;AAAA,QAAW,CAAX;AAAA,KAvEW;AAAA,IAuEI,SAAW,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAvEf;AAAA,IAwEnB,QAAU,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,EAAL;AAAA,QAAQ,EAAR;AAAA,QAAW,CAAX;AAAA,KAxES;AAAA,IAwEM,WAAa,EAAA;AAAA,QAAC,EAAD;AAAA,QAAI,GAAJ;AAAA,QAAQ,GAAR;AAAA,QAAY,CAAZ;AAAA,KAxEnB;AAAA,IAyEnB,QAAU,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAzES;AAAA,IAyEQ,OAAS,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KAzEjB;AAAA,IA0EnB,OAAS,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA1EU;AAAA,IA0EO,YAAc,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,GAAT;AAAA,QAAa,CAAb;AAAA,KA1ErB;AAAA,IA2EnB,QAAU,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,CAAT;AAAA,QAAW,CAAX;AAAA,KA3ES;AAAA,IA2EM,aAAe,EAAA;AAAA,QAAC,GAAD;AAAA,QAAK,GAAL;AAAA,QAAS,EAAT;AAAA,QAAY,CAAZ;AAAA,KA3ErB;AAAA,CAArB,CAvBA;AAoGA,SAASC,cAAT,CAAwBC,CAAxB,EAA2B;AAAA;AACzB,IAAAA,CAAA,GAAIC,IAAA,CAAKC,KAAL,CAAWF,CAAX,CAAJ,CADyB;AAAA;AAEzB,IAAA,OAAOA,CAAA,GAAI,CAAJ,GAAQ,CAAR,GAAYA,CAAA,GAAI,GAAJ,GAAU,GAAV,GAAgBA,CAAnC,CAFyB;AAAA,CApG3B;AAyGA,SAASG,eAAT,CAAyBC,CAAzB,EAA4B;AAAA;AAC1B,IAAA,OAAOA,CAAA,GAAI,CAAJ,GAAQ,CAAR,GAAYA,CAAA,GAAI,CAAJ,GAAQ,CAAR,GAAYA,CAA/B,CAD0B;AAAA,CAzG5B;AA6GA,SAASC,aAAT,CAAuBC,GAAvB,EAA4B;AAAA;AAC1B,IAAIA,IAAAA,GAAA,CAAIA,GAAA,CAAIC,MAAJ,GAAa,CAAjB,MAAwB,GAA5B;AAAA,QACE,OAAOR,cAAA,CAAeS,UAAA,CAAWF,GAAX,CAAA,GAAkB,GAAlB,GAAwB,GAAvC,CAAP,CAFwB;AAAA,IAG1B,OAAOP,cAAA,CAAeU,QAAA,CAASH,GAAT,CAAf,CAAP,CAH0B;AAAA,CA7G5B;AAmHA,SAASI,eAAT,CAAyBJ,GAAzB,EAA8B;AAAA;AAC5B,IAAIA,IAAAA,GAAA,CAAIA,GAAA,CAAIC,MAAJ,GAAa,CAAjB,MAAwB,GAA5B;AAAA,QACE,OAAOJ,eAAA,CAAgBK,UAAA,CAAWF,GAAX,CAAA,GAAkB,GAAlC,CAAP,CAF0B;AAAA,IAG5B,OAAOH,eAAA,CAAgBK,UAAA,CAAWF,GAAX,CAAhB,CAAP,CAH4B;AAAA,CAnH9B;AAyHA,SAASK,cAAT,CAAwBC,EAAxB,EAA4BC,EAA5B,EAAgCC,CAAhC,EAAmC;AAAA,IACjC,IAAIA,CAAA,GAAI,CAAR;AAAA,QAAWA,CAAA,IAAK,CAAL,CAAX;AAAA,SACK,IAAIA,CAAA,GAAI,CAAR;AAAA,QAAWA,CAAA,IAAK,CAAL,CAFiB;AAAA,IAIjC,IAAIA,CAAA,GAAI,CAAJ,GAAQ,CAAZ;AAAA,QAAe,OAAOF,EAAA,GAAM,CAAAC,EAAA,GAAKD,EAAL,IAAWE,CAAZ,GAAgB,CAA5B,CAJkB;AAAA,IAKjC,IAAIA,CAAA,GAAI,CAAJ,GAAQ,CAAZ;AAAA,QAAe,OAAOD,EAAP,CALkB;AAAA,IAMjC,IAAIC,CAAA,GAAI,CAAJ,GAAQ,CAAZ;AAAA,QAAe,OAAOF,EAAA,GAAM,CAAAC,EAAA,GAAKD,EAAL,KAAY,CAAA,GAAE,CAAF,GAAME,CAAN,CAAb,GAAwB,CAApC,CANkB;AAAA,IAOjC,OAAOF,EAAP,CAPiC;AAAA,CAzHnC;AAmIA,SAASG,aAAT,CAAuBC,OAAvB,EAAgC;AAAA;AAE9B,IAAA,IAAIV,GAAA,GAAMU,OAAA,CAAQC,OAAR,CAAgB,IAAhB,EAAsB,EAAtB,CAAA,CAA0BC,WAA1B,EAAV,CAF8B;AAAA;AAK9B,IAAIZ,IAAAA,GAAA,IAAOR,cAAX;AAAA,QAA2B,OAAOA,cAAA,CAAeQ,GAAf,CAAoBa,CAAAA,KAApB,EAAP,CALG;AAAA;AAQ9B;AAAA,IAAA,IAAIb,GAAA,CAAI,CAAJ,CAAA,KAAW,GAAf,EAAoB;AAAA,QAClB,IAAIA,GAAA,CAAIC,MAAJ,KAAe,CAAnB,EAAsB;AAAA,YACpB,IAAIa,EAAA,GAAKX,QAAA,CAASH,GAAA,CAAIe,MAAJ,CAAW,CAAX,CAAT,EAAwB,EAAxB,CAAT,CADoB;AAAA;AAEpB,YAAI,IAAA,EAAED,EAAA,IAAM,CAAN,IAAWA,EAAA,IAAM,IAAjB,CAAN;AAAA,gBAA+B,OAAO,IAAP,CAFX;AAAA;AAGpB,YAAO,OAAA;AAAA,gBAAG,CAAAA,EAAA,GAAK,IAAL,KAAe,CAAjB,GAAwB,CAAAA,EAAA,GAAK,IAAL,KAAe,CAAxC;AAAA,gBACEA,EAAA,GAAK,GAAN,GAAgB,CAAAA,EAAA,GAAK,GAAL,KAAc,CAD/B;AAAA,gBAEEA,EAAA,GAAK,EAAN,GAAe,CAAAA,EAAA,GAAK,EAAL,KAAa,CAF7B;AAAA,gBAGC,CAHD;AAAA,aAAP,CAHoB;AAAA,SAAtB,MAOO,IAAId,GAAA,CAAIC,MAAJ,KAAe,CAAnB,EAAsB;AAAA,YAC3B,IAAIa,EAAA,GAAKX,QAAA,CAASH,GAAA,CAAIe,MAAJ,CAAW,CAAX,CAAT,EAAwB,EAAxB,CAAT,CAD2B;AAAA;AAE3B,YAAI,IAAA,EAAED,EAAA,IAAM,CAAN,IAAWA,EAAA,IAAM,QAAjB,CAAN;AAAA,gBAAkC,OAAO,IAAP,CAFP;AAAA;AAG3B,YAAO,OAAA;AAAA,gBAAE,CAAAA,EAAA,GAAK,QAAL,KAAkB,EAApB;AAAA,gBACE,CAAAA,EAAA,GAAK,KAAL,KAAgB,CADlB;AAAA,gBAECA,EAAA,GAAK,GAFN;AAAA,gBAGC,CAHD;AAAA,aAAP,CAH2B;AAAA,SARX;AAAA,QAiBlB,OAAO,IAAP,CAjBkB;AAAA,KARU;AAAA,IA4B9B,IAAIE,EAAA,GAAKhB,GAAA,CAAIiB,OAAJ,CAAY,GAAZ,CAAT,EAA2BC,EAAA,GAAKlB,GAAA,CAAIiB,OAAJ,CAAY,GAAZ,CAAhC,CA5B8B;AAAA,IA6B9B,IAAID,EAAA,KAAO,CAAC,CAAR,IAAaE,EAAA,GAAK,CAAL,KAAWlB,GAAA,CAAIC,MAAhC,EAAwC;AAAA,QACtC,IAAIkB,KAAA,GAAQnB,GAAA,CAAIe,MAAJ,CAAW,CAAX,EAAcC,EAAd,CAAZ,CADsC;AAAA,QAEtC,IAAII,MAAA,GAASpB,GAAA,CAAIe,MAAJ,CAAWC,EAAA,GAAG,CAAd,EAAiBE,EAAA,IAAIF,EAAA,GAAG,CAAH,CAArB,EAA4BK,KAA5B,CAAkC,GAAlC,CAAb,CAFsC;AAAA,QAGtC,IAAIC,KAAA,GAAQ,CAAZ,CAHsC;AAAA;AAItC,QAAA,QAAQH,KAAR;AAAA,QACE,KAAK,MAAL;AAAA,YACE,IAAIC,MAAA,CAAOnB,MAAP,KAAkB,CAAtB;AAAA,gBAAyB,OAAO,IAAP,CAD3B;AAAA,YAEEqB,KAAA,GAAQlB,eAAA,CAAgBgB,MAAA,CAAOG,GAAP,EAAhB,CAAR,CAHJ;AAAA;AAKE,QAAA,KAAK,KAAL;AAAA,YACE,IAAIH,MAAA,CAAOnB,MAAP,KAAkB,CAAtB;AAAA,gBAAyB,OAAO,IAAP,CAD3B;AAAA,YAEE,OAAO;AAAA,gBAACF,aAAA,CAAcqB,MAAA,CAAO,CAAP,CAAd,CAAD;AAAA,gBACCrB,aAAA,CAAcqB,MAAA,CAAO,CAAP,CAAd,CADD;AAAA,gBAECrB,aAAA,CAAcqB,MAAA,CAAO,CAAP,CAAd,CAFD;AAAA,gBAGCE,KAHD;AAAA,aAAP,CAPJ;AAAA,QAWE,KAAK,MAAL;AAAA,YACE,IAAIF,MAAA,CAAOnB,MAAP,KAAkB,CAAtB;AAAA,gBAAyB,OAAO,IAAP,CAD3B;AAAA,YAEEqB,KAAA,GAAQlB,eAAA,CAAgBgB,MAAA,CAAOG,GAAP,EAAhB,CAAR,CAbJ;AAAA;AAeE,QAAA,KAAK,KAAL;AAAA,YACE,IAAIH,MAAA,CAAOnB,MAAP,KAAkB,CAAtB;AAAA,gBAAyB,OAAO,IAAP,CAD3B;AAAA,YAEE,IAAIO,CAAA,GAAM,CAACN,UAAA,CAAWkB,MAAA,CAAO,CAAP,CAAX,CAAwB,GAAA,GAAzB,GAAgC,GAAhC,IAAuC,GAAzC,GAAgD,GAAxD,CAFF;AAAA;AAKE;AAAA;AAAA,YAAII,IAAAA,CAAA,GAAIpB,eAAA,CAAgBgB,MAAA,CAAO,CAAP,CAAhB,CAAR,CALF;AAAA,YAME,IAAIK,CAAA,GAAIrB,eAAA,CAAgBgB,MAAA,CAAO,CAAP,CAAhB,CAAR,CANF;AAAA,YAOE,IAAIb,EAAA,GAAKkB,CAAA,IAAK,GAAL,GAAWA,CAAA,IAAKD,CAAA,GAAI,CAAJ,CAAhB,GAAyBC,CAAA,GAAID,CAAJ,GAAQC,CAAA,GAAID,CAA9C,CAPF;AAAA,YAQE,IAAIlB,EAAA,GAAKmB,CAAA,GAAI,CAAJ,GAAQlB,EAAjB,CARF;AAAA,YASE,OAAO;AAAA,gBAACd,cAAA,CAAeY,cAAA,CAAeC,EAAf,EAAmBC,EAAnB,EAAuBC,CAAA,GAAE,CAAA,GAAE,CAA3B,CAAA,GAAgC,GAA/C,CAAD;AAAA,gBACCf,cAAA,CAAeY,cAAA,CAAeC,EAAf,EAAmBC,EAAnB,EAAuBC,CAAvB,CAA4B,GAAA,GAA3C,CADD;AAAA,gBAECf,cAAA,CAAeY,cAAA,CAAeC,EAAf,EAAmBC,EAAnB,EAAuBC,CAAA,GAAE,CAAA,GAAE,CAA3B,CAAA,GAAgC,GAA/C,CAFD;AAAA,gBAGCc,KAHD;AAAA,aAAP,CAxBJ;AAAA,QA4BE;AAAA,YACE,OAAO,IAAP,CA7BJ;AAAA,SAJsC;AAAA,KA7BV;AAAA,IAkE9B,OAAO,IAAP,CAlE8B;AAAA,CAnIhC;AAwMA,IAAI;AAAA,IAAEI,eAAAA,GAAAA,cAAAA,CAAAA,aAAA,GAAwBjB,aAAxB,CAAF;AAAA,CAAJ,CAA8C,OAAMkB,CAAN,EAAS;AAAA;;ACtMvD;AAaA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAAMC,KAAN,CAAY;AAAA,IAMRC,WAAA,CAAYC,CAAZ,EAAuBC,CAAvB,EAAkCC,CAAlC,EAA6CC,CAAA,GAAY,CAAzD,EAA4D;AAAA,QACxD,IAAKH,CAAAA,CAAL,GAASA,CAAT,CADwD;AAAA,QAExD,IAAKC,CAAAA,CAAL,GAASA,CAAT,CAFwD;AAAA,QAGxD,IAAKC,CAAAA,CAAL,GAASA,CAAT,CAHwD;AAAA,QAIxD,IAAKC,CAAAA,CAAL,GAASA,CAAT,CAJwD;AAAA,KANpD;AAAA;AAuBR;AAAA;AAAA;AAAA,IAAOC,OAAAA,KAAP,CAAaC,KAAb,EAA0D;AAAA,QACtD,IAAI,CAACA,KAAL,EAAY;AAAA,YACR,OAAOC,SAAP,CADQ;AAAA,SAD0C;AAAA,QAKtD,IAAID,KAAA,YAAiBP,KAArB,EAA4B;AAAA,YACxB,OAAOO,KAAP,CADwB;AAAA,SAL0B;AAAA,QAStD,IAAI,OAAOA,KAAP,KAAiB,QAArB,EAA+B;AAAA,YAC3B,OAAOC,SAAP,CAD2B;AAAA,SATuB;AAAA,QAatD,MAAMC,IAAA,GAAO5B,eAAA,CAAc0B,KAAd,CAAb,CAbsD;AAAA,QActD,IAAI,CAACE,IAAL,EAAW;AAAA,YACP,OAAOD,SAAP,CADO;AAAA,SAd2C;AAAA,QAkBtD,OAAO,IAAIR,KAAJ,CACHS,IAAA,CAAK,CAAL,CAAU,GAAA,GAAV,GAAgBA,IAAA,CAAK,CAAL,CADb,EAEHA,IAAA,CAAK,CAAL,IAAU,GAAV,GAAgBA,IAAA,CAAK,CAAL,CAFb,EAGHA,IAAA,CAAK,CAAL,IAAU,GAAV,GAAgBA,IAAA,CAAK,CAAL,CAHb,EAIHA,IAAA,CAAK,CAAL,CAJG,CAAP,CAlBsD;AAAA,KAvBlD;AAAA;AA2DR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAAC,QAAA,GAAmB;AAAA,QACf,MAAM,CAACR,CAAD,EAAIC,CAAJ,EAAOC,CAAP,EAAUC,CAAV,CAAA,GAAe,IAAKM,CAAAA,OAAL,EAArB,CADe;AAAA,QAEf,OAAO,CAAC,KAAD,GAAQ5C,IAAA,CAAKC,KAAL,CAAWkC,CAAX,CAAR,EAAsB,CAAtB,GAAyBnC,IAAA,CAAKC,KAAL,CAAWmC,CAAX,CAAzB,EAAuC,CAAvC,GAA0CpC,IAAA,CAAKC,KAAL,CAAWoC,CAAX,CAA1C,EAAwD,CAAxD,GAA2DC,CAA3D,EAA6D,CAA7D,CAAP,CAFe;AAAA,KA3DX;AAAA;AAqER;AAAA;AAAA;AAAA;AAAA,IAAAM,OAAA,GAA4C;AAAA,QACxC,MAAM,CAACT,CAAD,EAAIC,CAAJ,EAAOC,CAAP,EAAUC,CAAV,CAAe,GAAA,IAArB,CADwC;AAAA,QAExC,OAAOA,CAAA,KAAM,CAAN,GAAU;AAAA,YAAC,CAAD;AAAA,YAAI,CAAJ;AAAA,YAAO,CAAP;AAAA,YAAU,CAAV;AAAA,SAAV,GAAyB;AAAA,YAC5BH,CAAA,GAAI,GAAJ,GAAUG,CADkB;AAAA,YAE5BF,CAAA,GAAI,GAAJ,GAAUE,CAFkB;AAAA,YAG5BD,CAAA,GAAI,GAAJ,GAAUC,CAHkB;AAAA,YAI5BA,CAJ4B;AAAA,SAAhC,CAFwC;AAAA,KArEpC;AAAA;AAoFR;AAAA;AAAA;AAAA;AAAA,IAAAO,SAAA,GAA8C;AAAA,QAC1C,MAAM,CAACV,CAAD,EAAIC,CAAJ,EAAOC,CAAP,EAAUC,CAAV,CAAe,GAAA,IAArB,CAD0C;AAAA,QAE1C,OAAOA,CAAA,KAAM,CAAN,GAAU;AAAA,YAAC,CAAD;AAAA,YAAI,CAAJ;AAAA,YAAO,CAAP;AAAA,YAAU,CAAV;AAAA,SAAV,GAAyB;AAAA,YAC5BH,CAAA,GAAIG,CADwB;AAAA,YAE5BF,CAAA,GAAIE,CAFwB;AAAA,YAG5BD,CAAA,GAAIC,CAHwB;AAAA,YAI5BA,CAJ4B;AAAA,SAAhC,CAF0C;AAAA,KApFtC;AAAA;AAmGR;AAAA;AAAA;AAAA;AAAA,IAAAQ,2BAAA,GAAgE;AAAA,QAC5D,MAAM,CAACX,CAAD,EAAIC,CAAJ,EAAOC,CAAP,EAAUC,CAAV,CAAe,GAAA,IAArB,CAD4D;AAAA,QAE5D,OAAO;AAAA,YACHH,CADG;AAAA,YAEHC,CAFG;AAAA,YAGHC,CAHG;AAAA,YAIHC,CAJG;AAAA,SAAP,CAF4D;AAAA,KAnGxD;AAAA,CAfZ;AA6HAL,KAAA,CAAMc,KAAN,GAAc,IAAId,KAAJ,CAAU,CAAV,EAAa,CAAb,EAAgB,CAAhB,EAAmB,CAAnB,CAAd,CA7HA;AA8HAA,KAAA,CAAMe,KAAN,GAAc,IAAIf,KAAJ,CAAU,CAAV,EAAa,CAAb,EAAgB,CAAhB,EAAmB,CAAnB,CAAd,CA9HA;AA+HAA,KAAA,CAAMgB,WAAN,GAAoB,IAAIhB,KAAJ,CAAU,CAAV,EAAa,CAAb,EAAgB,CAAhB,EAAmB,CAAnB,CAApB,CA/HA;AAgIAA,KAAA,CAAMiB,GAAN,GAAY,IAAIjB,KAAJ,CAAU,CAAV,EAAa,CAAb,EAAgB,CAAhB,EAAmB,CAAnB,CAAZ,CAhIA;AAiIAA,KAAA,CAAMkB,IAAN,GAAa,IAAIlB,KAAJ,CAAU,CAAV,EAAa,CAAb,EAAgB,CAAhB,EAAmB,CAAnB,CAAb,CAjIA;AAmIA,cAAA,KAAA;;AC5HA,SAASmB,cAAT,CAAwBC,KAAxB,EAA+B;AAAA,IAC3B,OAAO,OAAOA,KAAP,KAAiB,QAAjB,GAA4B;AAAA,QAAC,SAAD;AAAA,QAAYA,KAAZ;AAAA,KAA5B,GAAiDA,KAAxD,CAD2B;AAAA,CAP/B;AAWe,SAASC,eAAT,CAAyBC,UAAzB,EAA0CC,YAA1C,EAA6G;AAAA,IACxH,IAAIC,KAAA,GAAQF,UAAA,CAAWE,KAAvB,CADwH;AAAA,IAExH,IAAI,CAACA,KAAL,EAAY;AAAA;AAER,QAAA,OAAOC,uBAAA,CAAwBH,UAAxB,EAAoCC,YAApC,CAAP,CAFQ;AAAA,KAF4G;AAAA,IAOxH,MAAMG,uBAAA,GAA0BF,KAAA,IAAS,OAAOA,KAAA,CAAM,CAAN,CAAS,CAAA,CAAT,CAAP,KAAuB,QAAhE,CAPwH;AAAA,IAQxH,MAAMG,gBAAA,GAAmBD,uBAAA,IAA2BJ,UAAA,CAAWM,QAAX,KAAwBpB,SAA5E,CARwH;AAAA,IASxH,MAAMqB,aAAA,GAAgBH,uBAAA,IAA2B,CAACC,gBAAlD,CATwH;AAAA,IAWxHH,KAAA,GAAQA,KAAA,CAAMM,GAAN,CAAWC,IAAD,IAAU;AAAA,QACxB,IAAI,CAACJ,gBAAD,IAAqBJ,YAAA,CAAaS,MAAlC,IAA4C,OAAOD,IAAA,CAAK,CAAL,CAAP,KAAmB,QAAnE,EAA6E;AAAA,YACzE,OAAO;AAAA,gBAACA,IAAA,CAAK,CAAL,CAAD;AAAA,gBAAUE,kBAAA,CAAmBF,IAAA,CAAK,CAAL,CAAnB,CAAV;AAAA,aAAP,CADyE;AAAA,SADrD;AAAA,QAIxB,OAAO;AAAA,YAACA,IAAA,CAAK,CAAL,CAAD;AAAA,YAAUZ,cAAA,CAAeY,IAAA,CAAK,CAAL,CAAf,CAAV;AAAA,SAAP,CAJwB;AAAA,KAApB,CAAR,CAXwH;AAAA,IAkBxH,IAAIL,uBAAJ,EAA6B;AAAA,QACzB,OAAOQ,8BAAA,CAA+BZ,UAA/B,EAA2CC,YAA3C,EAAyDC,KAAzD,CAAP,CADyB;AAAA,KAA7B,MAEO,IAAIK,aAAJ,EAAmB;AAAA,QACtB,OAAOM,mBAAA,CAAoBb,UAApB,EAAgCC,YAAhC,EAA8CC,KAA9C,CAAP,CADsB;AAAA,KAAnB,MAEA;AAAA,QACH,OAAOY,uBAAA,CAAwBd,UAAxB,EAAoCC,YAApC,EAAkDC,KAAlD,CAAP,CADG;AAAA,KAtBiH;AAAA,CAX5H;AAsCA,SAASC,uBAAT,CAAiCH,UAAjC,EAA6CC,YAA7C,EAAyE;AAAA,IACrE,MAAMc,GAAA,GAAM;AAAA,QAAC,KAAD;AAAA,QAAQf,UAAA,CAAWM,QAAnB;AAAA,KAAZ,CADqE;AAAA,IAGrE,IAAIN,UAAA,CAAWgB,OAAX,KAAuB9B,SAA3B,EAAsC;AAAA;AAGlC;AAAA,QAAA,OAAOe,YAAA,CAAagB,IAAb,KAAsB,QAAtB,GAAiC;AAAA,YAAC,QAAD;AAAA,YAAWF,GAAX;AAAA,SAAjC,GAAmDA,GAA1D,CAHkC;AAAA,KAAtC,MAIO,IAAId,YAAA,CAAagB,IAAb,KAAsB,MAA1B,EAAkC;AAAA,QACrC,OAAO;AAAA,YACH,OADG;AAAA,YAEHF,GAFG;AAAA,YAGHG,MAAA,CAAOC,IAAP,CAAYlB,YAAA,CAAamB,MAAzB,CAHG;AAAA,YAIHL,GAJG;AAAA,YAKHf,UAAA,CAAWgB,OALR;AAAA,SAAP,CADqC;AAAA,KAAlC,MAQA;AAAA,QACH,MAAMK,UAAA,GAAa;AAAA,YAACpB,YAAA,CAAagB,IAAb,KAAsB,OAAtB,GAAgC,UAAhC,GAA6ChB,YAAA,CAAagB,IAA3D;AAAA,YAAiEF,GAAjE;AAAA,YAAsElB,cAAA,CAAeG,UAAA,CAAWgB,OAA1B,CAAtE;AAAA,SAAnB,CADG;AAAA,QAEH,IAAIf,YAAA,CAAagB,IAAb,KAAsB,OAA1B,EAAmC;AAAA,YAC/BI,UAAA,CAAWC,MAAX,CAAkB,CAAlB,EAAqB,CAArB,EAAwBrB,YAAA,CAAaH,KAArC,EAA4CG,YAAA,CAAalD,MAAb,IAAuB,IAAnE,CAD+B,CAAA;AAAA,SAFhC;AAAA,QAKH,OAAOsE,UAAP,CALG;AAAA,KAf8D;AAAA,CAtCzE;AA8DA,SAASE,sBAAT,CAAgCvB,UAAhC,EAA4C;AAAA,IACxC,QAAQA,UAAA,CAAWwB,UAAnB;AAAA,IACA,KAAK,KAAL;AAAA,QAAY,OAAO,iBAAP,CADZ;AAAA,IAEA,KAAK,KAAL;AAAA,QAAY,OAAO,iBAAP,CAFZ;AAAA,IAGA;AAAA,QAAS,OAAO,aAAP,CAHT;AAAA,KADwC;AAAA,CA9D5C;AAsEA,SAASZ,8BAAT,CAAwCZ,UAAxC,EAAoDC,YAApD,EAAkEC,KAAlE,EAAyE;AAAA,IACrE,MAAMuB,yBAAA,GAA4B,EAAlC,CADqE;AAAA,IAErE,MAAMC,oBAAA,GAAuB,EAA7B,CAFqE;AAAA,IAGrE,MAAMC,SAAA,GAAY,EAAlB,CAHqE;AAAA,IAIrE,KAAK,IAAIrD,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAI4B,KAAA,CAAMnD,MAA1B,EAAkCuB,CAAA,EAAlC,EAAuC;AAAA,QACnC,MAAMmC,IAAA,GAAOP,KAAA,CAAM5B,CAAN,CAAb,CADmC;AAAA,QAEnC,MAAMsD,IAAA,GAAOnB,IAAA,CAAK,CAAL,CAAA,CAAQmB,IAArB,CAFmC;AAAA,QAGnC,IAAIH,yBAAA,CAA0BG,IAA1B,CAAA,KAAoC1C,SAAxC,EAAmD;AAAA,YAC/CuC,yBAAA,CAA0BG,IAA1B,CAAkC,GAAA;AAAA,gBAC9BA,IAD8B;AAAA,gBAE9BX,IAAA,EAAMjB,UAAA,CAAWiB,IAFa;AAAA,gBAG9BX,QAAA,EAAUN,UAAA,CAAWM,QAHS;AAAA,gBAI9BU,OAAA,EAAShB,UAAA,CAAWgB,OAJU;AAAA,aAAlC,CAD+C;AAAA,YAO/CU,oBAAA,CAAqBE,IAArB,CAAA,GAA6B,EAA7B,CAP+C;AAAA,YAQ/CD,SAAA,CAAUE,IAAV,CAAeD,IAAf,CAR+C,CAAA;AAAA,SAHhB;AAAA,QAanCF,oBAAA,CAAqBE,IAArB,CAAA,CAA2BC,IAA3B,CAAgC;AAAA,YAACpB,IAAA,CAAK,CAAL,CAAA,CAAQX,KAAT;AAAA,YAAgBW,IAAA,CAAK,CAAL,CAAhB;AAAA,SAAhC,CAbmC,CAAA;AAAA,KAJ8B;AAAA;AAwBrE;AAAA;AAAA;AAAA,IAAMqB,MAAAA,YAAA,GAAeC,eAAA,CAAgB,EAAhB,EAAoB9B,YAApB,CAArB,CAxBqE;AAAA,IAyBrE,IAAI6B,YAAA,KAAiB,aAArB,EAAoC;AAAA,QAChC,MAAMT,UAAA,GAAa;AAAA,YAACE,sBAAA,CAAuBvB,UAAvB,CAAD;AAAA,YAAqC,CAAC,QAAD,CAArC;AAAA,YAAiD,CAAC,MAAD,CAAjD;AAAA,SAAnB,CADgC;AAAA,QAGhC,KAAWgC,MAAAA,CAAX,IAAgBL,SAAhB,EAA2B;AAAA,YACvB,MAAMM,MAAA,GAASnB,uBAAA,CAAwBW,yBAAA,CAA0BO,CAA1B,CAAxB,EAAsD/B,YAAtD,EAAoEyB,oBAAA,CAAqBM,CAArB,CAApE,CAAf,CADuB;AAAA,YAEvBE,cAAA,CAAeb,UAAf,EAA2BW,CAA3B,EAA8BC,MAA9B,EAAsC,KAAtC,CAFuB,CAAA;AAAA,SAHK;AAAA,QAQhC,OAAOZ,UAAP,CARgC;AAAA,KAApC,MASO;AAAA,QACH,MAAMA,UAAA,GAAa;AAAA,YAAC,MAAD;AAAA,YAAS,CAAC,MAAD,CAAT;AAAA,SAAnB,CADG;AAAA,QAGH,KAAWW,MAAAA,CAAX,IAAgBL,SAAhB,EAA2B;AAAA,YACvB,MAAMM,MAAA,GAASnB,uBAAA,CAAwBW,yBAAA,CAA0BO,CAA1B,CAAxB,EAAsD/B,YAAtD,EAAoEyB,oBAAA,CAAqBM,CAArB,CAApE,CAAf,CADuB;AAAA,YAEvBE,cAAA,CAAeb,UAAf,EAA2BW,CAA3B,EAA8BC,MAA9B,EAAsC,IAAtC,CAFuB,CAAA;AAAA,SAHxB;AAAA,QAQHE,wBAAA,CAAyBd,UAAzB,CARG,CAAA;AAAA,QAUH,OAAOA,UAAP,CAVG;AAAA,KAlC8D;AAAA,CAtEzE;AAsHA,SAASe,QAAT,CAAkBrD,CAAlB,EAAqBD,CAArB,EAAwB;AAAA,IACpB,IAAIC,CAAA,KAAMG,SAAV;AAAA,QAAqB,OAAOH,CAAP,CADD;AAAA,IAEpB,IAAID,CAAA,KAAMI,SAAV;AAAA,QAAqB,OAAOJ,CAAP,CAFD;AAAA,CAtHxB;AA2HA,SAASuD,WAAT,CAAqBrC,UAArB,EAAiCC,YAAjC,EAA+C;AAAA,IAC3C,MAAMqC,YAAA,GAAezC,cAAA,CAAeuC,QAAA,CAASpC,UAAA,CAAWgB,OAApB,EAA6Bf,YAAA,CAAae,OAA1C,CAAf,CAArB,CAD2C;AAAA;AAS3C;AAAA;AAAA;AAAA;AAAA;AAAA,IAAIsB,IAAAA,YAAA,KAAiBpD,SAAjB,IAA8Be,YAAA,CAAagB,IAAb,KAAsB,eAAxD,EAAyE;AAAA,QACrE,OAAO,EAAP,CADqE;AAAA,KAT9B;AAAA,IAY3C,OAAOqB,YAAP,CAZ2C;AAAA,CA3H/C;AA0IA,SAASxB,uBAAT,CAAiCd,UAAjC,EAA6CC,YAA7C,EAA2DC,KAA3D,EAAkE;AAAA,IAC9D,MAAMe,IAAA,GAAOc,eAAA,CAAgB/B,UAAhB,EAA4BC,YAA5B,CAAb,CAD8D;AAAA,IAE9D,MAAMc,GAAA,GAAM;AAAA,QAAC,KAAD;AAAA,QAAQf,UAAA,CAAWM,QAAnB;AAAA,KAAZ,CAF8D;AAAA,IAG9D,IAAIW,IAAA,KAAS,aAAT,IAA0B,OAAOf,KAAA,CAAM,CAAN,CAAS,CAAA,CAAT,CAAP,KAAuB,SAArD,EAAgE;AAAA,QAE5D,MAAMmB,UAAA,GAAa,CAAC,MAAD,CAAnB,CAF4D;AAAA,QAG5D,KAAWZ,MAAAA,IAAX,IAAmBP,KAAnB,EAA0B;AAAA,YACtBmB,UAAA,CAAWQ,IAAX,CAAgB;AAAA,gBAAC,IAAD;AAAA,gBAAOd,GAAP;AAAA,gBAAYN,IAAA,CAAK,CAAL,CAAZ;AAAA,aAAhB,EAAsCA,IAAA,CAAK,CAAL,CAAtC,CADsB,CAAA;AAAA,SAHkC;AAAA,QAO5DY,UAAA,CAAWQ,IAAX,CAAgBQ,WAAA,CAAYrC,UAAZ,EAAwBC,YAAxB,CAAhB,CAP4D,CAAA;AAAA,QAQ5D,OAAOoB,UAAP,CAR4D;AAAA,KAAhE,MASO,IAAIJ,IAAA,KAAS,aAAb,EAA4B;AAAA,QAC/B,MAAMI,UAAA,GAAa;AAAA,YAAC,OAAD;AAAA,YAAUN,GAAV;AAAA,SAAnB,CAD+B;AAAA,QAE/B,KAAWN,MAAAA,IAAX,IAAmBP,KAAnB,EAA0B;AAAA,YACtBgC,cAAA,CAAeb,UAAf,EAA2BZ,IAAA,CAAK,CAAL,CAA3B,EAAoCA,IAAA,CAAK,CAAL,CAApC,EAA6C,KAA7C,CADsB,CAAA;AAAA,SAFK;AAAA,QAK/BY,UAAA,CAAWQ,IAAX,CAAgBQ,WAAA,CAAYrC,UAAZ,EAAwBC,YAAxB,CAAhB,CAL+B,CAAA;AAAA,QAM/B,OAAOoB,UAAP,CAN+B;AAAA,KAA5B,MAOA,IAAIJ,IAAA,KAAS,UAAb,EAAyB;AAAA,QAC5B,MAAMI,UAAA,GAAa;AAAA,YAAC,MAAD;AAAA,YAAS;AAAA,gBAAC,QAAD;AAAA,gBAAWN,GAAX;AAAA,aAAT;AAAA,SAAnB,CAD4B;AAAA,QAE5B,KAAWN,MAAAA,IAAX,IAAmBP,KAAnB,EAA0B;AAAA,YACtBgC,cAAA,CAAeb,UAAf,EAA2BZ,IAAA,CAAK,CAAL,CAA3B,EAAoCA,IAAA,CAAK,CAAL,CAApC,EAA6C,IAA7C,CADsB,CAAA;AAAA,SAFE;AAAA,QAK5B0B,wBAAA,CAAyBd,UAAzB,CAL4B,CAAA;AAAA,QAM5B,OAAOrB,UAAA,CAAWgB,OAAX,KAAuB9B,SAAvB,GAAmCmC,UAAnC,GAAgD;AAAA,YACnD,MADmD;AAAA,YAEnD;AAAA,gBAAC,IAAD;AAAA,gBAAO;AAAA,oBAAC,QAAD;AAAA,oBAAWN,GAAX;AAAA,iBAAP;AAAA,gBAAwB,QAAxB;AAAA,aAFmD;AAAA,YAGnDM,UAHmD;AAAA,YAInDxB,cAAA,CAAeG,UAAA,CAAWgB,OAA1B,CAJmD;AAAA,SAAvD,CAN4B;AAAA,KAAzB,MAYA,IAAIC,IAAA,KAAS,aAAb,EAA4B;AAAA,QAC/B,MAAMsB,IAAA,GAAOvC,UAAA,CAAWuC,IAAX,KAAoBrD,SAApB,GAAgCc,UAAA,CAAWuC,IAA3C,GAAkD,CAA/D,CAD+B;AAAA,QAE/B,MAAMlB,UAAA,GAAa;AAAA,YACfE,sBAAA,CAAuBvB,UAAvB,CADe;AAAA,YAEfuC,IAAA,KAAS,CAAT,GAAa,CAAC,QAAD,CAAb,GAA0B;AAAA,gBAAC,aAAD;AAAA,gBAAgBA,IAAhB;AAAA,aAFX;AAAA,YAGf;AAAA,gBAAC,QAAD;AAAA,gBAAWxB,GAAX;AAAA,aAHe;AAAA,SAAnB,CAF+B;AAAA,QAQ/B,KAAWN,MAAAA,IAAX,IAAmBP,KAAnB,EAA0B;AAAA,YACtBgC,cAAA,CAAeb,UAAf,EAA2BZ,IAAA,CAAK,CAAL,CAA3B,EAAoCA,IAAA,CAAK,CAAL,CAApC,EAA6C,KAA7C,CADsB,CAAA;AAAA,SARK;AAAA,QAW/B,OAAOT,UAAA,CAAWgB,OAAX,KAAuB9B,SAAvB,GAAmCmC,UAAnC,GAAgD;AAAA,YACnD,MADmD;AAAA,YAEnD;AAAA,gBAAC,IAAD;AAAA,gBAAO;AAAA,oBAAC,QAAD;AAAA,oBAAWN,GAAX;AAAA,iBAAP;AAAA,gBAAwB,QAAxB;AAAA,aAFmD;AAAA,YAGnDM,UAHmD;AAAA,YAInDxB,cAAA,CAAeG,UAAA,CAAWgB,OAA1B,CAJmD;AAAA,SAAvD,CAX+B;AAAA,KAA5B,MAiBA;AAAA,QACH,MAAM,IAAIwB,KAAJ,CAAU,CAAC,+BAAD,GAAkCvB,IAAlC,EAAV,CAAA,CAAN,CADG;AAAA,KAhDuD;AAAA,CA1IlE;AA+LA,SAASJ,mBAAT,CAA6Bb,UAA7B,EAAyCC,YAAzC,EAAuDC,KAAvD,EAA8DjB,KAAA,GAAQ,CAAC,MAAD,CAAtE,EAAgF;AAAA,IAC5E,MAAMgC,IAAA,GAAOc,eAAA,CAAgB/B,UAAhB,EAA4BC,YAA5B,CAAb,CAD4E;AAAA,IAE5E,IAAIoB,UAAJ,CAF4E;AAAA,IAG5E,IAAIoB,MAAA,GAAS,KAAb,CAH4E;AAAA,IAI5E,IAAIxB,IAAA,KAAS,UAAb,EAAyB;AAAA,QACrBI,UAAA,GAAa;AAAA,YAAC,MAAD;AAAA,YAASpC,KAAT;AAAA,SAAb,CADqB;AAAA,QAErBwD,MAAA,GAAS,IAAT,CAFqB;AAAA,KAAzB,MAGO,IAAIxB,IAAA,KAAS,aAAb,EAA4B;AAAA,QAC/B,MAAMsB,IAAA,GAAOvC,UAAA,CAAWuC,IAAX,KAAoBrD,SAApB,GAAgCc,UAAA,CAAWuC,IAA3C,GAAkD,CAA/D,CAD+B;AAAA,QAE/BlB,UAAA,GAAa;AAAA,YAACE,sBAAA,CAAuBvB,UAAvB,CAAD;AAAA,YAAqCuC,IAAA,KAAS,CAAT,GAAa,CAAC,QAAD,CAAb,GAA0B;AAAA,gBAAC,aAAD;AAAA,gBAAgBA,IAAhB;AAAA,aAA/D;AAAA,YAAsFtD,KAAtF;AAAA,SAAb,CAF+B;AAAA,KAA5B,MAIA;AAAA,QACH,MAAM,IAAIuD,KAAJ,CAAU,CAAC,4BAAD,GAA+BvB,IAA/B,EAAoC,CAApC,CAAV,CAAN,CADG;AAAA,KAXqE;AAAA,IAe5E,KAAWR,MAAAA,IAAX,IAAmBP,KAAnB,EAA0B;AAAA,QACtBgC,cAAA,CAAeb,UAAf,EAA2BZ,IAAA,CAAK,CAAL,CAA3B,EAAoCA,IAAA,CAAK,CAAL,CAApC,EAA6CgC,MAA7C,CADsB,CAAA;AAAA,KAfkD;AAAA,IAmB5EN,wBAAA,CAAyBd,UAAzB,CAnB4E,CAAA;AAAA,IAqB5E,OAAOA,UAAP,CArB4E;AAAA,CA/LhF;AAuNA,SAASc,wBAAT,CAAkCd,UAAlC,EAA8C;AAAA;AAE1C,IAAIA,IAAAA,UAAA,CAAW,CAAX,CAAkB,KAAA,MAAlB,IAA4BA,UAAA,CAAWtE,MAAX,KAAsB,CAAtD,EAAyD;AAAA,QACrDsE,UAAA,CAAWQ,IAAX,CAAgB,CAAhB,CADqD,CAAA;AAAA,QAErDR,UAAA,CAAWQ,IAAX,CAAgBR,UAAA,CAAW,CAAX,CAAhB,CAFqD,CAAA;AAAA,KAFf;AAAA,CAvN9C;AA+NA,SAASa,cAAT,CAAwBQ,KAAxB,EAA+BzD,KAA/B,EAAsCgD,MAAtC,EAA8CQ,MAA9C,EAAsD;AAAA;AAGlD;AAAA,IAAA,IAAIC,KAAA,CAAM3F,MAAN,GAAe,CAAf,IAAoBkC,KAAA,KAAUyD,KAAA,CAAMA,KAAA,CAAM3F,MAAN,GAAe,CAArB,CAAlC,EAA2D;AAAA,QACvD,OADuD;AAAA,KAHT;AAAA;AAOlD,IAAI,IAAA,EAAE0F,MAAA,IAAUC,KAAA,CAAM3F,MAAN,KAAiB,CAA3B,CAAN,EAAqC;AAAA,QACjC2F,KAAA,CAAMb,IAAN,CAAW5C,KAAX,CADiC,CAAA;AAAA,KAPa;AAAA,IAUlDyD,KAAA,CAAMb,IAAN,CAAWI,MAAX,CAVkD,CAAA;AAAA,CA/NtD;AA4OA,SAASF,eAAT,CAAyB/B,UAAzB,EAAqCC,YAArC,EAAmD;AAAA,IAC/C,IAAID,UAAA,CAAWiB,IAAf,EAAqB;AAAA,QACjB,OAAOjB,UAAA,CAAWiB,IAAlB,CADiB;AAAA,KAArB,MAEO;AAAA,QAEH,OAAQhB,YAAA,CAAaoB,UAAd,CAA+BsB,YAA/B,GAA8C,aAA9C,GAA8D,UAArE,CAFG;AAAA,KAHwC;AAAA,CA5OnD;AAsPA;AAAO,SAAShC,kBAAT,CAA4BrC,CAA5B,EAAyE;AAAA,IAC5E,MAAMsE,MAAA,GAAS,CAAC,QAAD,CAAf,CAD4E;AAAA,IAE5E,MAAMC,EAAA,GAAK,aAAX,CAF4E;AAAA,IAG5E,IAAIC,GAAA,GAAM,CAAV,CAH4E;AAAA,IAI5E,KAAK,IAAIC,KAAA,GAAQF,EAAA,CAAGG,IAAH,CAAQ1E,CAAR,CAAZ,EAAwByE,KAAA,KAAU,IAAvC,EAA6CA,KAAA,GAAQF,EAAA,CAAGG,IAAH,CAAQ1E,CAAR,CAArD,EAAiE;AAAA,QAC7D,MAAM2E,OAAA,GAAU3E,CAAA,CAAEX,KAAF,CAAQmF,GAAR,EAAaD,EAAA,CAAGK,SAAH,GAAeH,KAAA,CAAM,CAAN,CAAShG,CAAAA,MAArC,CAAhB,CAD6D;AAAA,QAE7D+F,GAAA,GAAMD,EAAA,CAAGK,SAAT,CAF6D;AAAA,QAG7D,IAAID,OAAA,CAAQlG,MAAR,GAAiB,CAArB;AAAA,YAAwB6F,MAAA,CAAOf,IAAP,CAAYoB,OAAZ,CAHqC,CAAA;AAAA,QAI7DL,MAAA,CAAOf,IAAP,CAAY;AAAA,YAAC,KAAD;AAAA,YAAQkB,KAAA,CAAM,CAAN,CAAR;AAAA,SAAZ,CAJ6D,CAAA;AAAA,KAJW;AAAA,IAW5E,IAAIH,MAAA,CAAO7F,MAAP,KAAkB,CAAtB,EAAyB;AAAA,QACrB,OAAOuB,CAAP,CADqB;AAAA,KAXmD;AAAA,IAe5E,IAAIwE,GAAA,GAAMxE,CAAA,CAAEvB,MAAZ,EAAoB;AAAA,QAChB6F,MAAA,CAAOf,IAAP,CAAYvD,CAAA,CAAEX,KAAF,CAAQmF,GAAR,CAAZ,CADgB,CAAA;AAAA,KAApB,MAEO,IAAIF,MAAA,CAAO7F,MAAP,KAAkB,CAAtB,EAAyB;AAAA,QAC5B,OAAO;AAAA,YAAC,WAAD;AAAA,YAAc6F,MAAA,CAAO,CAAP,CAAd;AAAA,SAAP,CAD4B;AAAA,KAjB4C;AAAA,IAqB5E,OAAOA,MAAP,CArB4E;AAAA;;ACpPhF;AAAA,MAAMO,YAAN,SAA2BX,KAA3B,CAAiC;AAAA,IAG7B7D,WAAA,CAAYyE,GAAZ,EAAyBC,OAAzB,EAA0C;AAAA,QACtC,KAAA,CAAMA,OAAN,CADsC,CAAA;AAAA,QAEtC,IAAKA,CAAAA,OAAL,GAAeA,OAAf,CAFsC;AAAA,QAGtC,IAAKD,CAAAA,GAAL,GAAWA,GAAX,CAHsC;AAAA,KAHb;AAAA,CAFjC;AAYA,qBAAA,YAAA;;ACJA;AAAA;AAAA;AAAA;AAAA;AAAA,MAAME,KAAN,CAAY;AAAA,IAGR3E,WAAA,CAAY4E,MAAZ,EAA4BC,QAAA,GAAwC,EAApE,EAAwE;AAAA,QACpE,IAAKD,CAAAA,MAAL,GAAcA,MAAd,CADoE;AAAA,QAEpE,IAAKC,CAAAA,QAAL,GAAgB,EAAhB,CAFoE;AAAA,QAGpE,KAAA,MAAW,CAACC,IAAD,EAAOpC,UAAP,CAAX,IAAiCmC,QAAjC,EAA2C;AAAA,YACvC,KAAKA,QAAL,CAAcC,IAAd,CAAA,GAAsBpC,UAAtB,CADuC;AAAA,SAHyB;AAAA,KAHhE;AAAA,IAWRqC,MAAA,CAAOF,QAAP,EAAqD;AAAA,QACjD,OAAO,IAAIF,KAAJ,CAAU,IAAV,EAAgBE,QAAhB,CAAP,CADiD;AAAA,KAX7C;AAAA,IAeRzC,GAAA,CAAI0C,IAAJ,EAA8B;AAAA,QAC1B,IAAI,IAAKD,CAAAA,QAAL,CAAcC,IAAd,CAAJ,EAAyB;AAAA,YAAE,OAAO,IAAKD,CAAAA,QAAL,CAAcC,IAAd,CAAP,CAAF;AAAA,SADC;AAAA,QAE1B,IAAI,IAAKF,CAAAA,MAAT,EAAiB;AAAA,YAAE,OAAO,KAAKA,MAAL,CAAYxC,GAAZ,CAAgB0C,IAAhB,CAAP,CAAF;AAAA,SAFS;AAAA,QAG1B,MAAM,IAAIjB,KAAJ,CAAU,CAAA,GAAGiB,IAAH,EAAQ,oBAAR,CAAV,CAAN,CAH0B;AAAA,KAftB;AAAA,IAqBRE,GAAA,CAAIF,IAAJ,EAA2B;AAAA,QACvB,IAAI,IAAA,CAAKD,QAAL,CAAcC,IAAd,CAAJ;AAAA,YAAyB,OAAO,IAAP,CADF;AAAA,QAEvB,OAAO,IAAA,CAAKF,MAAL,GAAc,IAAKA,CAAAA,MAAL,CAAYI,GAAZ,CAAgBF,IAAhB,CAAd,GAAsC,KAA7C,CAFuB;AAAA,KArBnB;AAAA,CARZ;AAmCA,cAAA,KAAA;;ACGA;AAAO,MAAMG,QAAA,GAAW,EAACC,IAAA,EAAM,MAAP,EAAjB,CAtCP;AAuCO,MAAMC,UAAA,GAAa,EAACD,IAAA,EAAM,QAAP,EAAnB,CAvCP;AAwCO,MAAME,UAAA,GAAa,EAACF,IAAA,EAAM,QAAP,EAAnB,CAxCP;AAyCO,MAAMG,WAAA,GAAc,EAACH,IAAA,EAAM,SAAP,EAApB,CAzCP;AA0CO,MAAMI,SAAA,GAAY,EAACJ,IAAA,EAAM,OAAP,EAAlB,CA1CP;AA2CO,MAAMK,UAAA,GAAa,EAACL,IAAA,EAAM,QAAP,EAAnB,CA3CP;AA4CO,MAAMM,SAAA,GAAY,EAACN,IAAA,EAAM,OAAP,EAAlB,CA5CP;AA6CO,MAAMO,SAAA,GAAY,EAACP,IAAA,EAAM,OAAP,EAAlB,CA7CP;AA8CO,MAAMQ,YAAA,GAAe,EAACR,IAAA,EAAM,UAAP,EAArB,CA9CP;AA+CO,MAAMS,aAAA,GAAgB,EAACT,IAAA,EAAM,WAAP,EAAtB,CA/CP;AAgDO,MAAMU,iBAAA,GAAoB,EAACV,IAAA,EAAM,eAAP,EAA1B,CAhDP;AAkDO,SAASW,OAAT,CAAeC,QAAf,EAA+BC,CAA/B,EAAsD;AAAA,IACzD,OAAO;AAAA,QACHb,IAAA,EAAM,OADH;AAAA,QAEHY,QAFG;AAAA,QAGHC,CAHG;AAAA,KAAP,CADyD;AAAA,CAlD7D;AA0DO,SAAStF,UAAT,CAAkB6B,IAAlB,EAAsC;AAAA,IACzC,IAAIA,IAAA,CAAK4C,IAAL,KAAc,OAAlB,EAA2B;AAAA,QACvB,MAAMY,QAAA,GAAWrF,UAAA,CAAS6B,IAAA,CAAKwD,QAAd,CAAjB,CADuB;AAAA,QAEvB,OAAO,OAAOxD,IAAA,CAAKyD,CAAZ,KAAkB,QAAlB,GACH,CAAC,MAAD,GAASD,QAAT,EAAkB,EAAlB,GAAsBxD,IAAA,CAAKyD,CAA3B,EAA6B,CAA7B,CADG,GAEHzD,IAAA,CAAKwD,QAAL,CAAcZ,IAAd,KAAuB,OAAvB,GAAiC,OAAjC,GAA2C,CAAC,MAAD,GAASY,QAAT,EAAkB,CAAlB,CAF/C,CAFuB;AAAA,KAA3B,MAKO;AAAA,QACH,OAAOxD,IAAA,CAAK4C,IAAZ,CADG;AAAA,KANkC;AAAA,CA1D7C;AAqEA,MAAMc,gBAAA,GAAmB;AAAA,IACrBf,QADqB;AAAA,IAErBE,UAFqB;AAAA,IAGrBC,UAHqB;AAAA,IAIrBC,WAJqB;AAAA,IAKrBC,SALqB;AAAA,IAMrBK,aANqB;AAAA,IAOrBJ,UAPqB;AAAA,IAQrBM,OAAA,CAAML,SAAN,CARqB;AAAA,IASrBI,iBATqB;AAAA,CAAzB,CArEA;AAsFA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASK,YAAT,CAAsBC,QAAtB,EAAsCC,CAAtC,EAAwD;AAAA,IAC3D,IAAIA,CAAA,CAAEjB,IAAF,KAAW,OAAf,EAAwB;AAAA;AAEpB,QAAA,OAAO,IAAP,CAFoB;AAAA,KAAxB,MAGO,IAAIgB,QAAA,CAAShB,IAAT,KAAkB,OAAtB,EAA+B;AAAA,QAClC,IAAIiB,CAAA,CAAEjB,IAAF,KAAW,OAAX,KACEiB,CAAA,CAAEJ,CAAF,KAAQ,CAAR,IAAaI,CAAA,CAAEL,QAAF,CAAWZ,IAAX,KAAoB,OAAlC,IAA8C,CAACe,YAAA,CAAaC,QAAA,CAASJ,QAAtB,EAAgCK,CAAA,CAAEL,QAAlC,CAA/C,CADD,KAEC,OAAOI,QAAA,CAASH,CAAhB,KAAsB,QAAtB,IAAkCG,QAAA,CAASH,CAAT,KAAeI,CAAA,CAAEJ,CAAnD,CAFL,EAE4D;AAAA,YACxD,OAAO,IAAP,CADwD;AAAA,SAH1B;AAAA,KAA/B,MAMA,IAAIG,QAAA,CAAShB,IAAT,KAAkBiB,CAAA,CAAEjB,IAAxB,EAA8B;AAAA,QACjC,OAAO,IAAP,CADiC;AAAA,KAA9B,MAEA,IAAIgB,QAAA,CAAShB,IAAT,KAAkB,OAAtB,EAA+B;AAAA,QAClC,KAAWkB,MAAAA,UAAX,IAAyBJ,gBAAzB,EAA2C;AAAA,YACvC,IAAI,CAACC,YAAA,CAAaG,UAAb,EAAyBD,CAAzB,CAAL,EAAkC;AAAA,gBAC9B,OAAO,IAAP,CAD8B;AAAA,aADK;AAAA,SADT;AAAA,KAZqB;AAAA,IAoB3D,OAAO,CAAC,SAAD,GAAY1F,UAAA,CAASyF,QAAT,CAAZ,EAA+B,WAA/B,GAA4CzF,UAAA,CAAS0F,CAAT,CAA5C,EAAwD,SAAxD,CAAP,CApB2D;AAAA,CAtF/D;AA6GO,SAASE,WAAT,CAAqBC,QAArB,EAAqCC,YAArC,EAAyE;AAAA,IAC5E,OAAOA,YAAA,CAAaC,IAAb,CAAkBL,CAAA,IAAKA,CAAA,CAAEjB,IAAF,KAAWoB,QAAA,CAASpB,IAA3C,CAAP,CAD4E;AAAA,CA7GhF;AAiHO,SAASuB,iBAAT,CAA2BH,QAA3B,EAA0CC,YAA1C,EAAoF;AAAA,IACvF,OAAOA,YAAA,CAAaC,IAAb,CAAkBL,CAAA,IAAK;AAAA,QAC1B,IAAIA,CAAA,KAAM,MAAV,EAAkB;AAAA,YACd,OAAOG,QAAA,KAAa,IAApB,CADc;AAAA,SAAlB,MAEO,IAAIH,CAAA,KAAM,OAAV,EAAmB;AAAA,YACtB,OAAOO,KAAA,CAAMC,OAAN,CAAcL,QAAd,CAAP,CADsB;AAAA,SAAnB,MAEA,IAAIH,CAAA,KAAM,QAAV,EAAoB;AAAA,YACvB,OAAOG,QAAA,IAAY,CAACI,KAAA,CAAMC,OAAN,CAAcL,QAAd,CAAb,IAAwC,OAAOA,QAAP,KAAoB,QAAnE,CADuB;AAAA,SAApB,MAEA;AAAA,YACH,OAAOH,CAAA,KAAM,OAAOG,QAApB,CADG;AAAA,SAPmB;AAAA,KAAvB,CAAP,CADuF;AAAA;;AC/E3F;AAAA;AAAA;AAAe,MAAMM,QAAN,CAAe;AAAA,IAK1B5G,WAAA,CAAY6G,aAAZ,EAAoCC,kBAApC,EAAiEC,MAAjE,EAAwF;AAAA,QACpF,IAAIF,aAAJ;AAAA,YACI,IAAA,CAAKG,WAAL,GAAmBF,kBAAA,GAAqB,SAArB,GAAiC,MAApD,CADJ;AAAA;AAAA,YAGI,IAAA,CAAKE,WAAL,GAAmBF,kBAAA,GAAqB,QAArB,GAAgC,MAAnD,CAJgF;AAAA,QAMpF,IAAKC,CAAAA,MAAL,GAAcA,MAAd,CANoF;AAAA,QAOpF,IAAKE,CAAAA,QAAL,GAAgB,IAAIC,IAAA,CAAKN,QAAT,CAAkB,IAAA,CAAKG,MAAL,GAAc,IAAA,CAAKA,MAAnB,GAA4B,EAA9C,EACZ;AAAA,YAACC,WAAA,EAAa,IAAA,CAAKA,WAAnB;AAAA,YAAgCG,KAAA,EAAO,QAAvC;AAAA,SADY,CAAhB,CAPoF;AAAA,KAL9D;AAAA,IAgB1BC,OAAA,CAAQC,GAAR,EAAqBC,GAArB,EAA0C;AAAA,QACtC,OAAO,IAAKL,CAAAA,QAAL,CAAcG,OAAd,CAAsBC,GAAtB,EAA2BC,GAA3B,CAAP,CADsC;AAAA,KAhBhB;AAAA,IAoB1BC,cAAA,GAAyB;AAAA;AAGrB;AAAA,QAAA,OAAO,IAAIL,IAAA,CAAKN,QAAT,CAAkB,KAAKG,MAAL,GAAc,IAAKA,CAAAA,MAAnB,GAA4B,EAA9C,CAAA,CACFS,eADE,EAAA,CACgBT,MADvB,CAHqB;AAAA,KApBC;AAAA;;AC9B9B;AAAO,MAAMU,gBAAN,CAAuB;AAAA,IAO1BzH,WAAA,CAAY0H,IAAZ,EAA0BC,KAA1B,EAAuDC,KAAvD,EAA6EC,SAA7E,EAAuGC,SAAvG,EAAgI;AAAA;AAE5H,QAAA,IAAA,CAAKJ,IAAL,GAAYA,IAAA,CAAKK,SAAL,GAAiBL,IAAA,CAAKK,SAAL,EAAjB,GAAoCL,IAAhD,CAF4H;AAAA,QAG5H,IAAKC,CAAAA,KAAL,GAAaA,KAAb,CAH4H;AAAA,QAI5H,IAAKC,CAAAA,KAAL,GAAaA,KAAb,CAJ4H;AAAA,QAK5H,IAAKC,CAAAA,SAAL,GAAiBA,SAAjB,CAL4H;AAAA,QAM5H,IAAKC,CAAAA,SAAL,GAAiBA,SAAjB,CAN4H;AAAA,KAPtG;AAAA,CAJ9B;AAqBe,MAAME,SAAN,CAAgB;AAAA,IAG3BhI,WAAA,CAAYiI,QAAZ,EAA+C;AAAA,QAC3C,IAAKA,CAAAA,QAAL,GAAgBA,QAAhB,CAD2C;AAAA,KAHpB;AAAA,IAO3B,OAAOC,UAAP,CAAkBC,WAAlB,EAAkD;AAAA,QAC9C,OAAO,IAAIH,SAAJ,CAAc,CAAC,IAAIP,gBAAJ,CAAqBU,WAArB,EAAkC,IAAlC,EAAwC,IAAxC,EAA8C,IAA9C,EAAoD,IAApD,CAAD,CAAd,CAAP,CAD8C;AAAA,KAPvB;AAAA,IAW3BC,OAAA,GAAmB;AAAA,QACf,IAAI,IAAKH,CAAAA,QAAL,CAAc7J,MAAd,KAAyB,CAA7B;AAAA,YAAgC,OAAO,IAAP,CADjB;AAAA,QAEf,OAAO,CAAC,IAAK6J,CAAAA,QAAL,CAAczB,IAAd,CAAmB6B,OAAA,IAAWA,OAAA,CAAQX,IAAR,CAAatJ,MAAb,KAAwB,CAAxB,IACAiK,OAAA,CAAQV,KAAR,IAAiBU,OAAA,CAAQV,KAAR,CAAc7C,IAAd,CAAmB1G,MAAnB,KAA8B,CAD7E,CAAR,CAFe;AAAA,KAXQ;AAAA,IAiB3B,OAAOkK,OAAP,CAAeZ,IAAf,EAAoD;AAAA,QAChD,IAAIA,IAAA,YAAgBM,SAApB,EAA+B;AAAA,YAC3B,OAAON,IAAP,CAD2B;AAAA,SAA/B,MAEO;AAAA,YACH,OAAOM,SAAA,CAAUE,UAAV,CAAqBR,IAArB,CAAP,CADG;AAAA,SAHyC;AAAA,KAjBzB;AAAA,IAyB3BjH,QAAA,GAAmB;AAAA,QACf,IAAI,IAAKwH,CAAAA,QAAL,CAAc7J,MAAd,KAAyB,CAA7B;AAAA,YAAgC,OAAO,EAAP,CADjB;AAAA,QAEf,OAAO,IAAK6J,CAAAA,QAAL,CAAcpG,GAAd,CAAkBwG,OAAA,IAAWA,OAAA,CAAQX,IAArC,CAA2Ca,CAAAA,IAA3C,CAAgD,EAAhD,CAAP,CAFe;AAAA,KAzBQ;AAAA,IA8B3BC,SAAA,GAA0B;AAAA,QACtB,MAAMC,UAAA,GAA2B,CAAC,QAAD,CAAjC,CADsB;AAAA,QAEtB,KAAWJ,MAAAA,OAAX,IAAsB,IAAA,CAAKJ,QAA3B,EAAqC;AAAA,YACjC,IAAII,OAAA,CAAQV,KAAZ,EAAmB;AAAA,gBACfc,UAAA,CAAWvF,IAAX,CAAgB;AAAA,oBAAC,OAAD;AAAA,oBAAUmF,OAAA,CAAQV,KAAR,CAAc7C,IAAxB;AAAA,iBAAhB,CADe,CAAA;AAAA,gBAEf,SAFe;AAAA,aADc;AAAA,YAKjC2D,UAAA,CAAWvF,IAAX,CAAgBmF,OAAA,CAAQX,IAAxB,CALiC,CAAA;AAAA,YAMjC,MAAMgB,OAAA,GAAoC,EAA1C,CANiC;AAAA,YAOjC,IAAIL,OAAA,CAAQR,SAAZ,EAAuB;AAAA,gBACnBa,OAAA,CAAQ,WAAR,CAAuB,GAAA;AAAA,oBAAC,SAAD;AAAA,oBAAYL,OAAA,CAAQR,SAAR,CAAkBrI,KAAlB,CAAwB,GAAxB,CAAZ;AAAA,iBAAvB,CADmB;AAAA,aAPU;AAAA,YAUjC,IAAI6I,OAAA,CAAQT,KAAZ,EAAmB;AAAA,gBACfc,OAAA,CAAQ,YAAR,IAAwBL,OAAA,CAAQT,KAAhC,CADe;AAAA,aAVc;AAAA,YAajC,IAAIS,OAAA,CAAQP,SAAZ,EAAuB;AAAA,gBACnBY,OAAA,CAAQ,YAAR,CAAyB,GAAA,CAAC,MAAD,CAAD,CAAyB3D,MAAzB,CAAgCsD,OAAA,CAAQP,SAAR,CAAkBpH,OAAlB,EAAhC,CAAxB,CADmB;AAAA,aAbU;AAAA,YAgBjC+H,UAAA,CAAWvF,IAAX,CAAgBwF,OAAhB,CAhBiC,CAAA;AAAA,SAFf;AAAA,QAoBtB,OAAOD,UAAP,CApBsB;AAAA,KA9BC;AAAA;;ACd/B;AAAe,MAAME,aAAN,CAAoB;AAAA,IAI/B3I,WAAA,CAAY0I,OAAZ,EAA2C;AAAA,QACvC,KAAK5D,IAAL,GAAY4D,OAAA,CAAQ5D,IAApB,CADuC;AAAA,QAEvC,KAAK8D,SAAL,GAAiBF,OAAA,CAAQE,SAAzB,CAFuC;AAAA,KAJZ;AAAA,IAS/BnI,QAAA,GAAmB;AAAA,QACf,OAAO,IAAKqE,CAAAA,IAAZ,CADe;AAAA,KATY;AAAA,IAa/B,OAAOoD,UAAP,CAAkBpD,IAAlB,EAAsD;AAAA,QAClD,IAAI,CAACA,IAAL;AAAA,YAAW,OAAO,IAAP,CADuC;AAAA;AAElD,QAAO,OAAA,IAAI6D,aAAJ,CAAkB;AAAA,YAAC7D,IAAD;AAAA,YAAO8D,SAAA,EAAW,KAAlB;AAAA,SAAlB,CAAP,CAFkD;AAAA,KAbvB;AAAA,IAkB/BJ,SAAA,GAA2B;AAAA,QACvB,OAAO;AAAA,YAAC,OAAD;AAAA,YAAU,KAAK1D,IAAf;AAAA,SAAP,CADuB;AAAA,KAlBI;AAAA;;ACK5B,SAAS+D,YAAT,CAAsB5I,CAAtB,EAAgCC,CAAhC,EAA0CC,CAA1C,EAAoDC,CAApD,EAA8E;AAAA,IACjF,IAAI,EACA,OAAOH,CAAP,KAAa,QAAb,IAAyBA,CAAA,IAAK,CAA9B,IAAmCA,CAAA,IAAK,GAAxC,IACA,OAAOC,CAAP,KAAa,QADb,IACyBA,CAAA,IAAK,CAD9B,IACmCA,CAAA,IAAK,GADxC,IAEA,OAAOC,CAAP,KAAa,QAFb,IAEyBA,CAAA,IAAK,CAF9B,IAEmCA,CAAA,IAAK,GAFxC,CADJ,EAIG;AAAA,QACC,MAAMgB,KAAA,GAAQ,OAAOf,CAAP,KAAa,QAAb,GAAwB;AAAA,YAACH,CAAD;AAAA,YAAIC,CAAJ;AAAA,YAAOC,CAAP;AAAA,YAAUC,CAAV;AAAA,SAAxB,GAAuC;AAAA,YAACH,CAAD;AAAA,YAAIC,CAAJ;AAAA,YAAOC,CAAP;AAAA,SAArD,CADD;AAAA,QAEC,OAAO,CAAC,oBAAD,GAAuBgB,KAAA,CAAMoH,IAAN,CAAW,IAAX,CAAvB,EAAwC,+CAAxC,CAAP,CAFD;AAAA,KAL8E;AAAA,IAUjF,IAAI,EACOnI,OAAAA,CAAP,KAAa,WAAb,IAA6B,OAAOA,CAAP,KAAa,QAAb,IAAyBA,CAAA,IAAK,CAA9B,IAAmCA,CAAA,IAAK,CAArE,CADJ,EAEG;AAAA,QACC,OAAO,CAAC,oBAAD,GAAuB;AAAA,YAACH,CAAD;AAAA,YAAIC,CAAJ;AAAA,YAAOC,CAAP;AAAA,YAAUC,CAAV;AAAA,SAAA,CAAamI,IAAb,CAAkB,IAAlB,CAAvB,EAA+C,+BAA/C,CAAP,CADD;AAAA,KAZ8E;AAAA,IAgBjF,OAAO,IAAP,CAhBiF;AAAA,CAZrF;AAiCO,SAASO,OAAT,CAAiBC,KAAjB,EAAwC;AAAA,IAC3C,IAAIA,KAAA,KAAU,IAAd,EAAoB;AAAA,QAChB,OAAO,IAAP,CADgB;AAAA,KAApB,MAEO,IAAI,OAAOA,KAAP,KAAiB,QAArB,EAA+B;AAAA,QAClC,OAAO,IAAP,CADkC;AAAA,KAA/B,MAEA,IAAI,OAAOA,KAAP,KAAiB,SAArB,EAAgC;AAAA,QACnC,OAAO,IAAP,CADmC;AAAA,KAAhC,MAEA,IAAI,OAAOA,KAAP,KAAiB,QAArB,EAA+B;AAAA,QAClC,OAAO,IAAP,CADkC;AAAA,KAA/B,MAEA,IAAIA,KAAA,YAAiBhJ,OAArB,EAA4B;AAAA,QAC/B,OAAO,IAAP,CAD+B;AAAA,KAA5B,MAEA,IAAIgJ,KAAA,YAAiBnC,QAArB,EAA+B;AAAA,QAClC,OAAO,IAAP,CADkC;AAAA,KAA/B,MAEA,IAAImC,KAAA,YAAiBf,SAArB,EAAgC;AAAA,QACnC,OAAO,IAAP,CADmC;AAAA,KAAhC,MAEA,IAAIe,KAAA,YAAiBJ,aAArB,EAAoC;AAAA,QACvC,OAAO,IAAP,CADuC;AAAA,KAApC,MAEA,IAAIjC,KAAA,CAAMC,OAAN,CAAcoC,KAAd,CAAJ,EAA0B;AAAA,QAC7B,KAAWC,MAAAA,IAAX,IAAmBD,KAAnB,EAA0B;AAAA,YACtB,IAAI,CAACD,OAAA,CAAQE,IAAR,CAAL,EAAoB;AAAA,gBAChB,OAAO,KAAP,CADgB;AAAA,aADE;AAAA,SADG;AAAA,QAM7B,OAAO,IAAP,CAN6B;AAAA,KAA1B,MAOA,IAAI,OAAOD,KAAP,KAAiB,QAArB,EAA+B;AAAA,QAClC,KAAWtE,MAAAA,GAAX,IAAkBsE,KAAlB,EAAyB;AAAA,YACrB,IAAI,CAACD,OAAA,CAAQC,KAAA,CAAMtE,GAAN,CAAR,CAAL,EAA0B;AAAA,gBACtB,OAAO,KAAP,CADsB;AAAA,aADL;AAAA,SADS;AAAA,QAMlC,OAAO,IAAP,CANkC;AAAA,KAA/B,MAOA;AAAA,QACH,OAAO,KAAP,CADG;AAAA,KA/BoC;AAAA,CAjC/C;AAqEO,SAASwE,MAAT,CAAgB9H,KAAhB,EAAoC;AAAA,IACvC,IAAIA,KAAA,KAAU,IAAd,EAAoB;AAAA,QAChB,OAAO8D,QAAP,CADgB;AAAA,KAApB,MAEO,IAAI,OAAO9D,KAAP,KAAiB,QAArB,EAA+B;AAAA,QAClC,OAAOiE,UAAP,CADkC;AAAA,KAA/B,MAEA,IAAI,OAAOjE,KAAP,KAAiB,SAArB,EAAgC;AAAA,QACnC,OAAOkE,WAAP,CADmC;AAAA,KAAhC,MAEA,IAAI,OAAOlE,KAAP,KAAiB,QAArB,EAA+B;AAAA,QAClC,OAAOgE,UAAP,CADkC;AAAA,KAA/B,MAEA,IAAIhE,KAAA,YAAiBpB,OAArB,EAA4B;AAAA,QAC/B,OAAOuF,SAAP,CAD+B;AAAA,KAA5B,MAEA,IAAInE,KAAA,YAAiByF,QAArB,EAA+B;AAAA,QAClC,OAAOlB,YAAP,CADkC;AAAA,KAA/B,MAEA,IAAIvE,KAAA,YAAiB6G,SAArB,EAAgC;AAAA,QACnC,OAAOrC,aAAP,CADmC;AAAA,KAAhC,MAEA,IAAIxE,KAAA,YAAiBwH,aAArB,EAAoC;AAAA,QACvC,OAAO/C,iBAAP,CADuC;AAAA,KAApC,MAEA,IAAIc,KAAA,CAAMC,OAAN,CAAcxF,KAAd,CAAJ,EAA0B;AAAA,QAC7B,MAAM/C,MAAA,GAAS+C,KAAA,CAAM/C,MAArB,CAD6B;AAAA,QAE7B,IAAI0H,QAAJ,CAF6B;AAAA,QAI7B,KAAWkD,MAAAA,IAAX,IAAmB7H,KAAnB,EAA0B;AAAA,YACtB,MAAMgF,CAAA,GAAI8C,MAAA,CAAOD,IAAP,CAAV,CADsB;AAAA,YAEtB,IAAI,CAAClD,QAAL,EAAe;AAAA,gBACXA,QAAA,GAAWK,CAAX,CADW;AAAA,aAAf,MAEO,IAAIL,QAAA,KAAaK,CAAjB,EAAoB;AAAA,gBACvB,SADuB;AAAA,aAApB,MAEA;AAAA,gBACHL,QAAA,GAAWN,SAAX,CADG;AAAA,gBAEH,MAFG;AAAA,aANe;AAAA,SAJG;AAAA,QAgB7B,OAAOK,OAAA,CAAMC,QAAA,IAAYN,SAAlB,EAA6BpH,MAA7B,CAAP,CAhB6B;AAAA,KAA1B,MAiBA;AAAA,QAEH,OAAOmH,UAAP,CAFG;AAAA,KAlCgC;AAAA,CArE3C;AA6GO,SAAS9E,QAAT,CAAkBU,KAAlB,EAAwC;AAAA,IAC3C,MAAMmB,IAAA,GAAO,OAAOnB,KAApB,CAD2C;AAAA,IAE3C,IAAIA,KAAA,KAAU,IAAd,EAAoB;AAAA,QAChB,OAAO,EAAP,CADgB;AAAA,KAApB,MAEO,IAAImB,IAAA,KAAS,QAAT,IAAqBA,IAAA,KAAS,QAA9B,IAA0CA,IAAA,KAAS,SAAvD,EAAkE;AAAA,QACrE,OAAO4G,MAAA,CAAO/H,KAAP,CAAP,CADqE;AAAA,KAAlE,MAEA,IAAIA,KAAA,YAAiBpB,OAAjB,IAA0BoB,KAAA,YAAiB6G,SAA3C,IAAwD7G,KAAA,YAAiBwH,aAA7E,EAA4F;AAAA,QAC/F,OAAOxH,KAAA,CAAMV,QAAN,EAAP,CAD+F;AAAA,KAA5F,MAEA;AAAA,QACH,OAAO0I,IAAA,CAAKC,SAAL,CAAejI,KAAf,CAAP,CADG;AAAA,KARoC;AAAA;;AClG/C,MAAMkI,OAAN,CAAoC;AAAA,IAIhCrJ,WAAA,CAAYsC,IAAZ,EAAwBnB,KAAxB,EAAsC;AAAA,QAClC,IAAKmB,CAAAA,IAAL,GAAYA,IAAZ,CADkC;AAAA,QAElC,IAAKnB,CAAAA,KAAL,GAAaA,KAAb,CAFkC;AAAA,KAJN;AAAA,IAShC,OAAOd,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAAmF;AAAA,QAC/E,IAAID,IAAA,CAAKlL,MAAL,KAAgB,CAApB;AAAA,YACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,8DAAD,GAAiEF,IAAA,CAAKlL,MAAL,GAAc,CAA/E,EAAiF,SAAjF,CAAd,CAAP,CAF2E;AAAA,QAI/E,IAAI,CAAC0K,OAAA,CAAQQ,IAAA,CAAK,CAAL,CAAR,CAAL;AAAA,YACI,OAAOC,OAAA,CAAQC,KAAR,CAAc,CAAC,aAAD,CAAd,CAAP,CAL2E;AAAA,QAO/E,MAAMrI,KAAA,GAASmI,IAAA,CAAK,CAAL,CAAf,CAP+E;AAAA,QAQ/E,IAAIhH,IAAA,GAAO2G,MAAA,CAAO9H,KAAP,CAAX,CAR+E;AAAA;AAW/E,QAAA,MAAM+E,QAAA,GAAWqD,OAAA,CAAQE,YAAzB,CAX+E;AAAA,QAY/E,IACInH,IAAA,CAAK4C,IAAL,KAAc,OAAd,IACA5C,IAAA,CAAKyD,CAAL,KAAW,CADX,IAEAG,QAFA,IAGAA,QAAA,CAAShB,IAAT,KAAkB,OAHlB,KAIQgB,OAAAA,QAAA,CAASH,CAAhB,KAAsB,QAAtB,IAAkCG,QAAA,CAASH,CAAT,KAAe,CAAjD,CALL,EAME;AAAA,YACEzD,IAAA,GAAO4D,QAAP,CADF;AAAA,SAlB6E;AAAA,QAsB/E,OAAO,IAAImD,OAAJ,CAAY/G,IAAZ,EAAkBnB,KAAlB,CAAP,CAtB+E;AAAA,KATnD;AAAA,IAkChCuI,QAAA,GAAkB;AAAA,QACd,OAAO,IAAKvI,CAAAA,KAAZ,CADc;AAAA,KAlCc;AAAA,IAsChCwI,SAAA,GAAY;AAAA,KAtCoB;AAAA,IAwChCC,aAAA,GAAyB;AAAA,QACrB,OAAO,IAAP,CADqB;AAAA,KAxCO;AAAA,IA4ChCpB,SAAA,GAAkC;AAAA,QAC9B,IAAI,IAAA,CAAKlG,IAAL,CAAU4C,IAAV,KAAmB,OAAnB,IAA8B,IAAA,CAAK5C,IAAL,CAAU4C,IAAV,KAAmB,QAArD,EAA+D;AAAA,YAC3D,OAAO;AAAA,gBAAC,SAAD;AAAA,gBAAY,KAAK/D,KAAjB;AAAA,aAAP,CAD2D;AAAA,SAA/D,MAEO,IAAI,IAAA,CAAKA,KAAL,YAAsBpB,OAA1B,EAAiC;AAAA;AAIpC;AAAA;AAAA,YAAO,OAAA,CAAC,MAAD,CAAA,CAASgF,MAAT,CAAgB,IAAK5D,CAAAA,KAAL,CAAWT,OAAX,EAAhB,CAAP,CAJoC;AAAA,SAAjC,MAKA,IAAI,IAAA,CAAKS,KAAL,YAAsB6G,SAA1B,EAAqC;AAAA;AAExC,YAAA,OAAO,IAAK7G,CAAAA,KAAL,CAAWqH,SAAX,EAAP,CAFwC;AAAA,SAArC,MAGA;AAAA,YAKH,OAAQ,IAAKrH,CAAAA,KAAb,CALG;AAAA,SAXuB;AAAA,KA5CF;AAAA,CAXpC;AA4EA,gBAAA,OAAA;;AC1EA;AAAA,MAAM0I,YAAN,CAAmB;AAAA,IAIf7J,WAAA,CAAY0E,OAAZ,EAA6B;AAAA,QACzB,IAAKI,CAAAA,IAAL,GAAY,2BAAZ,CADyB;AAAA,QAEzB,IAAKJ,CAAAA,OAAL,GAAeA,OAAf,CAFyB;AAAA,KAJd;AAAA,IASfoF,MAAA,GAAiB;AAAA,QACb,OAAO,IAAKpF,CAAAA,OAAZ,CADa;AAAA,KATF;AAAA,CAFnB;AAgBA,qBAAA,YAAA;;ACMA,MAAMqF,OAAA,GAAQ;AAAA,IACVC,MAAA,EAAQ5E,UADE;AAAA,IAEV6E,MAAA,EAAQ9E,UAFE;AAAA,IAGV+E,OAAA,EAAS7E,WAHC;AAAA,IAIV8E,MAAA,EAAQ5E,UAJE;AAAA,CAAd,CAtBA;AA6BA,MAAM6E,SAAN,CAAsC;AAAA,IAIlCpK,WAAA,CAAYsC,IAAZ,EAAwBgH,IAAxB,EAAiD;AAAA,QAC7C,IAAKhH,CAAAA,IAAL,GAAYA,IAAZ,CAD6C;AAAA,QAE7C,IAAKgH,CAAAA,IAAL,GAAYA,IAAZ,CAF6C;AAAA,KAJf;AAAA,IASlC,OAAOjJ,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAAgF;AAAA,QAC5E,IAAID,IAAA,CAAKlL,MAAL,GAAc,CAAlB;AAAA,YACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,+BAAD,CAAd,CAAP,CAFwE;AAAA,QAI5E,IAAI3L,CAAA,GAAI,CAAR,CAJ4E;AAAA,QAK5E,IAAIyE,IAAJ,CAL4E;AAAA,QAO5E,MAAMwC,IAAA,GAAgBwE,IAAA,CAAK,CAAL,CAAtB,CAP4E;AAAA,QAQ5E,IAAIxE,IAAA,KAAS,OAAb,EAAsB;AAAA,YAClB,IAAIgB,QAAJ,CADkB;AAAA,YAElB,IAAIwD,IAAA,CAAKlL,MAAL,GAAc,CAAlB,EAAqB;AAAA,gBACjB,MAAMkE,IAAA,GAAOgH,IAAA,CAAK,CAAL,CAAb,CADiB;AAAA,gBAEjB,IAAI,OAAOhH,IAAP,KAAgB,QAAhB,IAA4B,EAAEA,IAAA,IAAQyH,OAAR,CAA9B,IAAgDzH,IAAA,KAAS,QAA7D;AAAA,oBACI,OAAOiH,OAAA,CAAQC,KAAR,CAAc,0EAAd,EAA0F,CAA1F,CAAP,CAHa;AAAA,gBAIjB1D,QAAA,GAAWiE,OAAA,CAAMzH,IAAN,CAAX,CAJiB;AAAA,gBAKjBzE,CAAA,EALiB,CAAA;AAAA,aAArB,MAMO;AAAA,gBACHiI,QAAA,GAAWN,SAAX,CADG;AAAA,aARW;AAAA,YAYlB,IAAIO,CAAJ,CAZkB;AAAA,YAalB,IAAIuD,IAAA,CAAKlL,MAAL,GAAc,CAAlB,EAAqB;AAAA,gBACjB,IAAIkL,IAAA,CAAK,CAAL,MAAY,IAAZ,KACQA,OAAAA,IAAA,CAAK,CAAL,CAAP,KAAmB,QAAnB,IACGA,IAAA,CAAK,CAAL,CAAA,GAAU,CADb,IAEGA,IAAA,CAAK,CAAL,MAAYxL,IAAA,CAAKuM,KAAL,CAAWf,IAAA,CAAK,CAAL,CAAX,CAFf,CADL,EAIE;AAAA,oBACE,OAAOC,OAAA,CAAQC,KAAR,CAAc,mEAAd,EAAmF,CAAnF,CAAP,CADF;AAAA,iBALe;AAAA,gBAQjBzD,CAAA,GAAIuD,IAAA,CAAK,CAAL,CAAJ,CARiB;AAAA,gBASjBzL,CAAA,EATiB,CAAA;AAAA,aAbH;AAAA,YAyBlByE,IAAA,GAAOuD,OAAA,CAAMC,QAAN,EAAgBC,CAAhB,CAAP,CAzBkB;AAAA,SAAtB,MA0BO;AAAA,YAEHzD,IAAA,GAAOyH,OAAA,CAAMjF,IAAN,CAAP,CAFG;AAAA,SAlCqE;AAAA,QAuC5E,MAAMwF,MAAA,GAAS,EAAf,CAvC4E;AAAA,QAwC5E,OAAOzM,CAAA,GAAIyL,IAAA,CAAKlL,MAAhB,EAAwBP,CAAA,EAAxB,EAA6B;AAAA,YACzB,MAAMyC,KAAA,GAAQiJ,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAKzL,CAAL,CAAd,EAAuBA,CAAvB,EAA0B2H,SAA1B,CAAd,CADyB;AAAA,YAEzB,IAAI,CAAClF,KAAL;AAAA,gBAAY,OAAO,IAAP,CAFa;AAAA,YAGzBgK,MAAA,CAAOpH,IAAP,CAAY5C,KAAZ,CAHyB,CAAA;AAAA,SAxC+C;AAAA,QA8C5E,OAAO,IAAI8J,SAAJ,CAAc9H,IAAd,EAAoBgI,MAApB,CAAP,CA9C4E;AAAA,KAT9C;AAAA,IA0DlCZ,QAAA,CAASa,GAAT,EAA6C;AAAA,QACzC,KAAK,IAAI1M,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAI,IAAA,CAAKyL,IAAL,CAAUlL,MAA9B,EAAsCP,CAAA,EAAtC,EAA2C;AAAA,YACvC,MAAMsD,KAAA,GAAQ,IAAA,CAAKmI,IAAL,CAAUzL,CAAV,CAAA,CAAa6L,QAAb,CAAsBa,GAAtB,CAAd,CADuC;AAAA,YAEvC,MAAMf,KAAA,GAAQvD,YAAA,CAAa,IAAA,CAAK3D,IAAlB,EAAwB2G,MAAA,CAAO9H,KAAP,CAAxB,CAAd,CAFuC;AAAA,YAGvC,IAAI,CAACqI,KAAL,EAAY;AAAA,gBACR,OAAOrI,KAAP,CADQ;AAAA,aAAZ,MAEO,IAAItD,CAAA,KAAM,IAAA,CAAKyL,IAAL,CAAUlL,MAAV,GAAmB,CAA7B,EAAgC;AAAA,gBACnC,MAAM,IAAIyL,cAAJ,CAAiB,CAAC,6BAAD,GAAgCpJ,UAAA,CAAS,IAAK6B,CAAAA,IAAd,CAAhC,EAAoD,YAApD,GAAkE7B,UAAA,CAASwI,MAAA,CAAO9H,KAAP,CAAT,CAAlE,EAA0F,SAA1F,CAAjB,CAAN,CADmC;AAAA,aALA;AAAA,SADF;AAAA,QAYzC,OAAO,IAAP,CAZyC;AAAA,KA1DX;AAAA,IAyElCwI,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnC,KAAKlB,IAAL,CAAUmB,OAAV,CAAkBD,EAAlB,CADmC,CAAA;AAAA,KAzEL;AAAA,IA6ElCZ,aAAA,GAAyB;AAAA,QACrB,OAAO,IAAA,CAAKN,IAAL,CAAUoB,KAAV,CAAgBC,GAAA,IAAOA,GAAA,CAAIf,aAAJ,EAAvB,CAAP,CADqB;AAAA,KA7ES;AAAA,IAiFlCpB,SAAA,GAAkC;AAAA,QAC9B,MAAMlG,IAAA,GAAO,IAAA,CAAKA,IAAlB,CAD8B;AAAA,QAE9B,MAAMmG,UAAA,GAAa,CAACnG,IAAA,CAAK4C,IAAN,CAAnB,CAF8B;AAAA,QAG9B,IAAI5C,IAAA,CAAK4C,IAAL,KAAc,OAAlB,EAA2B;AAAA,YACvB,MAAMY,QAAA,GAAWxD,IAAA,CAAKwD,QAAtB,CADuB;AAAA,YAEvB,IAAIA,QAAA,CAASZ,IAAT,KAAkB,QAAlB,IACAY,QAAA,CAASZ,IAAT,KAAkB,QADlB,IAEAY,QAAA,CAASZ,IAAT,KAAkB,SAFtB,EAEiC;AAAA,gBAC7BuD,UAAA,CAAWvF,IAAX,CAAgB4C,QAAA,CAASZ,IAAzB,CAD6B,CAAA;AAAA,gBAE7B,MAAMa,CAAA,GAAIzD,IAAA,CAAKyD,CAAf,CAF6B;AAAA,gBAG7B,IAAI,OAAOA,CAAP,KAAa,QAAb,IAAyB,IAAKuD,CAAAA,IAAL,CAAUlL,MAAV,GAAmB,CAAhD,EAAmD;AAAA,oBAC/CqK,UAAA,CAAWvF,IAAX,CAAgB6C,CAAhB,CAD+C,CAAA;AAAA,iBAHtB;AAAA,aAJV;AAAA,SAHG;AAAA,QAe9B,OAAO0C,UAAA,CAAW1D,MAAX,CAAkB,IAAA,CAAKuE,IAAL,CAAUzH,GAAV,CAAc8I,GAAA,IAAOA,GAAA,CAAInC,SAAJ,EAArB,CAAlB,CAAP,CAf8B;AAAA,KAjFA;AAAA,CA7BtC;AAiIA,kBAAA,SAAA;;AC/HA;AAkBe,MAAMoC,gBAAN,CAA6C;AAAA,IAIxD5K,WAAA,CAAYiI,QAAZ,EAAyD;AAAA,QACrD,IAAK3F,CAAAA,IAAL,GAAYqD,aAAZ,CADqD;AAAA,QAErD,IAAKsC,CAAAA,QAAL,GAAgBA,QAAhB,CAFqD;AAAA,KAJD;AAAA,IASxD,OAAO5H,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAAgF;AAAA,QAC5E,IAAID,IAAA,CAAKlL,MAAL,GAAc,CAAlB,EAAqB;AAAA,YACjB,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,+BAAD,CAAd,CAAP,CADiB;AAAA,SADuD;AAAA,QAK5E,MAAMqB,QAAA,GAAWvB,IAAA,CAAK,CAAL,CAAjB,CAL4E;AAAA,QAM5E,IAAI,CAAC5C,KAAA,CAAMC,OAAN,CAAckE,QAAd,CAAD,IAA4B,OAAOA,QAAP,KAAoB,QAApD,EAA+D;AAAA,YAC3D,OAAOtB,OAAA,CAAQC,KAAR,CAAc,CAAC,gDAAD,CAAd,CAAP,CAD2D;AAAA,SANa;AAAA,QAU5E,MAAMvB,QAAA,GAA8C,EAApD,CAV4E;AAAA,QAW5E,IAAI6C,oBAAA,GAAuB,KAA3B,CAX4E;AAAA,QAY5E,KAAK,IAAIjN,CAAA,GAAI,CAAR,EAAWA,CAAA,IAAKyL,IAAA,CAAKlL,MAAL,GAAc,CAAnC,EAAsC,EAAEP,CAAxC,EAA2C;AAAA,YACvC,MAAM8M,GAAA,GAAOrB,IAAA,CAAKzL,CAAL,CAAb,CADuC;AAAA,YAGvC,IAAIiN,oBAAA,IAAwB,OAAOH,GAAP,KAAe,QAAvC,IAAmD,CAACjE,KAAA,CAAMC,OAAN,CAAcgE,GAAd,CAAxD,EAA4E;AAAA,gBACxEG,oBAAA,GAAuB,KAAvB,CADwE;AAAA,gBAGxE,IAAIlD,KAAA,GAAQ,IAAZ,CAHwE;AAAA,gBAIxE,IAAI+C,GAAA,CAAI,YAAJ,CAAJ,EAAuB;AAAA,oBACnB/C,KAAA,GAAQ2B,OAAA,CAAQlJ,KAAR,CAAcsK,GAAA,CAAI,YAAJ,CAAd,EAAiC,CAAjC,EAAoCxF,UAApC,CAAR,CADmB;AAAA,oBAEnB,IAAI,CAACyC,KAAL;AAAA,wBAAY,OAAO,IAAP,CAFO;AAAA,iBAJiD;AAAA,gBASxE,IAAImD,IAAA,GAAO,IAAX,CATwE;AAAA,gBAUxE,IAAIJ,GAAA,CAAI,WAAJ,CAAJ,EAAsB;AAAA,oBAClBI,IAAA,GAAOxB,OAAA,CAAQlJ,KAAR,CAAcsK,GAAA,CAAI,WAAJ,CAAd,EAAgC,CAAhC,EAAmC9E,OAAA,CAAMT,UAAN,CAAnC,CAAP,CADkB;AAAA,oBAElB,IAAI,CAAC2F,IAAL;AAAA,wBAAW,OAAO,IAAP,CAFO;AAAA,iBAVkD;AAAA,gBAexE,IAAIjD,SAAA,GAAY,IAAhB,CAfwE;AAAA,gBAgBxE,IAAI6C,GAAA,CAAI,YAAJ,CAAJ,EAAuB;AAAA,oBACnB7C,SAAA,GAAYyB,OAAA,CAAQlJ,KAAR,CAAcsK,GAAA,CAAI,YAAJ,CAAd,EAAiC,CAAjC,EAAoCrF,SAApC,CAAZ,CADmB;AAAA,oBAEnB,IAAI,CAACwC,SAAL;AAAA,wBAAgB,OAAO,IAAP,CAFG;AAAA,iBAhBiD;AAAA,gBAqBxE,MAAMkD,cAAA,GAAiB/C,QAAA,CAASA,QAAA,CAAS7J,MAAT,GAAkB,CAA3B,CAAvB,CArBwE;AAAA,gBAsBxE4M,cAAA,CAAepD,KAAf,GAAuBA,KAAvB,CAtBwE;AAAA,gBAuBxEoD,cAAA,CAAeD,IAAf,GAAsBA,IAAtB,CAvBwE;AAAA,gBAwBxEC,cAAA,CAAelD,SAAf,GAA2BA,SAA3B,CAxBwE;AAAA,aAA5E,MAyBO;AAAA,gBACH,MAAMmD,OAAA,GAAU1B,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAKzL,CAAL,CAAd,EAAuB,CAAvB,EAA0B2H,SAA1B,CAAhB,CADG;AAAA,gBAEH,IAAI,CAACyF,OAAL;AAAA,oBAAc,OAAO,IAAP,CAFX;AAAA,gBAIH,MAAM/F,IAAA,GAAO+F,OAAA,CAAQ3I,IAAR,CAAa4C,IAA1B,CAJG;AAAA,gBAKH,IAAIA,IAAA,KAAS,QAAT,IAAqBA,IAAA,KAAS,OAA9B,IAAyCA,IAAA,KAAS,MAAlD,IAA4DA,IAAA,KAAS,eAAzE;AAAA,oBACI,OAAOqE,OAAA,CAAQC,KAAR,CAAc,CAAC,iEAAD,CAAd,CAAP,CAND;AAAA,gBAQHsB,oBAAA,GAAuB,IAAvB,CARG;AAAA,gBASH7C,QAAA,CAAS/E,IAAT,CAAc;AAAA,oBAAC+H,OAAD;AAAA,oBAAUrD,KAAA,EAAO,IAAjB;AAAA,oBAAuBmD,IAAA,EAAM,IAA7B;AAAA,oBAAmCjD,SAAA,EAAW,IAA9C;AAAA,iBAAd,CATG,CAAA;AAAA,aA5BgC;AAAA,SAZiC;AAAA,QAqD5E,OAAO,IAAI8C,gBAAJ,CAAqB3C,QAArB,CAAP,CArD4E;AAAA,KATxB;AAAA,IAiExDyB,QAAA,CAASa,GAAT,EAA4C;AAAA,QACxC,MAAMW,eAAA,GAAkB7C,OAAA,IAAW;AAAA,YAC/B,MAAM8C,gBAAA,GAAmB9C,OAAA,CAAQ4C,OAAR,CAAgBvB,QAAhB,CAAyBa,GAAzB,CAAzB,CAD+B;AAAA,YAE/B,IAAItB,MAAA,CAAOkC,gBAAP,CAAA,KAA6BvF,iBAAjC,EAAoD;AAAA,gBAChD,OAAO,IAAI6B,gBAAJ,CAAqB,EAArB,EAAyB0D,gBAAzB,EAA2C,IAA3C,EAAiD,IAAjD,EAAuD,IAAvD,CAAP,CADgD;AAAA,aAFrB;AAAA,YAM/B,OAAO,IAAI1D,gBAAJ,CACChH,QAAA,CAAS0K,gBAAT,CADD,EAEC,IAFD,EAGC9C,OAAA,CAAQT,KAAR,GAAgBS,OAAA,CAAQT,KAAR,CAAc8B,QAAd,CAAuBa,GAAvB,CAAhB,GAA8C,IAH/C,EAIClC,OAAA,CAAQ0C,IAAR,GAAe1C,OAAA,CAAQ0C,IAAR,CAAarB,QAAb,CAAsBa,GAAtB,CAAA,CAA2BhC,IAA3B,CAAgC,GAAhC,CAAf,GAAsD,IAJvD,EAKCF,OAAA,CAAQP,SAAR,GAAoBO,OAAA,CAAQP,SAAR,CAAkB4B,QAAlB,CAA2Ba,GAA3B,CAApB,GAAsD,IALvD,CAAP,CAN+B;AAAA,SAAnC,CADwC;AAAA,QAgBxC,OAAO,IAAIvC,SAAJ,CAAc,IAAKC,CAAAA,QAAL,CAAcpG,GAAd,CAAkBqJ,eAAlB,CAAd,CAAP,CAhBwC;AAAA,KAjEY;AAAA,IAoFxDvB,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnC,KAAWnC,MAAAA,OAAX,IAAsB,IAAA,CAAKJ,QAA3B,EAAqC;AAAA,YACjCuC,EAAA,CAAGnC,OAAA,CAAQ4C,OAAX,CADiC,CAAA;AAAA,YAEjC,IAAI5C,OAAA,CAAQT,KAAZ,EAAmB;AAAA,gBACf4C,EAAA,CAAGnC,OAAA,CAAQT,KAAX,CADe,CAAA;AAAA,aAFc;AAAA,YAKjC,IAAIS,OAAA,CAAQ0C,IAAZ,EAAkB;AAAA,gBACdP,EAAA,CAAGnC,OAAA,CAAQ0C,IAAX,CADc,CAAA;AAAA,aALe;AAAA,YAQjC,IAAI1C,OAAA,CAAQP,SAAZ,EAAuB;AAAA,gBACnB0C,EAAA,CAAGnC,OAAA,CAAQP,SAAX,CADmB,CAAA;AAAA,aARU;AAAA,SADF;AAAA,KApFiB;AAAA,IAmGxD8B,aAAA,GAAyB;AAAA;AAGrB;AAAA,QAAA,OAAO,KAAP,CAHqB;AAAA,KAnG+B;AAAA,IAyGxDpB,SAAA,GAAkC;AAAA,QAC9B,MAAMC,UAAA,GAAa,CAAC,QAAD,CAAnB,CAD8B;AAAA,QAE9B,KAAWJ,MAAAA,OAAX,IAAsB,IAAA,CAAKJ,QAA3B,EAAqC;AAAA,YACjCQ,UAAA,CAAWvF,IAAX,CAAgBmF,OAAA,CAAQ4C,OAAR,CAAgBzC,SAAhB,EAAhB,CADiC,CAAA;AAAA,YAEjC,MAAME,OAAA,GAAU,EAAhB,CAFiC;AAAA,YAGjC,IAAIL,OAAA,CAAQT,KAAZ,EAAmB;AAAA,gBACfc,OAAA,CAAQ,YAAR,CAAwBL,GAAAA,OAAA,CAAQT,KAAR,CAAcY,SAAd,EAAxB,CADe;AAAA,aAHc;AAAA,YAMjC,IAAIH,OAAA,CAAQ0C,IAAZ,EAAkB;AAAA,gBACdrC,OAAA,CAAQ,WAAR,CAAuBL,GAAAA,OAAA,CAAQ0C,IAAR,CAAavC,SAAb,EAAvB,CADc;AAAA,aANe;AAAA,YASjC,IAAIH,OAAA,CAAQP,SAAZ,EAAuB;AAAA,gBACnBY,OAAA,CAAQ,YAAR,CAAwBL,GAAAA,OAAA,CAAQP,SAAR,CAAkBU,SAAlB,EAAxB,CADmB;AAAA,aATU;AAAA,YAYjCC,UAAA,CAAWvF,IAAX,CAAgBwF,OAAhB,CAZiC,CAAA;AAAA,SAFP;AAAA,QAgB9B,OAAOD,UAAP,CAhB8B;AAAA,KAzGsB;AAAA;;AClB5D;AAQe,MAAM2C,eAAN,CAA4C;AAAA,IAIvDpL,WAAA,CAAYM,KAAZ,EAA+B;AAAA,QAC3B,IAAKgC,CAAAA,IAAL,GAAYsD,iBAAZ,CAD2B;AAAA,QAE3B,IAAKtF,CAAAA,KAAL,GAAaA,KAAb,CAF2B;AAAA,KAJwB;AAAA,IASvD,OAAOD,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAAgF;AAAA,QAC5E,IAAID,IAAA,CAAKlL,MAAL,KAAgB,CAApB,EAAuB;AAAA,YACnB,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,uBAAD,CAAd,CAAP,CADmB;AAAA,SADqD;AAAA,QAK5E,MAAM1E,IAAA,GAAOyE,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0BlE,UAA1B,CAAb,CAL4E;AAAA,QAM5E,IAAI,CAACN,IAAL;AAAA,YAAW,OAAOyE,OAAA,CAAQC,KAAR,CAAc,CAAC,uBAAD,CAAd,CAAP,CANiE;AAAA,QAQ5E,OAAO,IAAI4B,eAAJ,CAAoBtG,IAApB,CAAP,CAR4E;AAAA,KATzB;AAAA,IAoBvD4E,QAAA,CAASa,GAAT,EAAuD;AAAA,QACnD,MAAMc,kBAAA,GAAqB,IAAK/K,CAAAA,KAAL,CAAWoJ,QAAX,CAAoBa,GAApB,CAA3B,CADmD;AAAA,QAGnD,MAAMpJ,KAAA,GAAQwH,aAAA,CAAcT,UAAd,CAAyBmD,kBAAzB,CAAd,CAHmD;AAAA,QAInD,IAAIlK,KAAA,IAASoJ,GAAA,CAAIe,eAAjB;AAAA,YAAkCnK,KAAA,CAAMyH,SAAN,GAAkB2B,GAAA,CAAIe,eAAJ,CAAoBlM,OAApB,CAA4BiM,kBAA5B,CAAkD,GAAA,CAAC,CAArE,CAJiB;AAAA,QAMnD,OAAOlK,KAAP,CANmD;AAAA,KApBA;AAAA,IA6BvDwI,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnCA,EAAA,CAAG,IAAKlK,CAAAA,KAAR,CADmC,CAAA;AAAA,KA7BgB;AAAA,IAiCvDsJ,aAAA,GAAyB;AAAA;AAErB,QAAA,OAAO,KAAP,CAFqB;AAAA,KAjC8B;AAAA,IAsCvDpB,SAAA,GAAkC;AAAA,QAC9B,OAAO;AAAA,YAAC,OAAD;AAAA,YAAU,IAAKlI,CAAAA,KAAL,CAAWkI,SAAX,EAAV;AAAA,SAAP,CAD8B;AAAA,KAtCqB;AAAA;;ACO3D,MAAMuB,OAAA,GAAQ;AAAA,IACV,cAAc1E,WADJ;AAAA,IAEV,YAAYC,SAFF;AAAA,IAGV,aAAaH,UAHH;AAAA,IAIV,aAAaC,UAJH;AAAA,CAAd,CAjBA;AA+BA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAAMmG,QAAN,CAAqC;AAAA,IAIjCvL,WAAA,CAAYsC,IAAZ,EAAwBgH,IAAxB,EAAiD;AAAA,QAC7C,IAAKhH,CAAAA,IAAL,GAAYA,IAAZ,CAD6C;AAAA,QAE7C,IAAKgH,CAAAA,IAAL,GAAYA,IAAZ,CAF6C;AAAA,KAJhB;AAAA,IASjC,OAAOjJ,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAAgF;AAAA,QAC5E,IAAID,IAAA,CAAKlL,MAAL,GAAc,CAAlB;AAAA,YACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,+BAAD,CAAd,CAAP,CAFwE;AAAA,QAI5E,MAAM1E,IAAA,GAAgBwE,IAAA,CAAK,CAAL,CAAtB,CAJ4E;AAAA,QAO5E,IAAK,CAAAxE,IAAA,KAAS,YAAT,IAAyBA,IAAA,KAAS,WAAlC,KAAkDwE,IAAA,CAAKlL,MAAL,KAAgB,CAAvE;AAAA,YACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,sBAAD,CAAd,CAAP,CARwE;AAAA,QAU5E,MAAMlH,IAAA,GAAOyH,OAAA,CAAMjF,IAAN,CAAb,CAV4E;AAAA,QAY5E,MAAMwF,MAAA,GAAS,EAAf,CAZ4E;AAAA,QAa5E,KAAK,IAAIzM,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIyL,IAAA,CAAKlL,MAAzB,EAAiCP,CAAA,EAAjC,EAAsC;AAAA,YAClC,MAAMyC,KAAA,GAAQiJ,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAKzL,CAAL,CAAd,EAAuBA,CAAvB,EAA0B2H,SAA1B,CAAd,CADkC;AAAA,YAElC,IAAI,CAAClF,KAAL;AAAA,gBAAY,OAAO,IAAP,CAFsB;AAAA,YAGlCgK,MAAA,CAAOpH,IAAP,CAAY5C,KAAZ,CAHkC,CAAA;AAAA,SAbsC;AAAA,QAmB5E,OAAO,IAAIiL,QAAJ,CAAajJ,IAAb,EAAmBgI,MAAnB,CAAP,CAnB4E;AAAA,KAT/C;AAAA,IA+BjCZ,QAAA,CAASa,GAAT,EAAuG;AAAA,QACnG,IAAI,IAAKjI,CAAAA,IAAL,CAAU4C,IAAV,KAAmB,SAAvB,EAAkC;AAAA,YAC9B,OAAOsG,OAAA,CAAQ,IAAA,CAAKlC,IAAL,CAAU,CAAV,CAAA,CAAaI,QAAb,CAAsBa,GAAtB,CAAR,CAAP,CAD8B;AAAA,SAAlC,MAEO,IAAI,IAAKjI,CAAAA,IAAL,CAAU4C,IAAV,KAAmB,OAAvB,EAAgC;AAAA,YACnC,IAAI5E,KAAJ,CADmC;AAAA,YAEnC,IAAIkJ,KAAJ,CAFmC;AAAA,YAGnC,KAAWmB,MAAAA,GAAX,IAAkB,IAAA,CAAKrB,IAAvB,EAA6B;AAAA,gBACzBhJ,KAAA,GAAQqK,GAAA,CAAIjB,QAAJ,CAAaa,GAAb,CAAR,CADyB;AAAA,gBAEzBf,KAAA,GAAQ,IAAR,CAFyB;AAAA,gBAGzB,IAAIlJ,KAAA,YAAiBP,OAArB,EAA4B;AAAA,oBACxB,OAAOO,KAAP,CADwB;AAAA,iBAA5B,MAEO,IAAI,OAAOA,KAAP,KAAiB,QAArB,EAA+B;AAAA,oBAClC,MAAMmL,CAAA,GAAIlB,GAAA,CAAImB,UAAJ,CAAepL,KAAf,CAAV,CADkC;AAAA,oBAElC,IAAImL,CAAJ;AAAA,wBAAO,OAAOA,CAAP,CAF2B;AAAA,iBAA/B,MAGA,IAAI/E,KAAA,CAAMC,OAAN,CAAcrG,KAAd,CAAJ,EAA0B;AAAA,oBAC7B,IAAIA,KAAA,CAAMlC,MAAN,GAAe,CAAf,IAAoBkC,KAAA,CAAMlC,MAAN,GAAe,CAAvC,EAA0C;AAAA,wBACtCoL,KAAA,GAAQ,CAAC,mBAAD,GAAsBL,IAAA,CAAKC,SAAL,CAAe9I,KAAf,CAAtB,EAA4C,mEAA5C,CAAR,CADsC;AAAA,qBAA1C,MAEO;AAAA,wBACHkJ,KAAA,GAAQX,YAAA,CAAavI,KAAA,CAAM,CAAN,CAAb,EAAuBA,KAAA,CAAM,CAAN,CAAvB,EAAiCA,KAAA,CAAM,CAAN,CAAjC,EAA2CA,KAAA,CAAM,CAAN,CAA3C,CAAR,CADG;AAAA,qBAHsB;AAAA,oBAM7B,IAAI,CAACkJ,KAAL,EAAY;AAAA,wBACR,OAAO,IAAIzJ,OAAJ,CAAWO,KAAA,CAAM,CAAN,CAAD,GAAkB,GAA5B,EAAkCA,KAAA,CAAM,CAAN,CAAD,GAAkB,GAAnD,EAAyDA,KAAA,CAAM,CAAN,CAAD,GAAkB,GAA1E,EAAgFA,KAAA,CAAM,CAAN,CAAhF,CAAP,CADQ;AAAA,qBANiB;AAAA,iBARR;AAAA,aAHM;AAAA,YAsBnC,MAAM,IAAIuJ,cAAJ,CAAiBL,KAAA,IAAS,CAAC,kCAAD,GAAqC,OAAOlJ,KAAP,KAAiB,QAAjB,GAA4BA,KAA5B,GAAoC4I,MAAA,CAAOC,IAAA,CAAKC,SAAL,CAAe9I,KAAf,CAAP,CAAzE,EAAuG,CAAvG,CAA1B,CAAN,CAtBmC;AAAA,SAAhC,MAuBA,IAAI,IAAKgC,CAAAA,IAAL,CAAU4C,IAAV,KAAmB,QAAvB,EAAiC;AAAA,YACpC,IAAI/D,KAAA,GAAQ,IAAZ,CADoC;AAAA,YAEpC,KAAWwJ,MAAAA,GAAX,IAAkB,IAAA,CAAKrB,IAAvB,EAA6B;AAAA,gBACzBnI,KAAA,GAAQwJ,GAAA,CAAIjB,QAAJ,CAAaa,GAAb,CAAR,CADyB;AAAA,gBAEzB,IAAIpJ,KAAA,KAAU,IAAd;AAAA,oBAAoB,OAAO,CAAP,CAFK;AAAA,gBAGzB,MAAMwK,GAAA,GAAMC,MAAA,CAAOzK,KAAP,CAAZ,CAHyB;AAAA,gBAIzB,IAAI0K,KAAA,CAAMF,GAAN,CAAJ;AAAA,oBAAgB,SAJS;AAAA,gBAKzB,OAAOA,GAAP,CALyB;AAAA,aAFO;AAAA,YASpC,MAAM,IAAI9B,cAAJ,CAAiB,CAAC,kBAAD,GAAqBV,IAAA,CAAKC,SAAL,CAAejI,KAAf,CAArB,EAA2C,WAA3C,CAAjB,CAAN,CAToC;AAAA,SAAjC,MAUA,IAAI,IAAKmB,CAAAA,IAAL,CAAU4C,IAAV,KAAmB,WAAvB,EAAoC;AAAA;AAGvC;AAAA,YAAA,OAAO8C,SAAA,CAAUE,UAAV,CAAqB4D,QAAA,CAAc,IAAKxC,CAAAA,IAAL,CAAU,CAAV,EAAaI,QAAb,CAAsBa,GAAtB,CAAd,CAArB,CAAP,CAHuC;AAAA,SAApC,MAIA,IAAI,IAAKjI,CAAAA,IAAL,CAAU4C,IAAV,KAAmB,eAAvB,EAAwC;AAAA,YAC3C,OAAOyD,aAAA,CAAcT,UAAd,CAAyB4D,QAAA,CAAc,IAAKxC,CAAAA,IAAL,CAAU,CAAV,EAAaI,QAAb,CAAsBa,GAAtB,CAAd,CAAzB,CAAP,CAD2C;AAAA,SAAxC,MAEA;AAAA,YACH,OAAOuB,QAAA,CAAc,IAAA,CAAKxC,IAAL,CAAU,CAAV,CAAA,CAAaI,QAAb,CAAsBa,GAAtB,CAAd,CAAP,CADG;AAAA,SA1C4F;AAAA,KA/BtE;AAAA,IA8EjCZ,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnC,KAAKlB,IAAL,CAAUmB,OAAV,CAAkBD,EAAlB,CADmC,CAAA;AAAA,KA9EN;AAAA,IAkFjCZ,aAAA,GAAyB;AAAA,QACrB,OAAO,IAAA,CAAKN,IAAL,CAAUoB,KAAV,CAAgBC,GAAA,IAAOA,GAAA,CAAIf,aAAJ,EAAvB,CAAP,CADqB;AAAA,KAlFQ;AAAA,IAsFjCpB,SAAA,GAAkC;AAAA,QAC9B,IAAI,IAAKlG,CAAAA,IAAL,CAAU4C,IAAV,KAAmB,WAAvB,EAAoC;AAAA,YAChC,OAAO,IAAI0F,gBAAJ,CAAqB,CAAC;AAAA,oBAACK,OAAA,EAAS,IAAA,CAAK3B,IAAL,CAAU,CAAV,CAAV;AAAA,oBAAwB1B,KAAA,EAAO,IAA/B;AAAA,oBAAqCmD,IAAA,EAAM,IAA3C;AAAA,oBAAiDjD,SAAA,EAAW,IAA5D;AAAA,iBAAD,CAArB,CAAA,CAA0FU,SAA1F,EAAP,CADgC;AAAA,SADN;AAAA,QAK9B,IAAI,IAAKlG,CAAAA,IAAL,CAAU4C,IAAV,KAAmB,eAAvB,EAAwC;AAAA,YACpC,OAAO,IAAIkG,eAAJ,CAAoB,IAAK9B,CAAAA,IAAL,CAAU,CAAV,CAApB,CAAA,CAAkCd,SAAlC,EAAP,CADoC;AAAA,SALV;AAAA,QAS9B,MAAMC,UAAA,GAAa,CAAC,CAAC,GAAD,GAAM,IAAA,CAAKnG,IAAL,CAAU4C,IAAhB,EAAA,CAAD,CAAnB,CAT8B;AAAA,QAU9B,IAAKyE,CAAAA,SAAL,CAAeoC,KAAA,IAAS;AAAA,YAAEtD,UAAA,CAAWvF,IAAX,CAAgB6I,KAAA,CAAMvD,SAAN,EAAhB,CAAF,CAAA;AAAA,SAAxB,CAV8B,CAAA;AAAA,QAW9B,OAAOC,UAAP,CAX8B;AAAA,KAtFD;AAAA,CA/BrC;AAoIA,iBAAA,QAAA;;AClIA;AAQA,MAAMuD,aAAA,GAAgB;AAAA,IAAC,SAAD;AAAA,IAAY,OAAZ;AAAA,IAAqB,YAArB;AAAA,IAAmC,SAAnC;AAAA,CAAtB,CAVA;AAYA,MAAMC,iBAAN,CAAwB;AAAA,IAYpBjM,WAAA,GAAc;AAAA,QACV,IAAKkM,CAAAA,OAAL,GAAgB,IAAhB,CADU;AAAA,QAEV,IAAKC,CAAAA,OAAL,GAAe,IAAf,CAFU;AAAA,QAGV,IAAKC,CAAAA,YAAL,GAAoB,IAApB,CAHU;AAAA,QAIV,IAAKC,CAAAA,gBAAL,GAAwB,IAAxB,CAJU;AAAA,QAKV,IAAKC,CAAAA,gBAAL,GAAwB,EAAxB,CALU;AAAA,QAMV,IAAKhB,CAAAA,eAAL,GAAuB,IAAvB,CANU;AAAA,QAOV,IAAKiB,CAAAA,SAAL,GAAiB,IAAjB,CAPU;AAAA,QAQV,IAAKC,CAAAA,gBAAL,GAAwB,IAAxB,CARU;AAAA,QASV,IAAKC,CAAAA,mBAAL,GAA2B,IAA3B,CATU;AAAA,KAZM;AAAA,IAwBpBC,EAAA,GAAoB;AAAA,QAChB,OAAO,IAAKP,CAAAA,OAAL,IAAgB,IAAA,CAAKA,OAAL,CAAaO,EAAb,KAAoBnM,SAApC,GAAgD,IAAK4L,CAAAA,OAAL,CAAaO,EAA7D,GAAkE,IAAzE,CADgB;AAAA,KAxBA;AAAA,IA4BpBC,YAAA,GAA8B;AAAA,QAC1B,OAAO,IAAKR,CAAAA,OAAL,GAAe,OAAO,IAAKA,CAAAA,OAAL,CAAa7J,IAApB,KAA6B,QAA7B,GAAwC0J,aAAA,CAAc,IAAKG,CAAAA,OAAL,CAAa7J,IAA3B,CAAxC,GAA2E,IAAK6J,CAAAA,OAAL,CAAa7J,IAAvG,GAA8G,IAArH,CAD0B;AAAA,KA5BV;AAAA,IAgCpBsK,QAAA,GAAiC;AAAA,QAC7B,OAAO,IAAA,CAAKT,OAAL,IAAgB,cAAc,IAAKA,CAAAA,OAAnC,GAA6C,IAAA,CAAKA,OAAL,CAAaS,QAA1D,GAAqE,IAA5E,CAD6B;AAAA,KAhCb;AAAA,IAoCpBC,WAAA,GAAsC;AAAA,QAClC,OAAO,IAAKN,CAAAA,SAAZ,CADkC;AAAA,KApClB;AAAA,IAwCpBO,UAAA,GAA8B;AAAA,QAC1B,OAAQ,IAAKX,CAAAA,OAAL,IAAgB,IAAA,CAAKA,OAAL,CAAaW,UAA9B,IAA6C,EAApD,CAD0B;AAAA,KAxCV;AAAA,IA4CpBC,kBAAA,GAA6B;AAAA,QACzB,IAAI,IAAKP,CAAAA,gBAAL,IAAyB,IAAA,CAAKC,mBAAlC,EAAuD;AAAA,YAEnD,MAAMhB,CAAA,GAAI,KAAKgB,mBAAL,CAAyBO,MAAnC,CAFmD;AAAA,YAGnD,MAAMpF,KAAA,GAAQ,KAAK6E,mBAAL,CAAyB7E,KAAvC,CAHmD;AAAA,YAInD,MAAM,CAACqF,CAAD,EAAIC,CAAJ,CAAS,GAAA,IAAA,CAAKV,gBAApB,CAJmD;AAAA;AAOnD,YAAMW,MAAAA,EAAA,GAAKF,CAAA,GAAIrF,KAAJ,GAAY6D,CAAA,CAAE,CAAF,CAAvB,CAPmD;AAAA,YAQnD,MAAM2B,EAAA,GAAKF,CAAA,GAAItF,KAAJ,GAAY6D,CAAA,CAAE,CAAF,CAAvB,CARmD;AAAA;AAWnD,YAAM4B,MAAAA,EAAA,GAAK,IAAKZ,CAAAA,mBAAL,CAAyBa,OAAzB,CAAiC,CAAjC,CAAX,CAXmD;AAAA,YAYnD,MAAMC,EAAA,GAAK,IAAKd,CAAAA,mBAAL,CAAyBa,OAAzB,CAAiC,CAAjC,CAAX,CAZmD;AAAA;AAenD,YAAME,MAAAA,IAAA,GAAQH,EAAA,GAAKF,EAAL,GAAUI,EAAA,GAAKH,EAA7B,CAfmD;AAAA,YAgBnD,OAAOI,IAAP,CAhBmD;AAAA,SAD9B;AAAA,QAoBzB,OAAO,CAAP,CApByB;AAAA,KA5CT;AAAA,IAmEpB9B,UAAA,CAAWpL,KAAX,EAAkC;AAAA,QAC9B,IAAImN,MAAA,GAAS,IAAA,CAAKnB,gBAAL,CAAsBhM,KAAtB,CAAb,CAD8B;AAAA,QAE9B,IAAI,CAACmN,MAAL,EAAa;AAAA,YACTA,MAAA,GAAS,IAAKnB,CAAAA,gBAAL,CAAsBhM,KAAtB,CAA+BP,GAAAA,OAAA,CAAMM,KAAN,CAAYC,KAAZ,CAAxC,CADS;AAAA,SAFiB;AAAA,QAK9B,OAAOmN,MAAP,CAL8B;AAAA,KAnEd;AAAA,CAZxB;AAwFA,0BAAA,iBAAA;;ACtFA;AAgBA,MAAMC,kBAAN,CAA+C;AAAA,IAQ3C1N,WAAA,CAAY8E,IAAZ,EAA0BxC,IAA1B,EAAsCoH,QAAtC,EAA0DJ,IAA1D,EAAmF;AAAA,QAC/E,IAAKxE,CAAAA,IAAL,GAAYA,IAAZ,CAD+E;AAAA,QAE/E,IAAKxC,CAAAA,IAAL,GAAYA,IAAZ,CAF+E;AAAA,QAG/E,IAAKqL,CAAAA,SAAL,GAAiBjE,QAAjB,CAH+E;AAAA,QAI/E,IAAKJ,CAAAA,IAAL,GAAYA,IAAZ,CAJ+E;AAAA,KARxC;AAAA,IAe3CI,QAAA,CAASa,GAAT,EAAwC;AAAA,QACpC,OAAO,KAAKoD,SAAL,CAAepD,GAAf,EAAoB,IAAA,CAAKjB,IAAzB,CAAP,CADoC;AAAA,KAfG;AAAA,IAmB3CK,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnC,KAAKlB,IAAL,CAAUmB,OAAV,CAAkBD,EAAlB,CADmC,CAAA;AAAA,KAnBI;AAAA,IAuB3CZ,aAAA,GAAyB;AAAA,QACrB,OAAO,KAAP,CADqB;AAAA,KAvBkB;AAAA,IA2B3CpB,SAAA,GAA0B;AAAA,QACtB,OAAO,CAAC,IAAK1D,CAAAA,IAAN,EAAYC,MAAZ,CAAmB,KAAKuE,IAAL,CAAUzH,GAAV,CAAc8I,GAAA,IAAOA,GAAA,CAAInC,SAAJ,EAArB,CAAnB,CAAP,CADsB;AAAA,KA3BiB;AAAA,IA+B3C,OAAOnI,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAAgF;AAAA,QAC5E,MAAMpK,EAAA,GAAcmK,IAAA,CAAK,CAAL,CAApB,CAD4E;AAAA,QAE5E,MAAMsE,UAAA,GAAaF,kBAAA,CAAmBG,WAAnB,CAA+B1O,EAA/B,CAAnB,CAF4E;AAAA,QAG5E,IAAI,CAACyO,UAAL,EAAiB;AAAA,YACb,OAAOrE,OAAA,CAAQC,KAAR,CAAc,CAAC,oBAAD,GAAuBrK,EAAvB,EAA0B,yDAA1B,CAAd,EAAoG,CAApG,CAAP,CADa;AAAA,SAH2D;AAAA;AAQ5E,QAAA,MAAMmD,IAAA,GAAOoE,KAAA,CAAMC,OAAN,CAAciH,UAAd,CAAA,GACTA,UAAA,CAAW,CAAX,CADS,GACOA,UAAA,CAAWtL,IAD/B,CAR4E;AAAA,QAW5E,MAAMwL,kBAAA,GAAqBpH,KAAA,CAAMC,OAAN,CAAciH,UAAd,CAAA,GACvB,CAAC;AAAA,gBAACA,UAAA,CAAW,CAAX,CAAD;AAAA,gBAAgBA,UAAA,CAAW,CAAX,CAAhB;AAAA,aAAD,CADuB,GAEvBA,UAAA,CAAWG,SAFf,CAX4E;AAAA,QAe5E,MAAMA,SAAA,GAAYD,kBAAA,CAAmBE,MAAnB,CAA0B,CAAC,CAACC,SAAD,CAAD,KACxC,CAACvH,KAAA,CAAMC,OAAN,CAAcsH,SAAd,CAAD;AACA,QAAAA,SAAA,CAAU7P,MAAV,KAAqBkL,IAAA,CAAKlL,MAAL,GAAc,CAAA;AAFrB,CAAlB,CAf4E;AAAA,QAoB5E,IAAI8P,gBAAA,GAAoC,IAAxC,CApB4E;AAAA,QAsB5E,KAAA,MAAW,CAAC3O,MAAD,EAASmK,QAAT,CAAX,IAAiCqE,SAAjC,EAA4C;AAAA;AAGxC;AAAA,YAAAG,gBAAA,GAAmB,IAAIC,gBAAJ,CAAmB5E,OAAA,CAAQ6E,QAA3B,EAAqC7E,OAAA,CAAQ8E,IAA7C,EAAmD,IAAnD,EAAyD9E,OAAA,CAAQ+E,KAAjE,CAAnB,CAHwC;AAAA;AAOxC;AAAA,YAAMC,MAAAA,UAAA,GAAgC,EAAtC,CAPwC;AAAA,YAQxC,IAAIC,cAAA,GAAiB,KAArB,CARwC;AAAA,YASxC,KAAK,IAAI3Q,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIyL,IAAA,CAAKlL,MAAzB,EAAiCP,CAAA,EAAjC,EAAsC;AAAA,gBAClC,MAAM8M,GAAA,GAAMrB,IAAA,CAAKzL,CAAL,CAAZ,CADkC;AAAA,gBAElC,MAAM4L,YAAA,GAAe/C,KAAA,CAAMC,OAAN,CAAcpH,MAAd,CAAA,GACjBA,MAAA,CAAO1B,CAAA,GAAI,CAAX,CADiB,GAEjB0B,MAAA,CAAO+C,IAFX,CAFkC;AAAA,gBAMlC,MAAMgI,MAAA,GAAS4D,gBAAA,CAAiB7N,KAAjB,CAAuBsK,GAAvB,EAA4B,CAAA,GAAI4D,UAAA,CAAWnQ,MAA3C,EAAmDqL,YAAnD,CAAf,CANkC;AAAA,gBAOlC,IAAI,CAACa,MAAL,EAAa;AAAA,oBACTkE,cAAA,GAAiB,IAAjB,CADS;AAAA,oBAET,MAFS;AAAA,iBAPqB;AAAA,gBAWlCD,UAAA,CAAWrL,IAAX,CAAgBoH,MAAhB,CAXkC,CAAA;AAAA,aATE;AAAA,YAsBxC,IAAIkE,cAAJ,EAAoB;AAAA;AAGhB;AAAA,gBAHgB,SAAA;AAAA,aAtBoB;AAAA,YA4BxC,IAAI9H,KAAA,CAAMC,OAAN,CAAcpH,MAAd,CAAJ,EAA2B;AAAA,gBACvB,IAAIA,MAAA,CAAOnB,MAAP,KAAkBmQ,UAAA,CAAWnQ,MAAjC,EAAyC;AAAA,oBACrC8P,gBAAA,CAAiB1E,KAAjB,CAAuB,CAAC,SAAD,GAAYjK,MAAA,CAAOnB,MAAnB,EAA0B,sBAA1B,GAAkDmQ,UAAA,CAAWnQ,MAA7D,EAAoE,SAApE,CAAvB,CADqC,CAAA;AAAA,oBAErC,SAFqC;AAAA,iBADlB;AAAA,aA5Ba;AAAA,YAmCxC,KAAK,IAAIP,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAI0Q,UAAA,CAAWnQ,MAA/B,EAAuCP,CAAA,EAAvC,EAA4C;AAAA,gBACxC,MAAMqI,QAAA,GAAWQ,KAAA,CAAMC,OAAN,CAAcpH,MAAd,CAAwBA,GAAAA,MAAA,CAAO1B,CAAP,CAAxB,GAAoC0B,MAAA,CAAO+C,IAA5D,CADwC;AAAA,gBAExC,MAAMqI,GAAA,GAAM4D,UAAA,CAAW1Q,CAAX,CAAZ,CAFwC;AAAA,gBAGxCqQ,gBAAA,CAAiBnJ,MAAjB,CAAwBlH,CAAA,GAAI,CAA5B,CAA+BoI,CAAAA,YAA/B,CAA4CC,QAA5C,EAAsDyE,GAAA,CAAIrI,IAA1D,CAHwC,CAAA;AAAA,aAnCJ;AAAA,YAyCxC,IAAI4L,gBAAA,CAAiBO,MAAjB,CAAwBrQ,MAAxB,KAAmC,CAAvC,EAA0C;AAAA,gBACtC,OAAO,IAAIsP,kBAAJ,CAAuBvO,EAAvB,EAA2BmD,IAA3B,EAAiCoH,QAAjC,EAA2C6E,UAA3C,CAAP,CADsC;AAAA,aAzCF;AAAA,SAtBgC;AAAA,QAsE5E,IAAIR,SAAA,CAAU3P,MAAV,KAAqB,CAAzB,EAA4B;AAAA,YACxBmL,OAAA,CAAQkF,MAAR,CAAevL,IAAf,CAAoB,GAAGgL,gBAAA,CAAiBO,MAAxC,CADwB,CAAA;AAAA,SAA5B,MAEO;AAAA,YACH,MAAMvI,QAAA,GAAW6H,SAAA,CAAU3P,MAAV,GAAmB2P,SAAnB,GAA+BD,kBAAhD,CADG;AAAA,YAEH,MAAMY,UAAA,GAAaxI,QAAA,CACdrE,GADc,CACV,CAAC,CAACtC,MAAD,CAAD,KAAcoP,kBAAA,CAAmBpP,MAAnB,CADJ,EAEdgJ,IAFc,CAET,KAFS,CAAnB,CAFG;AAAA,YAMH,MAAMqG,WAAA,GAAc,EAApB,CANG;AAAA;AASH;AAAA,YAAA,KAAK,IAAI/Q,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIyL,IAAA,CAAKlL,MAAzB,EAAiCP,CAAA,EAAjC,EAAsC;AAAA,gBAClC,MAAMyM,MAAA,GAASf,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAKzL,CAAL,CAAd,EAAuB,CAAA,GAAI+Q,WAAA,CAAYxQ,MAAvC,CAAf,CADkC;AAAA,gBAElC,IAAI,CAACkM,MAAL;AAAA,oBAAa,OAAO,IAAP,CAFqB;AAAA,gBAGlCsE,WAAA,CAAY1L,IAAZ,CAAiBzC,UAAA,CAAS6J,MAAA,CAAOhI,IAAhB,CAAjB,CAHkC,CAAA;AAAA,aATnC;AAAA,YAcHiH,OAAA,CAAQC,KAAR,CAAc,CAAC,2BAAD,GAA8BkF,UAA9B,EAAyC,aAAzC,GAAwDE,WAAA,CAAYrG,IAAZ,CAAiB,IAAjB,CAAxD,EAA+E,UAA/E,CAAd,CAdG,CAAA;AAAA,SAxEqE;AAAA,QAyF5E,OAAO,IAAP,CAzF4E;AAAA,KA/BrC;AAAA,IA2H3C,OAAOsG,QAAP,CACIT,QADJ,EAEIP,WAFJ,EAGE;AAAA,QAEEH,kBAAA,CAAmBG,WAAnB,GAAiCA,WAAjC,CAFF;AAAA,QAGE,KAAW/I,MAAAA,IAAX,IAAmB+I,WAAnB,EAAgC;AAAA,YAC5BO,QAAA,CAAStJ,IAAT,CAAA,GAAiB4I,kBAAjB,CAD4B;AAAA,SAHlC;AAAA,KA9HyC;AAAA,CAlB/C;AAyJA,SAASiB,kBAAT,CAA4BV,SAA5B,EAA0D;AAAA,IACtD,IAAIvH,KAAA,CAAMC,OAAN,CAAcsH,SAAd,CAAJ,EAA8B;AAAA,QAC1B,OAAO,CAAC,CAAD,GAAIA,SAAA,CAAUpM,GAAV,CAAcpB,UAAd,CAAA,CAAwB8H,IAAxB,CAA6B,IAA7B,CAAJ,EAAuC,CAAvC,CAAP,CAD0B;AAAA,KAA9B,MAEO;AAAA,QACH,OAAO,CAAC,CAAD,GAAI9H,UAAA,CAASwN,SAAA,CAAU3L,IAAnB,CAAJ,EAA6B,IAA7B,CAAP,CADG;AAAA,KAH+C;AAAA,CAzJ1D;AAiKA,2BAAA,kBAAA;;AC/JA;AAQe,MAAMwM,kBAAN,CAA+C;AAAA,IAM1D9O,WAAA,CAAY6G,aAAZ,EAAuCC,kBAAvC,EAAuEC,MAAvE,EAAkG;AAAA,QAC9F,IAAKzE,CAAAA,IAAL,GAAYoD,YAAZ,CAD8F;AAAA,QAE9F,IAAKqB,CAAAA,MAAL,GAAcA,MAAd,CAF8F;AAAA,QAG9F,IAAKF,CAAAA,aAAL,GAAqBA,aAArB,CAH8F;AAAA,QAI9F,IAAKC,CAAAA,kBAAL,GAA0BA,kBAA1B,CAJ8F;AAAA,KANxC;AAAA,IAa1D,OAAOzG,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAAgF;AAAA,QAC5E,IAAID,IAAA,CAAKlL,MAAL,KAAgB,CAApB;AAAA,YACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,sBAAD,CAAd,CAAP,CAFwE;AAAA,QAI5E,MAAMd,OAAA,GAAWY,IAAA,CAAK,CAAL,CAAjB,CAJ4E;AAAA,QAK5E,IAAI,OAAOZ,OAAP,KAAmB,QAAnB,IAA+BhC,KAAA,CAAMC,OAAN,CAAc+B,OAAd,CAAnC;AAAA,YACI,OAAOa,OAAA,CAAQC,KAAR,CAAc,CAAC,4CAAD,CAAd,CAAP,CANwE;AAAA,QAQ5E,MAAM3C,aAAA,GAAgB0C,OAAA,CAAQlJ,KAAR,CAClBqI,OAAA,CAAQ,gBAAR,CAA8BnI,KAAAA,SAA9B,GAA0C,KAA1C,GAAkDmI,OAAA,CAAQ,gBAAR,CADhC,EAC2D,CAD3D,EAC8DrD,WAD9D,CAAtB,CAR4E;AAAA,QAU5E,IAAI,CAACwB,aAAL;AAAA,YAAoB,OAAO,IAAP,CAVwD;AAAA,QAY5E,MAAMC,kBAAA,GAAqByC,OAAA,CAAQlJ,KAAR,CACvBqI,OAAA,CAAQ,qBAAR,CAAmCnI,KAAAA,SAAnC,GAA+C,KAA/C,GAAuDmI,OAAA,CAAQ,qBAAR,CADhC,EACgE,CADhE,EACmErD,WADnE,CAA3B,CAZ4E;AAAA,QAc5E,IAAI,CAACyB,kBAAL;AAAA,YAAyB,OAAO,IAAP,CAdmD;AAAA,QAgB5E,IAAIC,MAAA,GAAS,IAAb,CAhB4E;AAAA,QAiB5E,IAAI2B,OAAA,CAAQ,QAAR,CAAJ,EAAuB;AAAA,YACnB3B,MAAA,GAASwC,OAAA,CAAQlJ,KAAR,CAAcqI,OAAA,CAAQ,QAAR,CAAd,EAAiC,CAAjC,EAAoCtD,UAApC,CAAT,CADmB;AAAA,YAEnB,IAAI,CAAC2B,MAAL;AAAA,gBAAa,OAAO,IAAP,CAFM;AAAA,SAjBqD;AAAA,QAsB5E,OAAO,IAAI+H,kBAAJ,CAAuBjI,aAAvB,EAAsCC,kBAAtC,EAA0DC,MAA1D,CAAP,CAtB4E;AAAA,KAbtB;AAAA,IAsC1D2C,QAAA,CAASa,GAAT,EAA2C;AAAA,QACvC,OAAO,IAAI3D,QAAJ,CAAa,KAAKC,aAAL,CAAmB6C,QAAnB,CAA4Ba,GAA5B,CAAb,EAA+C,IAAA,CAAKzD,kBAAL,CAAwB4C,QAAxB,CAAiCa,GAAjC,CAA/C,EAAsF,IAAKxD,CAAAA,MAAL,GAAc,IAAKA,CAAAA,MAAL,CAAY2C,QAAZ,CAAqBa,GAArB,CAAd,GAA0C,IAAhI,CAAP,CADuC;AAAA,KAtCe;AAAA,IA0C1DZ,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnCA,EAAA,CAAG,IAAK3D,CAAAA,aAAR,CADmC,CAAA;AAAA,QAEnC2D,EAAA,CAAG,IAAK1D,CAAAA,kBAAR,CAFmC,CAAA;AAAA,QAGnC,IAAI,IAAKC,CAAAA,MAAT,EAAiB;AAAA,YACbyD,EAAA,CAAG,IAAKzD,CAAAA,MAAR,CADa,CAAA;AAAA,SAHkB;AAAA,KA1CmB;AAAA,IAkD1D6C,aAAA,GAAyB;AAAA;AAKrB;AAAA;AAAA;AAAA,QAAA,OAAO,KAAP,CALqB;AAAA,KAlDiC;AAAA,IA0D1DpB,SAAA,GAAkC;AAAA,QAC9B,MAAME,OAAA,GAAU,EAAhB,CAD8B;AAAA,QAE9BA,OAAA,CAAQ,gBAAR,CAAA,GAA4B,KAAK7B,aAAL,CAAmB2B,SAAnB,EAA5B,CAF8B;AAAA,QAG9BE,OAAA,CAAQ,qBAAR,CAAA,GAAiC,KAAK5B,kBAAL,CAAwB0B,SAAxB,EAAjC,CAH8B;AAAA,QAI9B,IAAI,IAAKzB,CAAAA,MAAT,EAAiB;AAAA,YACb2B,OAAA,CAAQ,QAAR,CAAA,GAAoB,KAAK3B,MAAL,CAAYyB,SAAZ,EAApB,CADa;AAAA,SAJa;AAAA,QAO9B,OAAO;AAAA,YAAC,UAAD;AAAA,YAAaE,OAAb;AAAA,SAAP,CAP8B;AAAA,KA1DwB;AAAA;;ACR9D;AAaA;AAAA,MAAMqG,MAAA,GAAS,IAAf,CAfA;AAiBA,SAASC,UAAT,CAAoBC,IAApB,EAAgCC,KAAhC,EAAyD;AAAA,IACrDD,IAAA,CAAK,CAAL,IAAUnR,IAAA,CAAKqR,GAAL,CAASF,IAAA,CAAK,CAAL,CAAT,EAAkBC,KAAA,CAAM,CAAN,CAAlB,CAAV,CADqD;AAAA,IAErDD,IAAA,CAAK,CAAL,IAAUnR,IAAA,CAAKqR,GAAL,CAASF,IAAA,CAAK,CAAL,CAAT,EAAkBC,KAAA,CAAM,CAAN,CAAlB,CAAV,CAFqD;AAAA,IAGrDD,IAAA,CAAK,CAAL,IAAUnR,IAAA,CAAKsR,GAAL,CAASH,IAAA,CAAK,CAAL,CAAT,EAAkBC,KAAA,CAAM,CAAN,CAAlB,CAAV,CAHqD;AAAA,IAIrDD,IAAA,CAAK,CAAL,IAAUnR,IAAA,CAAKsR,GAAL,CAASH,IAAA,CAAK,CAAL,CAAT,EAAkBC,KAAA,CAAM,CAAN,CAAlB,CAAV,CAJqD;AAAA,CAjBzD;AAwBA,SAASG,gBAAT,CAA0BC,GAA1B,EAAuC;AAAA,IACnC,OAAQ,CAAMA,GAAAA,GAAAA,GAAN,IAAa,GAArB,CADmC;AAAA,CAxBvC;AA4BA,SAASC,gBAAT,CAA0BC,GAA1B,EAAuC;AAAA,IACnC,OAAQ,CAAA,GAAA,GAAO,GAAM1R,GAAAA,IAAA,CAAK2R,EAAX,GAAgB3R,IAAA,CAAK4R,GAAL,CAAS5R,IAAA,CAAK6R,GAAL,CAAS7R,IAAA,CAAK2R,EAAL,GAAU,CAAV,GAAcD,GAAA,GAAM1R,IAAA,CAAK2R,EAAX,GAAgB,GAAvC,CAAT,CAAvB,IAAiF,GAAzF,CADmC;AAAA,CA5BvC;AAgCA,SAASG,YAAT,CAAsBC,KAAtB,EAAmCC,KAAnC,EAAgD;AAAA,IAC5C,IAAID,KAAA,CAAM,CAAN,KAAYC,KAAA,CAAM,CAAN,CAAhB;AAAA,QAA0B,OAAO,KAAP,CADkB;AAAA,IAE5C,IAAID,KAAA,CAAM,CAAN,KAAYC,KAAA,CAAM,CAAN,CAAhB;AAAA,QAA0B,OAAO,KAAP,CAFkB;AAAA,IAG5C,IAAID,KAAA,CAAM,CAAN,KAAYC,KAAA,CAAM,CAAN,CAAhB;AAAA,QAA0B,OAAO,KAAP,CAHkB;AAAA,IAI5C,IAAID,KAAA,CAAM,CAAN,KAAYC,KAAA,CAAM,CAAN,CAAhB;AAAA,QAA0B,OAAO,KAAP,CAJkB;AAAA,IAK5C,OAAO,IAAP,CAL4C;AAAA,CAhChD;AAwCA,SAASC,kBAAT,CAA4BC,CAA5B,EAA+BzD,SAA/B,EAA2D;AAAA,IACvD,MAAMU,CAAA,GAAIoC,gBAAA,CAAiBW,CAAA,CAAE,CAAF,CAAjB,CAAV,CADuD;AAAA,IAEvD,MAAM9C,CAAA,GAAIqC,gBAAA,CAAiBS,CAAA,CAAE,CAAF,CAAjB,CAAV,CAFuD;AAAA,IAGvD,MAAMC,WAAA,GAAcnS,IAAA,CAAKoS,GAAL,CAAS,CAAT,EAAY3D,SAAA,CAAUlJ,CAAtB,CAApB,CAHuD;AAAA,IAIvD,OAAO;AAAA,QAACvF,IAAA,CAAKC,KAAL,CAAWkP,CAAA,GAAIgD,WAAJ,GAAkBlB,MAA7B,CAAD;AAAA,QAAuCjR,IAAA,CAAKC,KAAL,CAAWmP,CAAA,GAAI+C,WAAJ,GAAkBlB,MAA7B,CAAvC;AAAA,KAAP,CAJuD;AAAA,CAxC3D;AA+CA,SAASoB,UAAT,CAAoBH,CAApB,EAAuBI,EAAvB,EAA2BC,EAA3B,EAA+B;AAAA,IAC3B,MAAMC,EAAA,GAAKN,CAAA,CAAE,CAAF,CAAA,GAAOI,EAAA,CAAG,CAAH,CAAlB,CAD2B;AAAA,IAE3B,MAAMG,EAAA,GAAKP,CAAA,CAAE,CAAF,CAAA,GAAOI,EAAA,CAAG,CAAH,CAAlB,CAF2B;AAAA,IAG3B,MAAMI,EAAA,GAAKR,CAAA,CAAE,CAAF,CAAA,GAAOK,EAAA,CAAG,CAAH,CAAlB,CAH2B;AAAA,IAI3B,MAAMI,EAAA,GAAKT,CAAA,CAAE,CAAF,CAAA,GAAOK,EAAA,CAAG,CAAH,CAAlB,CAJ2B;AAAA,IAK3B,OAAQC,EAAA,GAAKG,EAAL,GAAUD,EAAA,GAAKD,EAAf,KAAsB,CAAvB,IAA8BD,EAAA,GAAKE,EAAL,IAAW,CAAzC,IAAgDD,EAAA,GAAKE,EAAL,IAAW,CAAlE,CAL2B;AAAA,CA/C/B;AAuDA,SAASC,YAAT,CAAsBV,CAAtB,EAAyBI,EAAzB,EAA6BC,EAA7B,EAAiC;AAAA,IAC7B,OAASD,EAAA,CAAG,CAAH,CAAQJ,GAAAA,CAAA,CAAE,CAAF,CAAT,KAAoBK,EAAA,CAAG,CAAH,CAAA,GAAQL,CAAA,CAAE,CAAF,CAA7B,IAAwCA,CAAA,CAAE,CAAF,CAAQ,GAAA,CAAAK,EAAA,CAAG,CAAH,CAAA,GAAQD,EAAA,CAAG,CAAH,CAAR,KAAkBJ,CAAA,CAAE,CAAF,CAAOI,GAAAA,EAAA,CAAG,CAAH,CAAP,CAAnB,IAAoCC,EAAA,CAAG,CAAH,CAAA,GAAQD,EAAA,CAAG,CAAH,CAAR,CAApC,GAAqDA,EAAA,CAAG,CAAH,CAA3G,CAD6B;AAAA,CAvDjC;AA4DA;AAAA,SAASO,kBAAT,CAA4BC,KAA5B,EAAmCC,KAAnC,EAA0C;AAAA,IACtC,IAAIC,MAAA,GAAS,KAAb,CADsC;AAAA,IAEtC,KAAK,IAAIjT,CAAA,GAAI,CAAR,EAAWkT,GAAA,GAAMF,KAAA,CAAMzS,MAAvB,EAA+BP,CAAA,GAAIkT,GAAxC,EAA6ClT,CAAA,EAA7C,EAAkD;AAAA,QAC9C,MAAMmT,IAAA,GAAOH,KAAA,CAAMhT,CAAN,CAAb,CAD8C;AAAA,QAE9C,KAAK,IAAIoT,CAAA,GAAI,CAAR,EAAWC,IAAA,GAAOF,IAAA,CAAK5S,MAAvB,EAA+B6S,CAAA,GAAIC,IAAA,GAAO,CAA/C,EAAkDD,CAAA,EAAlD,EAAuD;AAAA,YACnD,IAAId,UAAA,CAAWS,KAAX,EAAkBI,IAAA,CAAKC,CAAL,CAAlB,EAA2BD,IAAA,CAAKC,CAAA,GAAI,CAAT,CAA3B,CAAJ;AAAA,gBAA6C,OAAO,KAAP,CADM;AAAA,YAEnD,IAAIP,YAAA,CAAaE,KAAb,EAAoBI,IAAA,CAAKC,CAAL,CAApB,EAA6BD,IAAA,CAAKC,CAAA,GAAI,CAAT,CAA7B,CAAJ;AAAA,gBAA+CH,MAAA,GAAS,CAACA,MAAV,CAFI;AAAA,SAFT;AAAA,KAFZ;AAAA,IAStC,OAAOA,MAAP,CATsC;AAAA,CA5D1C;AAwEA,SAASK,mBAAT,CAA6BP,KAA7B,EAAoCQ,QAApC,EAA8C;AAAA,IAC1C,KAAK,IAAIvT,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIuT,QAAA,CAAShT,MAA7B,EAAqCP,CAAA,EAArC,EAA0C;AAAA,QACtC,IAAI8S,kBAAA,CAAmBC,KAAnB,EAA0BQ,QAAA,CAASvT,CAAT,CAA1B,CAAJ;AAAA,YAA4C,OAAO,IAAP,CADN;AAAA,KADA;AAAA,IAI1C,OAAO,KAAP,CAJ0C;AAAA,CAxE9C;AA+EA,SAASwT,IAAT,CAAcC,EAAd,EAAkBC,EAAlB,EAAsB;AAAA,IAClB,OAAQD,EAAA,CAAG,CAAH,CAAQC,GAAAA,EAAA,CAAG,CAAH,CAAR,GAAgBD,EAAA,CAAG,CAAH,CAAA,GAAQC,EAAA,CAAG,CAAH,CAAhC,CADkB;AAAA,CA/EtB;AAoFA;AAAA,SAAUC,QAAV,CAAmBpB,EAAnB,EAAuBC,EAAvB,EAA2BoB,EAA3B,EAA+BC,EAA/B,EAAmC;AAAA;AAE/B,IAAMpB,MAAAA,EAAA,GAAKF,EAAA,CAAG,CAAH,IAAQqB,EAAA,CAAG,CAAH,CAAnB,CAF+B;AAAA,IAG/B,MAAMlB,EAAA,GAAKH,EAAA,CAAG,CAAH,CAAA,GAAQqB,EAAA,CAAG,CAAH,CAAnB,CAH+B;AAAA,IAI/B,MAAMjB,EAAA,GAAKH,EAAA,CAAG,CAAH,CAAA,GAAQoB,EAAA,CAAG,CAAH,CAAnB,CAJ+B;AAAA,IAK/B,MAAMhB,EAAA,GAAKJ,EAAA,CAAG,CAAH,CAAA,GAAQoB,EAAA,CAAG,CAAH,CAAnB,CAL+B;AAAA,IAM/B,MAAME,EAAA,GAAKD,EAAA,CAAG,CAAH,CAAA,GAAQD,EAAA,CAAG,CAAH,CAAnB,CAN+B;AAAA,IAO/B,MAAMG,EAAA,GAAKF,EAAA,CAAG,CAAH,CAAA,GAAQD,EAAA,CAAG,CAAH,CAAnB,CAP+B;AAAA,IAQ/B,MAAMI,IAAA,GAAQvB,EAAA,GAAKsB,EAAL,GAAUD,EAAA,GAAKpB,EAA7B,CAR+B;AAAA,IAS/B,MAAMuB,IAAA,GAAStB,EAAA,GAAKoB,EAAL,GAAUD,EAAA,GAAKlB,EAA9B,CAT+B;AAAA,IAU/B,IAAKoB,IAAA,GAAO,CAAP,IAAYC,IAAA,GAAO,CAApB,IAA2BD,IAAA,GAAO,CAAP,IAAYC,IAAA,GAAO,CAAlD;AAAA,QAAsD,OAAO,IAAP,CAVvB;AAAA,IAW/B,OAAO,KAAP,CAX+B;AAAA,CApFnC;AAkGA;AAAA,SAASC,iBAAT,CAA2B3R,CAA3B,EAA8BD,CAA9B,EAAiCsL,CAAjC,EAAoCuG,CAApC,EAAuC;AAAA;AAInC;AAAA;AAAA,IAAA,MAAMC,OAAA,GAAU;AAAA,QAAC9R,CAAA,CAAE,CAAF,IAAOC,CAAA,CAAE,CAAF,CAAR;AAAA,QAAcD,CAAA,CAAE,CAAF,IAAOC,CAAA,CAAE,CAAF,CAArB;AAAA,KAAhB,CAJmC;AAAA,IAKnC,MAAM8R,OAAA,GAAU;AAAA,QAACF,CAAA,CAAE,CAAF,IAAOvG,CAAA,CAAE,CAAF,CAAR;AAAA,QAAcuG,CAAA,CAAE,CAAF,IAAOvG,CAAA,CAAE,CAAF,CAArB;AAAA,KAAhB,CALmC;AAAA,IAMnC,IAAI4F,IAAA,CAAKa,OAAL,EAAcD,OAAd,MAA2B,CAA/B;AAAA,QAAkC,OAAO,KAAP,CANC;AAAA;AAWnC;AAAA;AAAA,IAAA,IAAIT,QAAA,CAASpR,CAAT,EAAYD,CAAZ,EAAesL,CAAf,EAAkBuG,CAAlB,KAAwBR,QAAA,CAAS/F,CAAT,EAAYuG,CAAZ,EAAe5R,CAAf,EAAkBD,CAAlB,CAA5B;AAAA,QAAkD,OAAO,IAAP,CAXf;AAAA,IAYnC,OAAO,KAAP,CAZmC;AAAA,CAlGvC;AAiHA,SAASgS,oBAAT,CAA8B/B,EAA9B,EAAkCC,EAAlC,EAAsC+B,OAAtC,EAA+C;AAAA,IAC3C,KAAWpB,MAAAA,IAAX,IAAmBoB,OAAnB,EAA4B;AAAA;AAExB,QAAA,KAAK,IAAInB,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAID,IAAA,CAAK5S,MAAL,GAAc,CAAlC,EAAqC,EAAE6S,CAAvC,EAA0C;AAAA,YACtC,IAAIc,iBAAA,CAAkB3B,EAAlB,EAAsBC,EAAtB,EAA0BW,IAAA,CAAKC,CAAL,CAA1B,EAAmCD,IAAA,CAAKC,CAAA,GAAI,CAAT,CAAnC,CAAJ,EAAqD;AAAA,gBACjD,OAAO,IAAP,CADiD;AAAA,aADf;AAAA,SAFlB;AAAA,KADe;AAAA,IAS3C,OAAO,KAAP,CAT2C;AAAA,CAjH/C;AA6HA,SAASoB,uBAAT,CAAiCC,IAAjC,EAAuCF,OAAvC,EAAgD;AAAA;AAE5C,IAAA,KAAK,IAAIvU,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIyU,IAAA,CAAKlU,MAAzB,EAAiC,EAAEP,CAAnC,EAAsC;AAAA,QAClC,IAAI,CAAC8S,kBAAA,CAAmB2B,IAAA,CAAKzU,CAAL,CAAnB,EAA4BuU,OAA5B,CAAL,EAA2C;AAAA,YACvC,OAAO,KAAP,CADuC;AAAA,SADT;AAAA,KAFM;AAAA;AAS5C,IAAA,KAAK,IAAIvU,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIyU,IAAA,CAAKlU,MAAL,GAAc,CAAlC,EAAqC,EAAEP,CAAvC,EAA0C;AAAA,QACtC,IAAIsU,oBAAA,CAAqBG,IAAA,CAAKzU,CAAL,CAArB,EAA8ByU,IAAA,CAAKzU,CAAA,GAAI,CAAT,CAA9B,EAA2CuU,OAA3C,CAAJ,EAAyD;AAAA,YACrD,OAAO,KAAP,CADqD;AAAA,SADnB;AAAA,KATE;AAAA,IAc5C,OAAO,IAAP,CAd4C;AAAA,CA7HhD;AA8IA,SAASG,wBAAT,CAAkCD,IAAlC,EAAwClB,QAAxC,EAAkD;AAAA,IAC9C,KAAK,IAAIvT,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIuT,QAAA,CAAShT,MAA7B,EAAqCP,CAAA,EAArC,EAA0C;AAAA,QACtC,IAAIwU,uBAAA,CAAwBC,IAAxB,EAA8BlB,QAAA,CAASvT,CAAT,CAA9B,CAAJ;AAAA,YAAgD,OAAO,IAAP,CADV;AAAA,KADI;AAAA,IAI9C,OAAO,KAAP,CAJ8C;AAAA,CA9IlD;AAqJA,SAAS2U,cAAT,CAAwBC,WAAxB,EAAqCxD,IAArC,EAAiD1C,SAAjD,EAA6E;AAAA,IACzE,MAAM6F,OAAA,GAAU,EAAhB,CADyE;AAAA,IAEzE,KAAK,IAAIvU,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAI4U,WAAA,CAAYrU,MAAhC,EAAwCP,CAAA,EAAxC,EAA6C;AAAA,QACzC,MAAMmT,IAAA,GAAO,EAAb,CADyC;AAAA,QAEzC,KAAK,IAAIC,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIwB,WAAA,CAAY5U,CAAZ,CAAA,CAAeO,MAAnC,EAA2C6S,CAAA,EAA3C,EAAgD;AAAA,YAC5C,MAAM/B,KAAA,GAAQa,kBAAA,CAAmB0C,WAAA,CAAY5U,CAAZ,CAAA,CAAeoT,CAAf,CAAnB,EAAsC1E,SAAtC,CAAd,CAD4C;AAAA,YAE5CyC,UAAA,CAAWC,IAAX,EAAiBC,KAAjB,CAF4C,CAAA;AAAA,YAG5C8B,IAAA,CAAK9N,IAAL,CAAUgM,KAAV,CAH4C,CAAA;AAAA,SAFP;AAAA,QAOzCkD,OAAA,CAAQlP,IAAR,CAAa8N,IAAb,CAPyC,CAAA;AAAA,KAF4B;AAAA,IAWzE,OAAOoB,OAAP,CAXyE;AAAA,CArJ7E;AAmKA,SAASM,eAAT,CAAyBD,WAAzB,EAAsCxD,IAAtC,EAA4C1C,SAA5C,EAAwE;AAAA,IACpE,MAAM6E,QAAA,GAAW,EAAjB,CADoE;AAAA,IAEpE,KAAK,IAAIvT,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAI4U,WAAA,CAAYrU,MAAhC,EAAwCP,CAAA,EAAxC,EAA6C;AAAA,QACzC,MAAMuU,OAAA,GAAUI,cAAA,CAAeC,WAAA,CAAY5U,CAAZ,CAAf,EAA+BoR,IAA/B,EAAqC1C,SAArC,CAAhB,CADyC;AAAA,QAEzC6E,QAAA,CAASlO,IAAT,CAAckP,OAAd,CAFyC,CAAA;AAAA,KAFuB;AAAA,IAMpE,OAAOhB,QAAP,CANoE;AAAA,CAnKxE;AA4KA,SAASuB,WAAT,CAAqB3C,CAArB,EAAwBf,IAAxB,EAA8B2D,QAA9B,EAAwCC,SAAxC,EAAmD;AAAA,IAC/C,IAAI7C,CAAA,CAAE,CAAF,CAAO4C,GAAAA,QAAA,CAAS,CAAT,CAAP,IAAsB5C,CAAA,CAAE,CAAF,CAAA,GAAO4C,QAAA,CAAS,CAAT,CAAjC,EAA8C;AAAA,QAC1C,MAAME,aAAA,GAAgBD,SAAA,GAAY,GAAlC,CAD0C;AAAA,QAE1C,IAAIE,KAAA,GAAS/C,CAAA,CAAE,CAAF,CAAO4C,GAAAA,QAAA,CAAS,CAAT,CAAP,GAAqBE,aAAtB,GAAuC,CAACD,SAAxC,GAAqDD,QAAA,CAAS,CAAT,CAAA,GAAc5C,CAAA,CAAE,CAAF,CAAd,GAAqB8C,aAAtB,GAAuCD,SAAvC,GAAmD,CAAnH,CAF0C;AAAA,QAG1C,IAAIE,KAAA,KAAU,CAAd,EAAiB;AAAA,YACbA,KAAA,GAAS/C,CAAA,CAAE,CAAF,CAAA,GAAO4C,QAAA,CAAS,CAAT,CAAP,GAAqBE,aAAtB,GAAuC,CAACD,SAAxC,GAAqDD,QAAA,CAAS,CAAT,CAAc5C,GAAAA,CAAA,CAAE,CAAF,CAAd,GAAqB8C,aAAtB,GAAuCD,SAAvC,GAAmD,CAA/G,CADa;AAAA,SAHyB;AAAA,QAM1C7C,CAAA,CAAE,CAAF,CAAA,IAAQ+C,KAAR,CAN0C;AAAA,KADC;AAAA,IAS/C/D,UAAA,CAAWC,IAAX,EAAiBe,CAAjB,CAT+C,CAAA;AAAA,CA5KnD;AAwLA,SAASgD,SAAT,CAAmB/D,IAAnB,EAAyB;AAAA,IACrBA,IAAA,CAAK,CAAL,CAAA,GAAUA,IAAA,CAAK,CAAL,CAAUgE,GAAAA,QAApB,CADqB;AAAA,IAErBhE,IAAA,CAAK,CAAL,CAAUA,GAAAA,IAAA,CAAK,CAAL,CAAA,GAAU,CAACgE,QAArB,CAFqB;AAAA,CAxLzB;AA6LA,SAASC,aAAT,CAAuBtG,QAAvB,EAAiCuG,SAAjC,EAA4CP,QAA5C,EAAsDrG,SAAtD,EAAkF;AAAA,IAC9E,MAAMsG,SAAA,GAAY/U,IAAA,CAAKoS,GAAL,CAAS,CAAT,EAAY3D,SAAA,CAAUlJ,CAAtB,CAAA,GAA2B0L,MAA7C,CAD8E;AAAA,IAE9E,MAAMqE,MAAA,GAAS;AAAA,QAAC7G,SAAA,CAAUU,CAAV,GAAc8B,MAAf;AAAA,QAAuBxC,SAAA,CAAUW,CAAV,GAAc6B,MAArC;AAAA,KAAf,CAF8E;AAAA,IAG9E,MAAMsE,UAAA,GAAa,EAAnB,CAH8E;AAAA,IAI9E,IAAI,CAACzG,QAAL;AAAA,QAAe,OAAOyG,UAAP,CAJ+D;AAAA,IAK9E,KAAWC,MAAAA,MAAX,IAAqB1G,QAArB,EAA+B;AAAA,QAC3B,KAAWgE,MAAAA,KAAX,IAAoB0C,MAApB,EAA4B;AAAA,YACxB,MAAMtD,CAAA,GAAI;AAAA,gBAACY,KAAA,CAAM3D,CAAN,GAAUmG,MAAA,CAAO,CAAP,CAAX;AAAA,gBAAsBxC,KAAA,CAAM1D,CAAN,GAAUkG,MAAA,CAAO,CAAP,CAAhC;AAAA,aAAV,CADwB;AAAA,YAExBT,WAAA,CAAY3C,CAAZ,EAAemD,SAAf,EAA0BP,QAA1B,EAAoCC,SAApC,CAFwB,CAAA;AAAA,YAGxBQ,UAAA,CAAWnQ,IAAX,CAAgB8M,CAAhB,CAHwB,CAAA;AAAA,SADD;AAAA,KAL+C;AAAA,IAY9E,OAAOqD,UAAP,CAZ8E;AAAA,CA7LlF;AA4MA,SAASE,YAAT,CAAsB3G,QAAtB,EAAgC4G,QAAhC,EAA0CZ,QAA1C,EAAoDrG,SAApD,EAAgF;AAAA,IAC5E,MAAMsG,SAAA,GAAY/U,IAAA,CAAKoS,GAAL,CAAS,CAAT,EAAY3D,SAAA,CAAUlJ,CAAtB,CAAA,GAA2B0L,MAA7C,CAD4E;AAAA,IAE5E,MAAMqE,MAAA,GAAS;AAAA,QAAC7G,SAAA,CAAUU,CAAV,GAAc8B,MAAf;AAAA,QAAuBxC,SAAA,CAAUW,CAAV,GAAc6B,MAArC;AAAA,KAAf,CAF4E;AAAA,IAG5E,MAAM0E,SAAA,GAAY,EAAlB,CAH4E;AAAA,IAI5E,IAAI,CAAC7G,QAAL;AAAA,QAAe,OAAO6G,SAAP,CAJ6D;AAAA,IAK5E,KAAWnB,MAAAA,IAAX,IAAmB1F,QAAnB,EAA6B;AAAA,QACzB,MAAM8G,QAAA,GAAW,EAAjB,CADyB;AAAA,QAEzB,KAAW9C,MAAAA,KAAX,IAAoB0B,IAApB,EAA0B;AAAA,YACtB,MAAMtC,CAAA,GAAI;AAAA,gBAACY,KAAA,CAAM3D,CAAN,GAAUmG,MAAA,CAAO,CAAP,CAAX;AAAA,gBAAsBxC,KAAA,CAAM1D,CAAN,GAAUkG,MAAA,CAAO,CAAP,CAAhC;AAAA,aAAV,CADsB;AAAA,YAEtBpE,UAAA,CAAWwE,QAAX,EAAqBxD,CAArB,CAFsB,CAAA;AAAA,YAGtB0D,QAAA,CAASxQ,IAAT,CAAc8M,CAAd,CAHsB,CAAA;AAAA,SAFD;AAAA,QAOzByD,SAAA,CAAUvQ,IAAV,CAAewQ,QAAf,CAPyB,CAAA;AAAA,KAL+C;AAAA,IAc5E,IAAIF,QAAA,CAAS,CAAT,CAAcA,GAAAA,QAAA,CAAS,CAAT,CAAd,IAA6BX,SAAA,GAAY,CAA7C,EAAgD;AAAA,QAC5CG,SAAA,CAAUQ,QAAV,CAD4C,CAAA;AAAA,QAE5C,KAAWlB,MAAAA,IAAX,IAAmBmB,SAAnB,EAA8B;AAAA,YAC1B,KAAWzD,MAAAA,CAAX,IAAgBsC,IAAhB,EAAsB;AAAA,gBAClBK,WAAA,CAAY3C,CAAZ,EAAewD,QAAf,EAAyBZ,QAAzB,EAAmCC,SAAnC,CADkB,CAAA;AAAA,aADI;AAAA,SAFc;AAAA,KAd4B;AAAA,IAsB5E,OAAOY,SAAP,CAtB4E;AAAA,CA5MhF;AAqOA,SAASE,oBAAT,CAA8BpJ,GAA9B,EAAsDqJ,eAAtD,EAAwF;AAAA,IACpF,MAAMT,SAAA,GAAY;AAAA,QAACF,QAAD;AAAA,QAAWA,QAAX;AAAA,QAAqB,CAACA,QAAtB;AAAA,QAAgC,CAACA,QAAjC;AAAA,KAAlB,CADoF;AAAA,IAEpF,MAAML,QAAA,GAAW;AAAA,QAACK,QAAD;AAAA,QAAWA,QAAX;AAAA,QAAqB,CAACA,QAAtB;AAAA,QAAgC,CAACA,QAAjC;AAAA,KAAjB,CAFoF;AAAA,IAIpF,MAAM1G,SAAA,GAAYhC,GAAA,CAAIsC,WAAJ,EAAlB,CAJoF;AAAA,IAKpF,IAAI,CAACN,SAAL,EAAgB;AAAA,QACZ,OAAO,KAAP,CADY;AAAA,KALoE;AAAA,IASpF,IAAIqH,eAAA,CAAgBtR,IAAhB,KAAyB,SAA7B,EAAwC;AAAA,QACpC,MAAMuR,WAAA,GAAcrB,cAAA,CAAeoB,eAAA,CAAgBnB,WAA/B,EAA4CG,QAA5C,EAAsDrG,SAAtD,CAApB,CADoC;AAAA,QAEpC,MAAM8G,UAAA,GAAaH,aAAA,CAAc3I,GAAA,CAAIqC,QAAJ,EAAd,EAA8BuG,SAA9B,EAAyCP,QAAzC,EAAmDrG,SAAnD,CAAnB,CAFoC;AAAA,QAGpC,IAAI,CAACqD,YAAA,CAAauD,SAAb,EAAwBP,QAAxB,CAAL;AAAA,YAAwC,OAAO,KAAP,CAHJ;AAAA,QAKpC,KAAWhC,MAAAA,KAAX,IAAoByC,UAApB,EAAgC;AAAA,YAC5B,IAAI,CAAC1C,kBAAA,CAAmBC,KAAnB,EAA0BiD,WAA1B,CAAL;AAAA,gBAA6C,OAAO,KAAP,CADjB;AAAA,SALI;AAAA,KAT4C;AAAA,IAkBpF,IAAID,eAAA,CAAgBtR,IAAhB,KAAyB,cAA7B,EAA6C;AAAA,QACzC,MAAMwR,YAAA,GAAepB,eAAA,CAAgBkB,eAAA,CAAgBnB,WAAhC,EAA6CG,QAA7C,EAAuDrG,SAAvD,CAArB,CADyC;AAAA,QAEzC,MAAM8G,UAAA,GAAaH,aAAA,CAAc3I,GAAA,CAAIqC,QAAJ,EAAd,EAA8BuG,SAA9B,EAAyCP,QAAzC,EAAmDrG,SAAnD,CAAnB,CAFyC;AAAA,QAGzC,IAAI,CAACqD,YAAA,CAAauD,SAAb,EAAwBP,QAAxB,CAAL;AAAA,YAAwC,OAAO,KAAP,CAHC;AAAA,QAKzC,KAAWhC,MAAAA,KAAX,IAAoByC,UAApB,EAAgC;AAAA,YAC5B,IAAI,CAAClC,mBAAA,CAAoBP,KAApB,EAA2BkD,YAA3B,CAAL;AAAA,gBAA+C,OAAO,KAAP,CADnB;AAAA,SALS;AAAA,KAlBuC;AAAA,IA4BpF,OAAO,IAAP,CA5BoF;AAAA,CArOxF;AAoQA,SAASC,mBAAT,CAA6BxJ,GAA7B,EAAqDqJ,eAArD,EAAuF;AAAA,IACnF,MAAMJ,QAAA,GAAW;AAAA,QAACP,QAAD;AAAA,QAAWA,QAAX;AAAA,QAAqB,CAACA,QAAtB;AAAA,QAAgC,CAACA,QAAjC;AAAA,KAAjB,CADmF;AAAA,IAEnF,MAAML,QAAA,GAAW;AAAA,QAACK,QAAD;AAAA,QAAWA,QAAX;AAAA,QAAqB,CAACA,QAAtB;AAAA,QAAgC,CAACA,QAAjC;AAAA,KAAjB,CAFmF;AAAA,IAInF,MAAM1G,SAAA,GAAYhC,GAAA,CAAIsC,WAAJ,EAAlB,CAJmF;AAAA,IAKnF,IAAI,CAACN,SAAL,EAAgB;AAAA,QACZ,OAAO,KAAP,CADY;AAAA,KALmE;AAAA,IASnF,IAAIqH,eAAA,CAAgBtR,IAAhB,KAAyB,SAA7B,EAAwC;AAAA,QACpC,MAAMuR,WAAA,GAAcrB,cAAA,CAAeoB,eAAA,CAAgBnB,WAA/B,EAA4CG,QAA5C,EAAsDrG,SAAtD,CAApB,CADoC;AAAA,QAEpC,MAAMkH,SAAA,GAAYF,YAAA,CAAahJ,GAAA,CAAIqC,QAAJ,EAAb,EAA6B4G,QAA7B,EAAuCZ,QAAvC,EAAiDrG,SAAjD,CAAlB,CAFoC;AAAA,QAGpC,IAAI,CAACqD,YAAA,CAAa4D,QAAb,EAAuBZ,QAAvB,CAAL;AAAA,YAAuC,OAAO,KAAP,CAHH;AAAA,QAKpC,KAAWN,MAAAA,IAAX,IAAmBmB,SAAnB,EAA8B;AAAA,YAC1B,IAAI,CAACpB,uBAAA,CAAwBC,IAAxB,EAA8BuB,WAA9B,CAAL;AAAA,gBAAiD,OAAO,KAAP,CADvB;AAAA,SALM;AAAA,KAT2C;AAAA,IAkBnF,IAAID,eAAA,CAAgBtR,IAAhB,KAAyB,cAA7B,EAA6C;AAAA,QACzC,MAAMwR,YAAA,GAAepB,eAAA,CAAgBkB,eAAA,CAAgBnB,WAAhC,EAA6CG,QAA7C,EAAuDrG,SAAvD,CAArB,CADyC;AAAA,QAEzC,MAAMkH,SAAA,GAAYF,YAAA,CAAahJ,GAAA,CAAIqC,QAAJ,EAAb,EAA6B4G,QAA7B,EAAuCZ,QAAvC,EAAiDrG,SAAjD,CAAlB,CAFyC;AAAA,QAGzC,IAAI,CAACqD,YAAA,CAAa4D,QAAb,EAAuBZ,QAAvB,CAAL;AAAA,YAAuC,OAAO,KAAP,CAHE;AAAA,QAKzC,KAAWN,MAAAA,IAAX,IAAmBmB,SAAnB,EAA8B;AAAA,YAC1B,IAAI,CAAClB,wBAAA,CAAyBD,IAAzB,EAA+BwB,YAA/B,CAAL;AAAA,gBAAmD,OAAO,KAAP,CADzB;AAAA,SALW;AAAA,KAlBsC;AAAA,IA2BnF,OAAO,IAAP,CA3BmF;AAAA,CApQvF;AAkSA,MAAME,MAAN,CAAmC;AAAA,IAK/BhU,WAAA,CAAYiU,OAAZ,EAA8BC,UAA9B,EAA2D;AAAA,QACvD,IAAK5R,CAAAA,IAAL,GAAY+C,WAAZ,CADuD;AAAA,QAEvD,IAAK4O,CAAAA,OAAL,GAAeA,OAAf,CAFuD;AAAA,QAGvD,IAAKC,CAAAA,UAAL,GAAkBA,UAAlB,CAHuD;AAAA,KAL5B;AAAA,IAW/B,OAAO7T,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAA4E;AAAA,QACxE,IAAID,IAAA,CAAKlL,MAAL,KAAgB,CAApB;AAAA,YACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,6DAAD,GAAgEF,IAAA,CAAKlL,MAAL,GAAc,CAA9E,EAAgF,SAAhF,CAAd,CAAP,CAFoE;AAAA,QAGxE,IAAI0K,OAAA,CAAQQ,IAAA,CAAK,CAAL,CAAR,CAAJ,EAAsB;AAAA,YAClB,MAAM2K,OAAA,GAAW3K,IAAA,CAAK,CAAL,CAAjB,CADkB;AAAA,YAElB,IAAI2K,OAAA,CAAQ3R,IAAR,KAAiB,mBAArB,EAA0C;AAAA,gBACtC,KAAK,IAAIzE,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIoW,OAAA,CAAQE,QAAR,CAAiB/V,MAArC,EAA6C,EAAEP,CAA/C,EAAkD;AAAA,oBAC9C,MAAMyE,IAAA,GAAO2R,OAAA,CAAQE,QAAR,CAAiBtW,CAAjB,CAAoB+O,CAAAA,QAApB,CAA6BtK,IAA1C,CAD8C;AAAA,oBAE9C,IAAIA,IAAA,KAAS,SAAT,IAAsBA,IAAA,KAAS,cAAnC,EAAmD;AAAA,wBAC/C,OAAO,IAAI0R,MAAJ,CAAWC,OAAX,EAAoBA,OAAA,CAAQE,QAAR,CAAiBtW,CAAjB,CAAoB+O,CAAAA,QAAxC,CAAP,CAD+C;AAAA,qBAFL;AAAA,iBADZ;AAAA,aAA1C,MAOO,IAAIqH,OAAA,CAAQ3R,IAAR,KAAiB,SAArB,EAAgC;AAAA,gBACnC,MAAMA,IAAA,GAAO2R,OAAA,CAAQrH,QAAR,CAAiBtK,IAA9B,CADmC;AAAA,gBAEnC,IAAIA,IAAA,KAAS,SAAT,IAAsBA,IAAA,KAAS,cAAnC,EAAmD;AAAA,oBAC/C,OAAO,IAAI0R,MAAJ,CAAWC,OAAX,EAAoBA,OAAA,CAAQrH,QAA5B,CAAP,CAD+C;AAAA,iBAFhB;AAAA,aAAhC,MAKA,IAAIqH,OAAA,CAAQ3R,IAAR,KAAkB,SAAlB,IAA+B2R,OAAA,CAAQ3R,IAAR,KAAiB,cAApD,EAAoE;AAAA,gBACvE,OAAO,IAAI0R,MAAJ,CAAWC,OAAX,EAAoBA,OAApB,CAAP,CADuE;AAAA,aAdzD;AAAA,SAHkD;AAAA,QAqBxE,OAAO1K,OAAA,CAAQC,KAAR,CAAc,CAAC,sFAAD,CAAd,CAAP,CArBwE;AAAA,KAX7C;AAAA,IAmC/BE,QAAA,CAASa,GAAT,EAA0C;AAAA,QACtC,IAAIA,GAAA,CAAIqC,QAAJ,EAAkB,IAAA,IAAlB,IAA0BrC,GAAA,CAAIsC,WAAJ,EAAqB,IAAA,IAAnD,EAAyD;AAAA,YACrD,IAAItC,GAAA,CAAIoC,YAAJ,EAAA,KAAuB,OAA3B,EAAoC;AAAA,gBAChC,OAAOgH,oBAAA,CAAqBpJ,GAArB,EAA0B,IAAK2J,CAAAA,UAA/B,CAAP,CADgC;AAAA,aAApC,MAEO,IAAI3J,GAAA,CAAIoC,YAAJ,EAAA,KAAuB,YAA3B,EAAyC;AAAA,gBAC5C,OAAOoH,mBAAA,CAAoBxJ,GAApB,EAAyB,IAAK2J,CAAAA,UAA9B,CAAP,CAD4C;AAAA,aAHK;AAAA,SADnB;AAAA,QAQtC,OAAO,KAAP,CARsC;AAAA,KAnCX;AAAA,IA8C/BvK,SAAA,GAAY;AAAA,KA9CmB;AAAA,IAgD/BC,aAAA,GAAyB;AAAA,QACrB,OAAO,IAAP,CADqB;AAAA,KAhDM;AAAA,IAoD/BpB,SAAA,GAAkC;AAAA,QAC9B,OAAO;AAAA,YAAC,QAAD;AAAA,YAAW,KAAKyL,OAAhB;AAAA,SAAP,CAD8B;AAAA,KApDH;AAAA,CAlSnC;AA4VA,eAAA,MAAA;;AC1VA;AAIA,SAASG,iBAAT,CAA2BtU,CAA3B,EAAmD;AAAA,IAC/C,IAAIA,CAAA,YAAa4N,oBAAjB,EAAqC;AAAA,QACjC,IAAI5N,CAAA,CAAEgF,IAAF,KAAW,KAAX,IAAoBhF,CAAA,CAAEwJ,IAAF,CAAOlL,MAAP,KAAkB,CAA1C,EAA6C;AAAA,YACzC,OAAO,KAAP,CADyC;AAAA,SAA7C,MAEO,IAAI0B,CAAA,CAAEgF,IAAF,KAAW,eAAf,EAAgC;AAAA,YACnC,OAAO,KAAP,CADmC;AAAA,SAAhC,MAEA,IAAIhF,CAAA,CAAEgF,IAAF,KAAW,KAAX,IAAoBhF,CAAA,CAAEwJ,IAAF,CAAOlL,MAAP,KAAkB,CAA1C,EAA6C;AAAA,YAChD,OAAO,KAAP,CADgD;AAAA,SAA7C,MAEA,IACH0B,CAAA,CAAEgF,IAAF,KAAW,YAAX,IACAhF,CAAA,CAAEgF,IAAF,KAAW,eADX,IAEAhF,CAAA,CAAEgF,IAAF,KAAW,IAHR,EAIL;AAAA,YACE,OAAO,KAAP,CADF;AAAA,SAJK,MAMA,IAAI,UAAWuP,CAAAA,IAAX,CAAgBvU,CAAA,CAAEgF,IAAlB,CAAJ,EAA6B;AAAA,YAChC,OAAO,KAAP,CADgC;AAAA,SAbH;AAAA,KADU;AAAA,IAmB/C,IAAIhF,CAAA,YAAakU,QAAjB,EAAyB;AAAA,QACrB,OAAO,KAAP,CADqB;AAAA,KAnBsB;AAAA,IAuB/C,IAAI/P,MAAA,GAAS,IAAb,CAvB+C;AAAA,IAwB/CnE,CAAA,CAAE6J,SAAF,CAAYgB,GAAA,IAAO;AAAA,QACf,IAAI1G,MAAA,IAAU,CAACmQ,iBAAA,CAAkBzJ,GAAlB,CAAf,EAAuC;AAAA,YAAE1G,MAAA,GAAS,KAAT,CAAF;AAAA,SADxB;AAAA,KAAnB,CAxB+C,CAAA;AAAA,IA2B/C,OAAOA,MAAP,CA3B+C;AAAA,CANnD;AAoCA,SAASqQ,eAAT,CAAyBxU,CAAzB,EAAiD;AAAA,IAC7C,IAAIA,CAAA,YAAa4N,oBAAjB,EAAqC;AAAA,QACjC,IAAI5N,CAAA,CAAEgF,IAAF,KAAW,eAAf,EAAgC;AAAA,YAC5B,OAAO,KAAP,CAD4B;AAAA,SADC;AAAA,KADQ;AAAA,IAM7C,IAAIb,MAAA,GAAS,IAAb,CAN6C;AAAA,IAO7CnE,CAAA,CAAE6J,SAAF,CAAYgB,GAAA,IAAO;AAAA,QACf,IAAI1G,MAAA,IAAU,CAACqQ,eAAA,CAAgB3J,GAAhB,CAAf,EAAqC;AAAA,YAAE1G,MAAA,GAAS,KAAT,CAAF;AAAA,SADtB;AAAA,KAAnB,CAP6C,CAAA;AAAA,IAU7C,OAAOA,MAAP,CAV6C;AAAA,CApCjD;AAiDA,SAASsQ,wBAAT,CAAkCzU,CAAlC,EAAiDgN,UAAjD,EAAqF;AAAA,IACjF,IAAIhN,CAAA,YAAa4N,oBAAb,IAAmCZ,UAAA,CAAW1N,OAAX,CAAmBU,CAAA,CAAEgF,IAArB,CAAA,IAA8B,CAArE,EAAwE;AAAA,QAAE,OAAO,KAAP,CAAF;AAAA,KADS;AAAA,IAEjF,IAAIb,MAAA,GAAS,IAAb,CAFiF;AAAA,IAGjFnE,CAAA,CAAE6J,SAAF,CAAagB,GAAD,IAAS;AAAA,QACjB,IAAI1G,MAAA,IAAU,CAACsQ,wBAAA,CAAyB5J,GAAzB,EAA8BmC,UAA9B,CAAf,EAA0D;AAAA,YAAE7I,MAAA,GAAS,KAAT,CAAF;AAAA,SADzC;AAAA,KAArB,CAHiF,CAAA;AAAA,IAMjF,OAAOA,MAAP,CANiF;AAAA;;AC1CrF;AAAA,MAAMuQ,GAAN,CAAgC;AAAA,IAK5BxU,WAAA,CAAY8E,IAAZ,EAA0B2P,eAA1B,EAAuD;AAAA,QACnD,KAAKnS,IAAL,GAAYmS,eAAA,CAAgBnS,IAA5B,CADmD;AAAA,QAEnD,IAAKwC,CAAAA,IAAL,GAAYA,IAAZ,CAFmD;AAAA,QAGnD,IAAK2P,CAAAA,eAAL,GAAuBA,eAAvB,CAHmD;AAAA,KAL3B;AAAA,IAW5B,OAAOpU,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAA+E;AAAA,QAC3E,IAAID,IAAA,CAAKlL,MAAL,KAAgB,CAAhB,IAAqB,OAAOkL,IAAA,CAAK,CAAL,CAAP,KAAmB,QAA5C;AAAA,YACI,OAAOC,OAAA,CAAQC,KAAR,CAAc,CAAC,8DAAD,CAAd,CAAP,CAFuE;AAAA,QAI3E,MAAM1E,IAAA,GAAOwE,IAAA,CAAK,CAAL,CAAb,CAJ2E;AAAA,QAK3E,IAAI,CAACC,OAAA,CAAQ+E,KAAR,CAActJ,GAAd,CAAkBF,IAAlB,CAAL,EAA8B;AAAA,YAC1B,OAAOyE,OAAA,CAAQC,KAAR,CAAc,CAAC,kBAAD,GAAqB1E,IAArB,EAA0B,cAA1B,GAA0CA,IAA1C,EAA+C,kEAA/C,CAAd,EAAkI,CAAlI,CAAP,CAD0B;AAAA,SAL6C;AAAA,QAS3E,OAAO,IAAI0P,GAAJ,CAAQ1P,IAAR,EAAcyE,OAAA,CAAQ+E,KAAR,CAAclM,GAAd,CAAkB0C,IAAlB,CAAd,CAAP,CAT2E;AAAA,KAXnD;AAAA,IAuB5B4E,QAAA,CAASa,GAAT,EAAsC;AAAA,QAClC,OAAO,KAAKkK,eAAL,CAAqB/K,QAArB,CAA8Ba,GAA9B,CAAP,CADkC;AAAA,KAvBV;AAAA,IA2B5BZ,SAAA,GAAY;AAAA,KA3BgB;AAAA,IA6B5BC,aAAA,GAAyB;AAAA,QACrB,OAAO,KAAP,CADqB;AAAA,KA7BG;AAAA,IAiC5BpB,SAAA,GAA2B;AAAA,QACvB,OAAO;AAAA,YAAC,KAAD;AAAA,YAAQ,KAAK1D,IAAb;AAAA,SAAP,CADuB;AAAA,KAjCC;AAAA,CAPhC;AA6CA,YAAA,GAAA;;AC3CA;AAoBA;AAAA;AAAA;AAAA;AAAA,MAAMqJ,cAAN,CAAqB;AAAA;AAajB;AAAA;AAAA;AAAA,IAAAnO,WAAA,CACIoO,QADJ,EAEIC,IAAA,GAAsB,EAF1B,EAGI5E,YAHJ,EAII6E,KAAA,GAAe,IAAI3J,OAAJ,EAJnB,EAKI8J,MAAA,GAA8B,EALlC,EAME;AAAA,QACE,IAAKL,CAAAA,QAAL,GAAgBA,QAAhB,CADF;AAAA,QAEE,IAAKC,CAAAA,IAAL,GAAYA,IAAZ,CAFF;AAAA,QAGE,IAAA,CAAK5J,GAAL,GAAW4J,IAAA,CAAKxM,GAAL,CAAS6S,IAAA,IAAQ,CAAC,CAAD,GAAIA,IAAJ,EAAS,CAAT,CAAjB,EAA8BnM,IAA9B,CAAmC,EAAnC,CAAX,CAHF;AAAA,QAIE,IAAK+F,CAAAA,KAAL,GAAaA,KAAb,CAJF;AAAA,QAKE,IAAKG,CAAAA,MAAL,GAAcA,MAAd,CALF;AAAA,QAME,IAAKhF,CAAAA,YAAL,GAAoBA,YAApB,CANF;AAAA,KAnBe;AAAA;AAmCjB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAApJ,KAAA,CACIsU,IADJ,EAEIC,KAFJ,EAGInL,YAHJ,EAII5E,QAJJ,EAKI6D,OAAA,GAA2D,EAL/D,EAMe;AAAA,QACX,IAAIkM,KAAJ,EAAW;AAAA,YACP,OAAO,IAAK7P,CAAAA,MAAL,CAAY6P,KAAZ,EAAmBnL,YAAnB,EAAiC5E,QAAjC,CAAA,CAA2CgQ,MAA3C,CAAkDF,IAAlD,EAAwDjM,OAAxD,CAAP,CADO;AAAA,SADA;AAAA,QAIX,OAAO,KAAKmM,MAAL,CAAYF,IAAZ,EAAkBjM,OAAlB,CAAP,CAJW;AAAA,KAzCE;AAAA,IAgDjBmM,MAAA,CAAOF,IAAP,EAAoBjM,OAApB,EAA2F;AAAA,QACvF,IAAIiM,IAAA,KAAS,IAAT,IAAiB,OAAOA,IAAP,KAAgB,QAAjC,IAA6C,OAAOA,IAAP,KAAgB,SAA7D,IAA0E,OAAOA,IAAP,KAAgB,QAA9F,EAAwG;AAAA,YACpGA,IAAA,GAAO;AAAA,gBAAC,SAAD;AAAA,gBAAYA,IAAZ;AAAA,aAAP,CADoG;AAAA,SADjB;AAAA,QAKvF,SAASG,QAAT,CAAkBxK,MAAlB,EAA0BhI,IAA1B,EAAgCyS,cAAhC,EAA8E;AAAA,YAC1E,IAAIA,cAAA,KAAmB,QAAvB,EAAiC;AAAA,gBAC7B,OAAO,IAAI3K,WAAJ,CAAc9H,IAAd,EAAoB,CAACgI,MAAD,CAApB,CAAP,CAD6B;AAAA,aAAjC,MAEO,IAAIyK,cAAA,KAAmB,QAAvB,EAAiC;AAAA,gBACpC,OAAO,IAAIxJ,UAAJ,CAAajJ,IAAb,EAAmB,CAACgI,MAAD,CAAnB,CAAP,CADoC;AAAA,aAAjC,MAEA;AAAA,gBACH,OAAOA,MAAP,CADG;AAAA,aALmE;AAAA,SALS;AAAA,QAevF,IAAI5D,KAAA,CAAMC,OAAN,CAAcgO,IAAd,CAAJ,EAAyB;AAAA,YACrB,IAAIA,IAAA,CAAKvW,MAAL,KAAgB,CAApB,EAAuB;AAAA,gBACnB,OAAO,KAAKoL,KAAL,CAAW,CAAC,gGAAD,CAAX,CAAP,CADmB;AAAA,aADF;AAAA,YAKrB,MAAMrK,EAAA,GAAKwV,IAAA,CAAK,CAAL,CAAX,CALqB;AAAA,YAMrB,IAAI,OAAOxV,EAAP,KAAc,QAAlB,EAA4B;AAAA,gBACxB,IAAKqK,CAAAA,KAAL,CAAW,CAAC,4CAAD,GAA+C,OAAOrK,EAAtD,EAAyD,gEAAzD,CAAX,EAAuI,CAAvI,CADwB,CAAA;AAAA,gBAExB,OAAO,IAAP,CAFwB;AAAA,aANP;AAAA,YAWrB,MAAM6V,IAAA,GAAO,IAAA,CAAK5G,QAAL,CAAcjP,EAAd,CAAb,CAXqB;AAAA,YAYrB,IAAI6V,IAAJ,EAAU;AAAA,gBACN,IAAI1K,MAAA,GAAS0K,IAAA,CAAK3U,KAAL,CAAWsU,IAAX,EAAiB,IAAjB,CAAb,CADM;AAAA,gBAEN,IAAI,CAACrK,MAAL;AAAA,oBAAa,OAAO,IAAP,CAFP;AAAA,gBAIN,IAAI,IAAKb,CAAAA,YAAT,EAAuB;AAAA,oBACnB,MAAMvD,QAAA,GAAW,IAAA,CAAKuD,YAAtB,CADmB;AAAA,oBAEnB,MAAMwL,MAAA,GAAS3K,MAAA,CAAOhI,IAAtB,CAFmB;AAAA;AAYnB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAAA,IAAK,CAAA4D,QAAA,CAAShB,IAAT,KAAkB,QAAlB,IAA8BgB,QAAA,CAAShB,IAAT,KAAkB,QAAhD,IAA4DgB,QAAA,CAAShB,IAAT,KAAkB,SAA9E,IAA2FgB,QAAA,CAAShB,IAAT,KAAkB,QAA7G,IAAyHgB,QAAA,CAAShB,IAAT,KAAkB,OAA3I,KAAuJ+P,MAAA,CAAO/P,IAAP,KAAgB,OAA5K,EAAqL;AAAA,wBACjLoF,MAAA,GAASwK,QAAA,CAASxK,MAAT,EAAiBpE,QAAjB,EAA2BwC,OAAA,CAAQqM,cAAR,IAA0B,QAArD,CAAT,CADiL;AAAA,qBAArL,MAEO,IAAK,CAAA7O,QAAA,CAAShB,IAAT,KAAkB,OAAlB,IAA6BgB,QAAA,CAAShB,IAAT,KAAkB,WAA/C,IAA8DgB,QAAA,CAAShB,IAAT,KAAkB,eAAhF,MAAqG+P,MAAA,CAAO/P,IAAP,KAAgB,OAAhB,IAA2B+P,MAAA,CAAO/P,IAAP,KAAgB,QAA3C,CAA1G,EAAgK;AAAA,wBACnKoF,MAAA,GAASwK,QAAA,CAASxK,MAAT,EAAiBpE,QAAjB,EAA2BwC,OAAA,CAAQqM,cAAR,IAA0B,QAArD,CAAT,CADmK;AAAA,qBAAhK,MAEA,IAAI,IAAK9O,CAAAA,YAAL,CAAkBC,QAAlB,EAA4B+O,MAA5B,CAAJ,EAAyC;AAAA,wBAC5C,OAAO,IAAP,CAD4C;AAAA,qBAhB7B;AAAA,iBAJjB;AAAA;AA6BN;AAAA;AAAA;AAAA,gBAAA,IAAI,EAAE3K,MAAA,YAAkBjB,SAAlB,CAAF,IAAiCiB,MAAA,CAAOhI,IAAP,CAAY4C,IAAZ,KAAqB,eAAtD,IAA0EgQ,UAAA,CAAW5K,MAAX,CAA9E,EAAkG;AAAA,oBAC9F,MAAM6K,EAAA,GAAK,IAAIlJ,mBAAJ,EAAX,CAD8F;AAAA,oBAE9F,IAAI;AAAA,wBACA3B,MAAA,GAAS,IAAIjB,SAAJ,CAAYiB,MAAA,CAAOhI,IAAnB,EAAyBgI,MAAA,CAAOZ,QAAP,CAAgByL,EAAhB,CAAzB,CAAT,CADA;AAAA,qBAAJ,CAEE,OAAOrV,CAAP,EAAU;AAAA,wBACR,KAAK0J,KAAL,CAAW1J,CAAA,CAAE4E,OAAb,CADQ,CAAA;AAAA,wBAER,OAAO,IAAP,CAFQ;AAAA,qBAJkF;AAAA,iBA7B5F;AAAA,gBAuCN,OAAO4F,MAAP,CAvCM;AAAA,aAZW;AAAA,YAsDrB,OAAO,IAAA,CAAKd,KAAL,CAAW,CAAC,oBAAD,GAAuBrK,EAAvB,EAA0B,yDAA1B,CAAX,EAAiG,CAAjG,CAAP,CAtDqB;AAAA,SAAzB,MAuDO,IAAI,OAAOwV,IAAP,KAAgB,WAApB,EAAiC;AAAA,YACpC,OAAO,KAAKnL,KAAL,CAAW,CAAC,4CAAD,CAAX,CAAP,CADoC;AAAA,SAAjC,MAEA,IAAI,OAAOmL,IAAP,KAAgB,QAApB,EAA8B;AAAA,YACjC,OAAO,KAAKnL,KAAL,CAAW,CAAC,qDAAD,CAAX,CAAP,CADiC;AAAA,SAA9B,MAEA;AAAA,YACH,OAAO,IAAA,CAAKA,KAAL,CAAW,CAAC,6BAAD,GAAgC,OAAOmL,IAAvC,EAA4C,SAA5C,CAAX,CAAP,CADG;AAAA,SA1EgF;AAAA,KAhD1E;AAAA;AAuIjB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAA5P,MAAA,CAAO6P,KAAP,EAAsBnL,YAAtB,EAA4C5E,QAA5C,EAAoG;AAAA,QAChG,MAAMwJ,IAAA,GAAO,OAAOuG,KAAP,KAAiB,QAAjB,GAA4B,IAAA,CAAKvG,IAAL,CAAUtJ,MAAV,CAAiB6P,KAAjB,CAA5B,GAAsD,IAAA,CAAKvG,IAAxE,CADgG;AAAA,QAEhG,MAAMC,KAAA,GAAQzJ,QAAA,GAAW,IAAKyJ,CAAAA,KAAL,CAAWvJ,MAAX,CAAkBF,QAAlB,CAAX,GAAyC,IAAA,CAAKyJ,KAA5D,CAFgG;AAAA,QAGhG,OAAO,IAAIH,cAAJ,CACH,IAAKC,CAAAA,QADF,EAEHC,IAFG,EAGH5E,YAAA,IAAgB,IAHb,EAIH6E,KAJG,EAKH,IAAKG,CAAAA,MALF,CAAP,CAHgG;AAAA,KAvInF;AAAA;AA0JjB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAAjF,KAAA,CAAMA,KAAN,EAAqB,OAArB,EAA6C;AAAA,QACzC,MAAM/E,GAAA,GAAM,CAAG,GAAA,IAAA,CAAKA,GAAR,EAAA,GAAcjC,IAAA,CAAKX,GAAL,CAASuT,CAAA,IAAK,CAAC,CAAD,GAAIA,CAAJ,EAAM,CAAN,CAAd,CAAwB7M,CAAAA,IAAxB,CAA6B,EAA7B,CAAd,EAAA,CAAZ,CADyC;AAAA,QAEzC,IAAKkG,CAAAA,MAAL,CAAYvL,IAAZ,CAAiB,IAAIsB,cAAJ,CAAiBC,GAAjB,EAAsB+E,KAAtB,CAAjB,CAFyC,CAAA;AAAA,KA1J5B;AAAA;AAmKjB;AAAA;AAAA;AAAA,IAAAvD,YAAA,CAAaC,QAAb,EAA6BC,CAA7B,EAA+C;AAAA,QAC3C,MAAMqD,KAAA,GAAQvD,YAAA,CAAaC,QAAb,EAAuBC,CAAvB,CAAd,CAD2C;AAAA,QAE3C,IAAIqD,KAAJ;AAAA,YAAW,IAAKA,CAAAA,KAAL,CAAWA,KAAX,CAFgC,CAAA;AAAA,QAG3C,OAAOA,KAAP,CAH2C;AAAA,KAnK9B;AAAA,CAtBrB;AAgMA,uBAhMA,cAAA,CAAA;AAkMA,SAAS0L,UAAT,CAAoBxS,UAApB,EAA4C;AAAA,IACxC,IAAIA,UAAA,YAAsB8R,KAA1B,EAA+B;AAAA,QAC3B,OAAOU,UAAA,CAAWxS,UAAA,CAAW+R,eAAtB,CAAP,CAD2B;AAAA,KAA/B,MAEO,IAAI/R,UAAA,YAAsBgL,oBAAtB,IAA4ChL,UAAA,CAAWoC,IAAX,KAAoB,OAApE,EAA6E;AAAA,QAChF,OAAO,KAAP,CADgF;AAAA,KAA7E,MAEA,IAAIpC,UAAA,YAAsBoM,kBAA1B,EAA8C;AAAA;AAIjD;AAAA;AAAA,QAAA,OAAO,KAAP,CAJiD;AAAA,KAA9C,MAKA,IAAIpM,UAAA,YAAsBsR,QAA1B,EAAkC;AAAA,QACrC,OAAO,KAAP,CADqC;AAAA,KAVD;AAAA,IAcxC,MAAMqB,gBAAA,GAAmB3S,UAAA,YAAsB6I,UAAtB,IACrB7I,UAAA,YAAsB0H,WAD1B,CAdwC;AAAA,IAiBxC,IAAIkL,gBAAA,GAAmB,IAAvB,CAjBwC;AAAA,IAkBxC5S,UAAA,CAAWiH,SAAX,CAAqBoC,KAAA,IAAS;AAAA;AAQ1B;AAAA;AAAA;AAAA;AAAA;AAAA,QAAA,IAAIsJ,gBAAJ,EAAsB;AAAA,YAClBC,gBAAA,GAAmBA,gBAAA,IAAoBJ,UAAA,CAAWnJ,KAAX,CAAvC,CADkB;AAAA,SAAtB,MAEO;AAAA,YACHuJ,gBAAA,GAAmBA,gBAAA,IAAoBvJ,KAAA,YAAiB1C,SAAxD,CADG;AAAA,SAVmB;AAAA,KAA9B,CAlBwC,CAAA;AAAA,IAgCxC,IAAI,CAACiM,gBAAL,EAAuB;AAAA,QACnB,OAAO,KAAP,CADmB;AAAA,KAhCiB;AAAA,IAoCxC,OAAOlB,iBAAA,CAAkB1R,UAAlB,KACH6R,wBAAA,CAAyB7R,UAAzB,EAAqC;AAAA,QAAC,MAAD;AAAA,QAAS,iBAAT;AAAA,QAA4B,eAA5B;AAAA,QAA6C,qBAA7C;AAAA,QAAoE,aAApE;AAAA,QAAmF,qBAAnF;AAAA,QAA0G,OAA1G;AAAA,QAAmH,sBAAnH;AAAA,KAArC,CADJ,CApCwC;AAAA;;AChM5C;AAUA;AAAA;AAAA;AAAA;AAAO,SAAS6S,yBAAT,CAAmChU,KAAnC,EAAyDjB,KAAzD,EAAgF;AAAA,IACnF,MAAMiE,SAAA,GAAYhD,KAAA,CAAMnD,MAAN,GAAe,CAAjC,CADmF;AAAA,IAEnF,IAAIoX,UAAA,GAAa,CAAjB,CAFmF;AAAA,IAGnF,IAAIC,UAAA,GAAalR,SAAjB,CAHmF;AAAA,IAInF,IAAImR,YAAA,GAAe,CAAnB,CAJmF;AAAA,IAKnF,IAAIC,YAAJ,EAAkBC,SAAlB,CALmF;AAAA,IAOnF,OAAOJ,UAAA,IAAcC,UAArB,EAAiC;AAAA,QAC7BC,YAAA,GAAe5X,IAAA,CAAKuM,KAAL,CAAY,CAAAmL,UAAA,GAAaC,UAAb,IAA2B,CAAvC,CAAf,CAD6B;AAAA,QAE7BE,YAAA,GAAepU,KAAA,CAAMmU,YAAN,CAAf,CAF6B;AAAA,QAG7BE,SAAA,GAAYrU,KAAA,CAAMmU,YAAA,GAAe,CAArB,CAAZ,CAH6B;AAAA,QAK7B,IAAIC,YAAA,IAAgBrV,KAApB,EAA2B;AAAA,YACvB,IAAIoV,YAAA,KAAiBnR,SAAjB,IAA8BjE,KAAA,GAAQsV,SAA1C,EAAqD;AAAA;AACjD,gBAAA,OAAOF,YAAP,CADiD;AAAA,aAD9B;AAAA,YAKvBF,UAAA,GAAaE,YAAA,GAAe,CAA5B,CALuB;AAAA,SAA3B,MAMO,IAAIC,YAAA,GAAerV,KAAnB,EAA0B;AAAA,YAC7BmV,UAAA,GAAaC,YAAA,GAAe,CAA5B,CAD6B;AAAA,SAA1B,MAEA;AAAA,YACH,MAAM,IAAI7L,cAAJ,CAAiB,wBAAjB,CAAN,CADG;AAAA,SAbsB;AAAA,KAPkD;AAAA,IAyBnF,OAAO,CAAP,CAzBmF;AAAA;;ACVvF;AAUA,MAAMgM,IAAN,CAAiC;AAAA,IAO7B7V,WAAA,CAAYsC,IAAZ,EAAwBhC,KAAxB,EAA2CiB,KAA3C,EAAyD;AAAA,QACrD,IAAKe,CAAAA,IAAL,GAAYA,IAAZ,CADqD;AAAA,QAErD,IAAKhC,CAAAA,KAAL,GAAaA,KAAb,CAFqD;AAAA,QAIrD,IAAKwV,CAAAA,MAAL,GAAc,EAAd,CAJqD;AAAA,QAKrD,IAAKC,CAAAA,OAAL,GAAe,EAAf,CALqD;AAAA,QAMrD,KAAA,MAAW,CAACC,KAAD,EAAQtT,UAAR,CAAX,IAAkCnB,KAAlC,EAAyC;AAAA,YACrC,KAAKuU,MAAL,CAAY5S,IAAZ,CAAiB8S,KAAjB,CADqC,CAAA;AAAA,YAErC,KAAKD,OAAL,CAAa7S,IAAb,CAAkBR,UAAlB,CAFqC,CAAA;AAAA,SANY;AAAA,KAP5B;AAAA,IAmB7B,OAAOrC,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAA0E;AAAA,QACtE,IAAID,IAAA,CAAKlL,MAAL,GAAc,CAAd,GAAkB,CAAtB,EAAyB;AAAA,YACrB,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,8CAAD,GAAiDF,IAAA,CAAKlL,MAAL,GAAc,CAA/D,EAAiE,CAAjE,CAAd,CAAP,CADqB;AAAA,SAD6C;AAAA,QAKtE,IAAK,CAAAkL,IAAA,CAAKlL,MAAL,GAAc,CAAd,IAAmB,CAApB,KAA0B,CAA9B,EAAiC;AAAA,YAC7B,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,qCAAD,CAAd,CAAP,CAD6B;AAAA,SALqC;AAAA,QAStE,MAAMlJ,KAAA,GAAQiJ,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0BnE,UAA1B,CAAd,CATsE;AAAA,QAUtE,IAAI,CAAC7E,KAAL;AAAA,YAAY,OAAO,IAAP,CAV0D;AAAA,QAYtE,MAAMiB,KAAA,GAAe,EAArB,CAZsE;AAAA,QActE,IAAI0U,UAAA,GAAoB,IAAxB,CAdsE;AAAA,QAetE,IAAI1M,OAAA,CAAQE,YAAR,IAAwBF,OAAA,CAAQE,YAAR,CAAqBvE,IAArB,KAA8B,OAA1D,EAAmE;AAAA,YAC/D+Q,UAAA,GAAa1M,OAAA,CAAQE,YAArB,CAD+D;AAAA,SAfG;AAAA,QAmBtE,KAAK,IAAI5L,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIyL,IAAA,CAAKlL,MAAzB,EAAiCP,CAAA,IAAK,CAAtC,EAAyC;AAAA,YACrC,MAAMmY,KAAA,GAAQnY,CAAA,KAAM,CAAN,GAAU,CAACoV,QAAX,GAAsB3J,IAAA,CAAKzL,CAAL,CAApC,CADqC;AAAA,YAErC,MAAMsD,KAAA,GAAQmI,IAAA,CAAKzL,CAAA,GAAI,CAAT,CAAd,CAFqC;AAAA,YAIrC,MAAMqY,QAAA,GAAWrY,CAAjB,CAJqC;AAAA,YAKrC,MAAMsY,QAAA,GAAWtY,CAAA,GAAI,CAArB,CALqC;AAAA,YAOrC,IAAI,OAAOmY,KAAP,KAAiB,QAArB,EAA+B;AAAA,gBAC3B,OAAOzM,OAAA,CAAQC,KAAR,CAAc,yIAAd,EAAyJ0M,QAAzJ,CAAP,CAD2B;AAAA,aAPM;AAAA,YAWrC,IAAI3U,KAAA,CAAMnD,MAAN,IAAgBmD,KAAA,CAAMA,KAAA,CAAMnD,MAAN,GAAe,CAArB,CAAA,CAAwB,CAAxB,CAAA,IAA8B4X,KAAlD,EAAyD;AAAA,gBACrD,OAAOzM,OAAA,CAAQC,KAAR,CAAc,2GAAd,EAA2H0M,QAA3H,CAAP,CADqD;AAAA,aAXpB;AAAA,YAerC,MAAM5L,MAAA,GAASf,OAAA,CAAQlJ,KAAR,CAAcc,KAAd,EAAqBgV,QAArB,EAA+BF,UAA/B,CAAf,CAfqC;AAAA,YAgBrC,IAAI,CAAC3L,MAAL;AAAA,gBAAa,OAAO,IAAP,CAhBwB;AAAA,YAiBrC2L,UAAA,GAAaA,UAAA,IAAc3L,MAAA,CAAOhI,IAAlC,CAjBqC;AAAA,YAkBrCf,KAAA,CAAM2B,IAAN,CAAW;AAAA,gBAAC8S,KAAD;AAAA,gBAAQ1L,MAAR;AAAA,aAAX,CAlBqC,CAAA;AAAA,SAnB6B;AAAA,QAwCtE,OAAO,IAAIuL,IAAJ,CAASI,UAAT,EAAqB3V,KAArB,EAA4BiB,KAA5B,CAAP,CAxCsE;AAAA,KAnB7C;AAAA,IA8D7BmI,QAAA,CAASa,GAAT,EAAsC;AAAA,QAClC,MAAMuL,MAAA,GAAS,IAAA,CAAKA,MAApB,CADkC;AAAA,QAElC,MAAMC,OAAA,GAAU,IAAA,CAAKA,OAArB,CAFkC;AAAA,QAIlC,IAAID,MAAA,CAAO1X,MAAP,KAAkB,CAAtB,EAAyB;AAAA,YACrB,OAAO2X,OAAA,CAAQ,CAAR,EAAWrM,QAAX,CAAoBa,GAApB,CAAP,CADqB;AAAA,SAJS;AAAA,QAQlC,MAAMpJ,KAAA,GAAU,IAAKb,CAAAA,KAAL,CAAWoJ,QAAX,CAAoBa,GAApB,CAAhB,CARkC;AAAA,QASlC,IAAIpJ,KAAA,IAAS2U,MAAA,CAAO,CAAP,CAAb,EAAwB;AAAA,YACpB,OAAOC,OAAA,CAAQ,CAAR,EAAWrM,QAAX,CAAoBa,GAApB,CAAP,CADoB;AAAA,SATU;AAAA,QAalC,MAAM6L,SAAA,GAAYN,MAAA,CAAO1X,MAAzB,CAbkC;AAAA,QAclC,IAAI+C,KAAA,IAAS2U,MAAA,CAAOM,SAAA,GAAY,CAAnB,CAAb,EAAoC;AAAA,YAChC,OAAOL,OAAA,CAAQK,SAAA,GAAY,CAApB,CAAA,CAAuB1M,QAAvB,CAAgCa,GAAhC,CAAP,CADgC;AAAA,SAdF;AAAA,QAkBlC,MAAMqK,KAAA,GAAQW,yBAAA,CAA0BO,MAA1B,EAAkC3U,KAAlC,CAAd,CAlBkC;AAAA,QAmBlC,OAAO4U,OAAA,CAAQnB,KAAR,EAAelL,QAAf,CAAwBa,GAAxB,CAAP,CAnBkC;AAAA,KA9DT;AAAA,IAoF7BZ,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnCA,EAAA,CAAG,IAAKlK,CAAAA,KAAR,CADmC,CAAA;AAAA,QAEnC,KAAWoC,MAAAA,UAAX,IAAyB,IAAA,CAAKqT,OAA9B,EAAuC;AAAA,YACnCvL,EAAA,CAAG9H,UAAH,CADmC,CAAA;AAAA,SAFJ;AAAA,KApFV;AAAA,IA2F7BkH,aAAA,GAAyB;AAAA,QACrB,OAAO,IAAA,CAAKmM,OAAL,CAAarL,KAAb,CAAmB2L,GAAA,IAAOA,GAAA,CAAIzM,aAAJ,EAA1B,CAAP,CADqB;AAAA,KA3FI;AAAA,IA+F7BpB,SAAA,GAAkC;AAAA,QAC9B,MAAMC,UAAA,GAAa;AAAA,YAAC,MAAD;AAAA,YAAS,IAAKnI,CAAAA,KAAL,CAAWkI,SAAX,EAAT;AAAA,SAAnB,CAD8B;AAAA,QAE9B,KAAK,IAAI3K,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAI,IAAA,CAAKiY,MAAL,CAAY1X,MAAhC,EAAwCP,CAAA,EAAxC,EAA6C;AAAA,YACzC,IAAIA,CAAA,GAAI,CAAR,EAAW;AAAA,gBACP4K,UAAA,CAAWvF,IAAX,CAAgB,KAAK4S,MAAL,CAAYjY,CAAZ,CAAhB,CADO,CAAA;AAAA,aAD8B;AAAA,YAIzC4K,UAAA,CAAWvF,IAAX,CAAgB,IAAA,CAAK6S,OAAL,CAAalY,CAAb,CAAA,CAAgB2K,SAAhB,EAAhB,CAJyC,CAAA;AAAA,SAFf;AAAA,QAQ9B,OAAOC,UAAP,CAR8B;AAAA,KA/FL;AAAA,CAZjC;AAuHA,aAAA,IAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IC3FA6N,UAAA,GAAiBC,UAAjB,CA5BA;AA8BA,SAASA,UAAT,CAAoBC,GAApB,EAAyBC,GAAzB,EAA8BC,GAA9B,EAAmCC,GAAnC,EAAwC;AAAA;AAEpC,IAAA,IAAA,CAAKC,EAAL,GAAU,CAAMJ,GAAAA,GAAhB,CAFoC;AAAA,IAGpC,IAAKK,CAAAA,EAAL,GAAU,CAAA,IAAOH,GAAA,GAAMF,GAAN,CAAP,GAAoB,IAAKI,CAAAA,EAAnC,CAHoC;AAAA,IAIpC,IAAA,CAAKE,EAAL,GAAU,CAAA,GAAM,KAAKF,EAAX,GAAgB,IAAKC,CAAAA,EAA/B,CAJoC;AAAA,IAMpC,IAAKE,CAAAA,EAAL,GAAU,CAAA,GAAMN,GAAhB,CANoC;AAAA,IAOpC,IAAKO,CAAAA,EAAL,GAAU,CAAA,IAAOL,GAAA,GAAMF,GAAN,CAAP,GAAoB,IAAKM,CAAAA,EAAnC,CAPoC;AAAA,IAQpC,IAAA,CAAKE,EAAL,GAAU,CAAA,GAAM,KAAKF,EAAX,GAAgB,IAAKC,CAAAA,EAA/B,CARoC;AAAA,IAUpC,IAAKR,CAAAA,GAAL,GAAWA,GAAX,CAVoC;AAAA,IAWpC,IAAKC,CAAAA,GAAL,GAAWE,GAAX,CAXoC;AAAA,IAYpC,IAAKD,CAAAA,GAAL,GAAWA,GAAX,CAZoC;AAAA,IAapC,IAAKC,CAAAA,GAAL,GAAWA,GAAX,CAboC;AAAA,CA9BxC;AA8CAJ,UAAA,CAAWW,SAAX,CAAqBC,YAArB,GAAoC,UAAShR,CAAT,EAAY;AAAA;AAE5C,IAAA,OAAQ,CAAC,CAAK2Q,IAAAA,CAAAA,EAAL,GAAU3Q,CAAV,GAAc,IAAK0Q,CAAAA,EAAnB,IAAyB1Q,CAA1B,GAA8B,IAAA,CAAKyQ,EAAnC,IAAyCzQ,CAAjD,CAF4C;AAAA,CAAhD,CA9CA;AAmDAoQ,UAAA,CAAWW,SAAX,CAAqBE,YAArB,GAAoC,UAASjR,CAAT,EAAY;AAAA,IAC5C,OAAQ,CAAC,CAAA,IAAA,CAAK8Q,EAAL,GAAU9Q,CAAV,GAAc,IAAK6Q,CAAAA,EAAnB,IAAyB7Q,CAA1B,GAA8B,IAAA,CAAK4Q,EAAnC,IAAyC5Q,CAAjD,CAD4C;AAAA,CAAhD,CAnDA;AAuDAoQ,UAAA,CAAWW,SAAX,CAAqBG,sBAArB,GAA8C,UAASlR,CAAT,EAAY;AAAA,IACtD,OAAQ,CAAM,CAAA,GAAA,IAAA,CAAK2Q,EAAX,GAAgB3Q,CAAhB,GAAoB,CAAA,GAAM,IAAK0Q,CAAAA,EAA/B,IAAqC1Q,CAAtC,GAA0C,IAAA,CAAKyQ,EAAtD,CADsD;AAAA,CAA1D,CAvDA;AA2DAL,UAAA,CAAWW,SAAX,CAAqBI,WAArB,GAAmC,UAASrK,CAAT,EAAYsK,OAAZ,EAAqB;AAAA,IACpD,IAAI,OAAOA,OAAP,KAAmB,WAAvB;AAAA,QAAoCA,OAAA,GAAU,QAAV,CADgB;AAAA,IAGpD,IAAIC,EAAJ,EAAQC,EAAR,EAAYC,EAAZ,EAAgBlH,EAAhB,EAAoB3S,CAApB,CAHoD;AAAA;AAMpD,IAAA,KAAK6Z,EAAA,GAAKzK,CAAL,EAAQpP,CAAA,GAAI,CAAjB,EAAoBA,CAAA,GAAI,CAAxB,EAA2BA,CAAA,EAA3B,EAAgC;AAAA,QAE5B2S,EAAA,GAAK,IAAK2G,CAAAA,YAAL,CAAkBO,EAAlB,CAAA,GAAwBzK,CAA7B,CAF4B;AAAA,QAG5B,IAAInP,IAAA,CAAK6Z,GAAL,CAASnH,EAAT,IAAe+G,OAAnB;AAAA,YAA4B,OAAOG,EAAP,CAHA;AAAA,QAK5B,IAAIE,EAAA,GAAK,IAAA,CAAKP,sBAAL,CAA4BK,EAA5B,CAAT,CAL4B;AAAA,QAM5B,IAAI5Z,IAAA,CAAK6Z,GAAL,CAASC,EAAT,IAAe,QAAnB;AAAA,YAAyB,MANG;AAAA,QAQ5BF,EAAA,GAAKA,EAAA,GAAKlH,EAAA,GAAKoH,EAAf,CAR4B;AAAA,KANoB;AAAA;AAkBpD,IAAAJ,EAAA,GAAK,CAAL,CAlBoD;AAAA,IAmBpDC,EAAA,GAAK,CAAL,CAnBoD;AAAA,IAoBpDC,EAAA,GAAKzK,CAAL,CApBoD;AAAA,IAsBpD,IAAIyK,EAAA,GAAKF,EAAT;AAAA,QAAa,OAAOA,EAAP,CAtBuC;AAAA,IAuBpD,IAAIE,EAAA,GAAKD,EAAT;AAAA,QAAa,OAAOA,EAAP,CAvBuC;AAAA,IAyBpD,OAAOD,EAAA,GAAKC,EAAZ,EAAgB;AAAA,QAEZjH,EAAA,GAAK,IAAA,CAAK2G,YAAL,CAAkBO,EAAlB,CAAL,CAFY;AAAA,QAGZ,IAAI5Z,IAAA,CAAK6Z,GAAL,CAASnH,EAAA,GAAKvD,CAAd,CAAA,GAAmBsK,OAAvB;AAAA,YAAgC,OAAOG,EAAP,CAHpB;AAAA,QAKZ,IAAIzK,CAAA,GAAIuD,EAAR,EAAY;AAAA,YACRgH,EAAA,GAAKE,EAAL,CADQ;AAAA,SAAZ,MAEO;AAAA,YACHD,EAAA,GAAKC,EAAL,CADG;AAAA,SAPK;AAAA,QAWZA,EAAA,GAAM,CAAAD,EAAA,GAAKD,EAAL,IAAW,GAAZ,GAAkBA,EAAvB,CAXY;AAAA,KAzBoC;AAAA;AAwCpD,IAAA,OAAOE,EAAP,CAxCoD;AAAA,CAAxD,CA3DA;AAsGAnB,UAAA,CAAWW,SAAX,CAAqBW,KAArB,GAA6B,UAAS5K,CAAT,EAAYsK,OAAZ,EAAqB;AAAA,IAC9C,OAAO,IAAA,CAAKH,YAAL,CAAkB,IAAKE,CAAAA,WAAL,CAAiBrK,CAAjB,EAAoBsK,OAApB,CAAlB,CAAP,CAD8C;AAAA,CAAlD,CAAA;;;;ACpGA;AAEO,SAAStN,MAAT,CAAgB7J,CAAhB,EAA2BD,CAA3B,EAAsCgG,CAAtC,EAAyD;AAAA,IAC5D,OAAQ/F,CAAA,IAAS+F,CAAAA,GAAAA,CAAJ,CAAN,GAAiBhG,CAAA,GAAIgG,CAA5B,CAD4D;AAAA,CAJhE;AAQO,SAAS2R,KAAT,CAAeC,IAAf,EAA4BC,EAA5B,EAAuC7R,CAAvC,EAAyD;AAAA,IAC5D,OAAO,IAAIpG,OAAJ,CACHkK,MAAA,CAAO8N,IAAA,CAAK9X,CAAZ,EAAe+X,EAAA,CAAG/X,CAAlB,EAAqBkG,CAArB,CADG,EAEH8D,MAAA,CAAO8N,IAAA,CAAK7X,CAAZ,EAAe8X,EAAA,CAAG9X,CAAlB,EAAqBiG,CAArB,CAFG,EAGH8D,MAAA,CAAO8N,IAAA,CAAK5X,CAAZ,EAAe6X,EAAA,CAAG7X,CAAlB,EAAqBgG,CAArB,CAHG,EAIH8D,MAAA,CAAO8N,IAAA,CAAK3X,CAAZ,EAAe4X,EAAA,CAAG5X,CAAlB,EAAqB+F,CAArB,CAJG,CAAP,CAD4D;AAAA,CARhE;AAiBO,SAASN,KAAT,CAAekS,IAAf,EAAoCC,EAApC,EAAuD7R,CAAvD,EAAiF;AAAA,IACpF,OAAO4R,IAAA,CAAKlW,GAAL,CAAS,CAACmQ,CAAD,EAAInU,CAAJ,KAAU;AAAA,QACtB,OAAOoM,MAAA,CAAO+H,CAAP,EAAUgG,EAAA,CAAGna,CAAH,CAAV,EAAiBsI,CAAjB,CAAP,CADsB;AAAA,KAAnB,CAAP,CADoF;AAAA;;;;;;;;;ACfxF;AAmBA;AAAA,MAAM8R,EAAA,GAAK,OAAX;AAAA;AACI,IAAAC,EAAA,GAAK,CADT,EAEIC,EAAA,GAAK,OAFT,EAGIX,EAAA,GAAK,IAAI,EAHb,EAIIC,EAAA,GAAK,CAAA,GAAI,EAJb,EAKIC,EAAA,GAAK,CAAA,GAAID,EAAJ,GAASA,EALlB,EAMIW,EAAA,GAAKX,EAAA,GAAKA,EAAL,GAAUA,EANnB,EAOIY,SAAA,GAAUva,IAAA,CAAK2R,EAAL,GAAU,GAPxB,EAQI6I,OAAA,GAAU,GAAMxa,GAAAA,IAAA,CAAK2R,EARzB,CArBA;AAgCA;AAAA,SAAS8I,OAAT,CAAiBpS,CAAjB,EAA4B;AAAA,IACxB,OAAOA,CAAA,GAAIiS,EAAJ,GAASta,IAAA,CAAKoS,GAAL,CAAS/J,CAAT,EAAY,CAAI,GAAA,CAAhB,CAAT,GAA8BA,CAAA,GAAIuR,EAAJ,GAASF,EAA9C,CADwB;AAAA,CAhC5B;AAoCA,SAASgB,OAAT,CAAiBrS,CAAjB,EAA4B;AAAA,IACxB,OAAOA,CAAA,GAAIsR,EAAJ,GAAStR,CAAA,GAAIA,CAAJ,GAAQA,CAAjB,GAAqBuR,EAAA,IAAMvR,CAAA,GAAIqR,EAAJ,CAAlC,CADwB;AAAA,CApC5B;AAwCA,SAASiB,OAAT,CAAiBxL,CAAjB,EAA4B;AAAA,IACxB,OAAO,OAAOA,CAAA,IAAK,SAAL,GAAiB,KAAQA,GAAAA,CAAzB,GAA6B,KAAA,GAAQnP,IAAA,CAAKoS,GAAL,CAASjD,CAAT,EAAY,CAAA,GAAI,GAAhB,CAAR,GAA+B,KAA5D,CAAd,CADwB;AAAA,CAxC5B;AA4CA,SAASyL,OAAT,CAAiBzL,CAAjB,EAA4B;AAAA,IACxBA,CAAA,IAAK,GAAL,CADwB;AAAA,IAExB,OAAOA,CAAA,IAAK,OAAL,GAAeA,CAAA,GAAI,KAAnB,GAA2BnP,IAAA,CAAKoS,GAAL,CAAU,CAAAjD,CAAA,GAAI,KAAJ,IAAa,KAAvB,EAA8B,GAA9B,CAAlC,CAFwB;AAAA,CA5C5B;AAkDA;AAAA,SAAS0L,QAAT,CAAkBC,QAAlB,EAA6C;AAAA,IACzC,MAAMzY,CAAA,GAAIuY,OAAA,CAAQE,QAAA,CAAS3Y,CAAjB,CAAV,EACIG,CAAA,GAAIsY,OAAA,CAAQE,QAAA,CAAS1Y,CAAjB,CADR,EAEIN,CAAA,GAAI8Y,OAAA,CAAQE,QAAA,CAASzY,CAAjB,CAFR,EAGI8M,CAAA,GAAIsL,OAAA,CAAS,CAAA,SAAA,GAAYpY,CAAZ,GAAgB,SAAA,GAAYC,CAA5B,GAAgC,SAAA,GAAYR,CAA5C,IAAiDqY,EAA1D,CAHR,EAII/K,CAAA,GAAIqL,OAAA,CAAS,CAAYpY,SAAAA,GAAAA,CAAZ,GAAgB,SAAYC,GAAAA,CAA5B,GAAgC,QAAA,GAAYR,CAA5C,IAAiDsY,EAA1D,CAJR,EAKI7U,CAAA,GAAIkV,OAAA,CAAS,aAAYpY,CAAZ,GAAgB,QAAYC,GAAAA,CAA5B,GAAgC,SAAYR,GAAAA,CAA5C,IAAiDuY,EAA1D,CALR,CADyC;AAAA,IAQzC,OAAO;AAAA,QACHvY,CAAA,EAAG,GAAMsN,GAAAA,CAAN,GAAU,EADV;AAAA,QAEH9M,CAAA,EAAG,GAAA,IAAO6M,CAAA,GAAIC,CAAJ,CAFP;AAAA,QAGH/M,CAAA,EAAG,GAAA,IAAO+M,CAAA,GAAI7J,CAAJ,CAHP;AAAA,QAIH5D,KAAA,EAAOmZ,QAAA,CAASxY,CAJb;AAAA,KAAP,CARyC;AAAA,CAlD7C;AAkEA,SAASyY,QAAT,CAAkBC,QAAlB,EAA6C;AAAA,IACzC,IAAI5L,CAAA,GAAK,CAAA4L,QAAA,CAASlZ,CAAT,GAAa,EAAb,IAAmB,GAA5B,EACIqN,CAAA,GAAIpB,KAAA,CAAMiN,QAAA,CAAS1Y,CAAf,CAAoB8M,GAAAA,CAApB,GAAwBA,CAAA,GAAI4L,QAAA,CAAS1Y,CAAT,GAAa,GADjD,EAEIiD,CAAA,GAAIwI,KAAA,CAAMiN,QAAA,CAAS3Y,CAAf,CAAoB+M,GAAAA,CAApB,GAAwBA,CAAA,GAAI4L,QAAA,CAAS3Y,CAAT,GAAa,GAFjD,CADyC;AAAA,IAIzC+M,CAAA,GAAIgL,EAAA,GAAKM,OAAA,CAAQtL,CAAR,CAAT,CAJyC;AAAA,IAKzCD,CAAA,GAAIgL,EAAA,GAAKO,OAAA,CAAQvL,CAAR,CAAT,CALyC;AAAA,IAMzC5J,CAAA,GAAI8U,EAAA,GAAKK,OAAA,CAAQnV,CAAR,CAAT,CANyC;AAAA,IAOzC,OAAO,IAAItD,OAAJ,CACH0Y,OAAA,CAAQ,SAAA,GAAYxL,CAAZ,GAAgB,YAAYC,CAA5B,GAAgC,SAAY7J,GAAAA,CAApD,CADG;AAEH,IAAAoV,OAAA,CAAQ,CAAC,QAAD,GAAaxL,CAAb,GAAiB,SAAA,GAAYC,CAA7B,GAAiC,QAAY7J,GAAAA,CAArD,CAFG,EAGHoV,OAAA,CAAQ,SAAA,GAAYxL,CAAZ,GAAgB,SAAYC,GAAAA,CAA5B,GAAgC,SAAA,GAAY7J,CAApD,CAHG,EAIHyV,QAAA,CAASrZ,KAJN,CAAP,CAPyC;AAAA,CAlE7C;AAiFA,SAASsZ,cAAT,CAAwBhB,IAAxB,EAAwCC,EAAxC,EAAsD7R,CAAtD,EAA2E;AAAA,IACvE,OAAO;AAAA,QACHvG,CAAA,EAAGoZ,MAAA,CAAkBjB,IAAA,CAAKnY,CAAvB,EAA0BoY,EAAA,CAAGpY,CAA7B,EAAgCuG,CAAhC,CADA;AAAA,QAEH/F,CAAA,EAAG4Y,MAAA,CAAkBjB,IAAA,CAAK3X,CAAvB,EAA0B4X,EAAA,CAAG5X,CAA7B,EAAgC+F,CAAhC,CAFA;AAAA,QAGHhG,CAAA,EAAG6Y,MAAA,CAAkBjB,IAAA,CAAK5X,CAAvB,EAA0B6X,EAAA,CAAG7X,CAA7B,EAAgCgG,CAAhC,CAHA;AAAA,QAIH1G,KAAA,EAAOuZ,MAAA,CAAkBjB,IAAA,CAAKtY,KAAvB,EAA8BuY,EAAA,CAAGvY,KAAjC,EAAwC0G,CAAxC,CAJJ;AAAA,KAAP,CADuE;AAAA,CAjF3E;AA2FA;AAAA,SAAS8S,QAAT,CAAkBL,QAAlB,EAA6C;AAAA,IACzC,MAAM,CAAChZ,CAAD,EAAIQ,CAAJ,EAAOD,CAAP,CAAA,GAAYwY,QAAA,CAASC,QAAT,CAAlB,CADyC;AAAA,IAEzC,MAAMja,CAAA,GAAIb,IAAA,CAAKob,KAAL,CAAW/Y,CAAX,EAAcC,CAAd,CAAmBkY,GAAAA,OAA7B,CAFyC;AAAA,IAGzC,OAAO;AAAA,QACH3Z,CAAA,EAAGA,CAAA,GAAI,CAAJ,GAAQA,CAAA,GAAI,GAAZ,GAAkBA,CADlB;AAAA,QAEH8M,CAAA,EAAG3N,IAAA,CAAKqb,IAAL,CAAU/Y,CAAA,GAAIA,CAAJ,GAAQD,CAAA,GAAIA,CAAtB,CAFA;AAAA,QAGHP,CAHG;AAAA,QAIHH,KAAA,EAAOmZ,QAAA,CAASxY,CAJb;AAAA,KAAP,CAHyC;AAAA,CA3F7C;AAsGA,SAASgZ,QAAT,CAAkBC,QAAlB,EAA6C;AAAA,IACzC,MAAM1a,CAAA,GAAI0a,QAAA,CAAS1a,CAAT,GAAa0Z,SAAvB,EACI5M,CAAA,GAAI4N,QAAA,CAAS5N,CADjB,EAEI7L,CAAA,GAAIyZ,QAAA,CAASzZ,CAFjB,CADyC;AAAA,IAIzC,OAAOiZ,QAAA,CAAS;AAAA,QACZjZ,CADY;AAAA,QAEZQ,CAAA,EAAGtC,IAAA,CAAKwb,GAAL,CAAS3a,CAAT,IAAc8M,CAFL;AAAA,QAGZtL,CAAA,EAAGrC,IAAA,CAAKyb,GAAL,CAAS5a,CAAT,IAAc8M,CAHL;AAAA,QAIZhM,KAAA,EAAO4Z,QAAA,CAAS5Z,KAJJ;AAAA,KAAT,CAAP,CAJyC;AAAA,CAtG7C;AAkHA,SAAS+Z,cAAT,CAAwBpZ,CAAxB,EAAmCD,CAAnC,EAA8CgG,CAA9C,EAAyD;AAAA,IACrD,MAAM6L,CAAA,GAAI7R,CAAA,GAAIC,CAAd,CADqD;AAAA,IAErD,OAAOA,CAAA,GAAI+F,CAAA,IAAK6L,CAAA,GAAI,GAAJ,IAAWA,CAAA,GAAI,CAAC,GAAhB,GAAsBA,CAAA,GAAI,GAAA,GAAMlU,IAAA,CAAKC,KAAL,CAAWiU,CAAA,GAAI,GAAf,CAAhC,GAAsDA,CAAtD,CAAhB,CAFqD;AAAA,CAlHzD;AAuHA,SAASyH,cAAT,CAAwB1B,IAAxB,EAAwCC,EAAxC,EAAsD7R,CAAtD,EAA2E;AAAA,IACvE,OAAO;AAAA,QACHxH,CAAA,EAAG6a,cAAA,CAAezB,IAAA,CAAKpZ,CAApB,EAAuBqZ,EAAA,CAAGrZ,CAA1B,EAA6BwH,CAA7B,CADA;AAAA,QAEHsF,CAAA,EAAGuN,MAAA,CAAkBjB,IAAA,CAAKtM,CAAvB,EAA0BuM,EAAA,CAAGvM,CAA7B,EAAgCtF,CAAhC,CAFA;AAAA,QAGHvG,CAAA,EAAGoZ,MAAA,CAAkBjB,IAAA,CAAKnY,CAAvB,EAA0BoY,EAAA,CAAGpY,CAA7B,EAAgCuG,CAAhC,CAHA;AAAA,QAIH1G,KAAA,EAAOuZ,MAAA,CAAkBjB,IAAA,CAAKtY,KAAvB,EAA8BuY,EAAA,CAAGvY,KAAjC,EAAwC0G,CAAxC,CAJJ;AAAA,KAAP,CADuE;AAAA,CAvH3E;AAgIO,MAAMuT,GAAA,GAAM;AAAA,IACfC,OAAA,EAAShB,QADM;AAAA,IAEfiB,OAAA,EAASf,QAFM;AAAA,IAGfgB,WAAA,EAAad,cAHE;AAAA,CAAZ,CAhIP;AAsIO,MAAMe,GAAA,GAAM;AAAA,IACfH,OAAA,EAASV,QADM;AAAA,IAEfW,OAAA,EAASR,QAFM;AAAA,IAGfS,WAAA,EAAaJ,cAHE;AAAA,CAAZ;;ACpIP;AAmBA,MAAMM,WAAN,CAAwC;AAAA,IASpC/Z,WAAA,CAAYsC,IAAZ,EAAwB0X,QAAxB,EAAyFC,aAAzF,EAA2H3Z,KAA3H,EAA8IiB,KAA9I,EAA4J;AAAA,QACxJ,IAAKe,CAAAA,IAAL,GAAYA,IAAZ,CADwJ;AAAA,QAExJ,IAAK0X,CAAAA,QAAL,GAAgBA,QAAhB,CAFwJ;AAAA,QAGxJ,IAAKC,CAAAA,aAAL,GAAqBA,aAArB,CAHwJ;AAAA,QAIxJ,IAAK3Z,CAAAA,KAAL,GAAaA,KAAb,CAJwJ;AAAA,QAMxJ,IAAKwV,CAAAA,MAAL,GAAc,EAAd,CANwJ;AAAA,QAOxJ,IAAKC,CAAAA,OAAL,GAAe,EAAf,CAPwJ;AAAA,QAQxJ,KAAA,MAAW,CAACC,KAAD,EAAQtT,UAAR,CAAX,IAAkCnB,KAAlC,EAAyC;AAAA,YACrC,KAAKuU,MAAL,CAAY5S,IAAZ,CAAiB8S,KAAjB,CADqC,CAAA;AAAA,YAErC,KAAKD,OAAL,CAAa7S,IAAb,CAAkBR,UAAlB,CAFqC,CAAA;AAAA,SAR+G;AAAA,KATxH;AAAA,IAuBpC,OAAOwX,mBAAP,CAA2BD,aAA3B,EAA6D3Z,KAA7D,EAA4E6Z,KAA5E,EAA2FC,KAA3F,EAAkH;AAAA,QAC9G,IAAIjU,CAAA,GAAI,CAAR,CAD8G;AAAA,QAE9G,IAAI8T,aAAA,CAAcnV,IAAd,KAAuB,aAA3B,EAA0C;AAAA,YACtCqB,CAAA,GAAIkU,wBAAA,CAAyB/Z,KAAzB,EAAgC2Z,aAAA,CAAcrW,IAA9C,EAAoDuW,KAApD,EAA2DC,KAA3D,CAAJ,CADsC;AAAA,SAA1C,MAEO,IAAIH,aAAA,CAAcnV,IAAd,KAAuB,QAA3B,EAAqC;AAAA,YACxCqB,CAAA,GAAIkU,wBAAA,CAAyB/Z,KAAzB,EAAgC,CAAhC,EAAmC6Z,KAAnC,EAA0CC,KAA1C,CAAJ,CADwC;AAAA,SAArC,MAEA,IAAIH,aAAA,CAAcnV,IAAd,KAAuB,cAA3B,EAA2C;AAAA,YAC9C,MAAM2G,CAAA,GAAIwO,aAAA,CAAcK,aAAxB,CAD8C;AAAA,YAE9C,MAAMC,EAAA,GAAK,IAAIhE,YAAJ,CAAe9K,CAAA,CAAE,CAAF,CAAf,EAAqBA,CAAA,CAAE,CAAF,CAArB,EAA2BA,CAAA,CAAE,CAAF,CAA3B,EAAiCA,CAAA,CAAE,CAAF,CAAjC,CAAX,CAF8C;AAAA,YAG9CtF,CAAA,GAAIoU,EAAA,CAAG1C,KAAH,CAASwC,wBAAA,CAAyB/Z,KAAzB,EAAgC,CAAhC,EAAmC6Z,KAAnC,EAA0CC,KAA1C,CAAT,CAAJ,CAH8C;AAAA,SAN4D;AAAA,QAW9G,OAAOjU,CAAP,CAX8G;AAAA,KAvB9E;AAAA,IAqCpC,OAAO9F,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAAiF;AAAA,QAC7E,IAAI,CAACyQ,QAAD,EAAWC,aAAX,EAA0B3Z,KAA1B,EAAiC,GAAA,IAAjC,CAA4CgJ,GAAAA,IAAhD,CAD6E;AAAA,QAG7E,IAAI,CAAC5C,KAAA,CAAMC,OAAN,CAAcsT,aAAd,CAAD,IAAiCA,aAAA,CAAc7b,MAAd,KAAyB,CAA9D,EAAiE;AAAA,YAC7D,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,0CAAD,CAAd,EAA4D,CAA5D,CAAP,CAD6D;AAAA,SAHY;AAAA,QAO7E,IAAIyQ,aAAA,CAAc,CAAd,CAAA,KAAqB,QAAzB,EAAmC;AAAA,YAC/BA,aAAA,GAAgB,EAACnV,IAAA,EAAM,QAAP,EAAhB,CAD+B;AAAA,SAAnC,MAEO,IAAImV,aAAA,CAAc,CAAd,CAAA,KAAqB,aAAzB,EAAwC;AAAA,YAC3C,MAAMrW,IAAA,GAAOqW,aAAA,CAAc,CAAd,CAAb,CAD2C;AAAA,YAE3C,IAAI,OAAOrW,IAAP,KAAgB,QAApB;AAAA,gBACI,OAAO2F,OAAA,CAAQC,KAAR,CAAc,CAAC,kDAAD,CAAd,EAAoE,CAApE,EAAuE,CAAvE,CAAP,CAHuC;AAAA,YAI3CyQ,aAAA,GAAgB;AAAA,gBACZnV,IAAA,EAAM,aADM;AAAA,gBAEZlB,IAFY;AAAA,aAAhB,CAJ2C;AAAA,SAAxC,MAQA,IAAIqW,aAAA,CAAc,CAAd,CAAA,KAAqB,cAAzB,EAAyC;AAAA,YAC5C,MAAMK,aAAA,GAAgBL,aAAA,CAAcjb,KAAd,CAAoB,CAApB,CAAtB,CAD4C;AAAA,YAE5C,IACIsb,aAAA,CAAclc,MAAd,KAAyB,CAAzB,IACAkc,aAAA,CAAc9T,IAAd,CAAmBL,CAAA,IAAK,OAAOA,CAAP,KAAa,QAAb,IAAyBA,CAAA,GAAI,CAA7B,IAAkCA,CAAA,GAAI,CAA9D,CAFJ,EAGE;AAAA,gBACE,OAAOoD,OAAA,CAAQC,KAAR,CAAc,yFAAd,EAAyG,CAAzG,CAAP,CADF;AAAA,aAL0C;AAAA,YAS5CyQ,aAAA,GAAgB;AAAA,gBACZnV,IAAA,EAAM,cADM;AAAA,gBAEZwV,aAAA,EAAgBA,aAFJ;AAAA,aAAhB,CAT4C;AAAA,SAAzC,MAaA;AAAA,YACH,OAAO/Q,OAAA,CAAQC,KAAR,CAAc,CAAC,2BAAD,GAA8BN,MAAA,CAAO+Q,aAAA,CAAc,CAAd,CAAP,CAA9B,EAAA,CAAd,EAAwE,CAAxE,EAA2E,CAA3E,CAAP,CADG;AAAA,SA9BsE;AAAA,QAkC7E,IAAI3Q,IAAA,CAAKlL,MAAL,GAAc,CAAd,GAAkB,CAAtB,EAAyB;AAAA,YACrB,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,8CAAD,GAAiDF,IAAA,CAAKlL,MAAL,GAAc,CAA/D,EAAiE,CAAjE,CAAd,CAAP,CADqB;AAAA,SAlCoD;AAAA,QAsC7E,IAAK,CAAAkL,IAAA,CAAKlL,MAAL,GAAc,CAAd,IAAmB,CAApB,KAA0B,CAA9B,EAAiC;AAAA,YAC7B,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,qCAAD,CAAd,CAAP,CAD6B;AAAA,SAtC4C;AAAA,QA0C7ElJ,KAAA,GAAQiJ,OAAA,CAAQlJ,KAAR,CAAcC,KAAd,EAAqB,CAArB,EAAwB6E,UAAxB,CAAR,CA1C6E;AAAA,QA2C7E,IAAI,CAAC7E,KAAL;AAAA,YAAY,OAAO,IAAP,CA3CiE;AAAA,QA6C7E,MAAMiB,KAAA,GAAe,EAArB,CA7C6E;AAAA,QA+C7E,IAAI0U,UAAA,GAAoB,IAAxB,CA/C6E;AAAA,QAgD7E,IAAI+D,QAAA,KAAa,iBAAb,IAAkCA,QAAA,KAAa,iBAAnD,EAAsE;AAAA,YAClE/D,UAAA,GAAa3Q,SAAb,CADkE;AAAA,SAAtE,MAEO,IAAIiE,OAAA,CAAQE,YAAR,IAAwBF,OAAA,CAAQE,YAAR,CAAqBvE,IAArB,KAA8B,OAA1D,EAAmE;AAAA,YACtE+Q,UAAA,GAAa1M,OAAA,CAAQE,YAArB,CADsE;AAAA,SAlDG;AAAA,QAsD7E,KAAK,IAAI5L,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAI2c,IAAA,CAAKpc,MAAzB,EAAiCP,CAAA,IAAK,CAAtC,EAAyC;AAAA,YACrC,MAAMmY,KAAA,GAAQwE,IAAA,CAAK3c,CAAL,CAAd,CADqC;AAAA,YAErC,MAAMsD,KAAA,GAAQqZ,IAAA,CAAK3c,CAAA,GAAI,CAAT,CAAd,CAFqC;AAAA,YAIrC,MAAMqY,QAAA,GAAWrY,CAAA,GAAI,CAArB,CAJqC;AAAA,YAKrC,MAAMsY,QAAA,GAAWtY,CAAA,GAAI,CAArB,CALqC;AAAA,YAOrC,IAAI,OAAOmY,KAAP,KAAiB,QAArB,EAA+B;AAAA,gBAC3B,OAAOzM,OAAA,CAAQC,KAAR,CAAc,gJAAd,EAAgK0M,QAAhK,CAAP,CAD2B;AAAA,aAPM;AAAA,YAWrC,IAAI3U,KAAA,CAAMnD,MAAN,IAAgBmD,KAAA,CAAMA,KAAA,CAAMnD,MAAN,GAAe,CAArB,CAAA,CAAwB,CAAxB,CAAA,IAA8B4X,KAAlD,EAAyD;AAAA,gBACrD,OAAOzM,OAAA,CAAQC,KAAR,CAAc,kHAAd,EAAkI0M,QAAlI,CAAP,CADqD;AAAA,aAXpB;AAAA,YAerC,MAAM5L,MAAA,GAASf,OAAA,CAAQlJ,KAAR,CAAcc,KAAd,EAAqBgV,QAArB,EAA+BF,UAA/B,CAAf,CAfqC;AAAA,YAgBrC,IAAI,CAAC3L,MAAL;AAAA,gBAAa,OAAO,IAAP,CAhBwB;AAAA,YAiBrC2L,UAAA,GAAaA,UAAA,IAAc3L,MAAA,CAAOhI,IAAlC,CAjBqC;AAAA,YAkBrCf,KAAA,CAAM2B,IAAN,CAAW;AAAA,gBAAC8S,KAAD;AAAA,gBAAQ1L,MAAR;AAAA,aAAX,CAlBqC,CAAA;AAAA,SAtDoC;AAAA,QA2E7E,IAAI2L,UAAA,CAAW/Q,IAAX,KAAoB,QAApB,IACA+Q,UAAA,CAAW/Q,IAAX,KAAoB,OADpB,IAEA,EACI+Q,UAAA,CAAW/Q,IAAX,KAAoB,OAApB,IACA+Q,UAAA,CAAWnQ,QAAX,CAAoBZ,IAApB,KAA6B,QAD7B,IAEA,OAAO+Q,UAAA,CAAWlQ,CAAlB,KAAwB,QAFxB,CAHR,EAOE;AAAA,YACE,OAAOwD,OAAA,CAAQC,KAAR,CAAc,CAAC,KAAD,GAAQ/I,UAAA,CAASwV,UAAT,CAAR,EAA6B,uBAA7B,CAAd,CAAP,CADF;AAAA,SAlF2E;AAAA,QAsF7E,OAAO,IAAI8D,WAAJ,CAAgB9D,UAAhB,EAA6B+D,QAA7B,EAA6CC,aAA7C,EAA4D3Z,KAA5D,EAAmEiB,KAAnE,CAAP,CAtF6E;AAAA,KArC7C;AAAA,IA8HpCmI,QAAA,CAASa,GAAT,EAAwC;AAAA,QACpC,MAAMuL,MAAA,GAAS,IAAA,CAAKA,MAApB,CADoC;AAAA,QAEpC,MAAMC,OAAA,GAAU,IAAA,CAAKA,OAArB,CAFoC;AAAA,QAIpC,IAAID,MAAA,CAAO1X,MAAP,KAAkB,CAAtB,EAAyB;AAAA,YACrB,OAAO2X,OAAA,CAAQ,CAAR,EAAWrM,QAAX,CAAoBa,GAApB,CAAP,CADqB;AAAA,SAJW;AAAA,QAQpC,MAAMpJ,KAAA,GAAU,IAAKb,CAAAA,KAAL,CAAWoJ,QAAX,CAAoBa,GAApB,CAAhB,CARoC;AAAA,QASpC,IAAIpJ,KAAA,IAAS2U,MAAA,CAAO,CAAP,CAAb,EAAwB;AAAA,YACpB,OAAOC,OAAA,CAAQ,CAAR,EAAWrM,QAAX,CAAoBa,GAApB,CAAP,CADoB;AAAA,SATY;AAAA,QAapC,MAAM6L,SAAA,GAAYN,MAAA,CAAO1X,MAAzB,CAboC;AAAA,QAcpC,IAAI+C,KAAA,IAAS2U,MAAA,CAAOM,SAAA,GAAY,CAAnB,CAAb,EAAoC;AAAA,YAChC,OAAOL,OAAA,CAAQK,SAAA,GAAY,CAApB,CAAA,CAAuB1M,QAAvB,CAAgCa,GAAhC,CAAP,CADgC;AAAA,SAdA;AAAA,QAkBpC,MAAMqK,KAAA,GAAQW,yBAAA,CAA0BO,MAA1B,EAAkC3U,KAAlC,CAAd,CAlBoC;AAAA,QAmBpC,MAAMgZ,KAAA,GAAQrE,MAAA,CAAOlB,KAAP,CAAd,CAnBoC;AAAA,QAoBpC,MAAMwF,KAAA,GAAQtE,MAAA,CAAOlB,KAAA,GAAQ,CAAf,CAAd,CApBoC;AAAA,QAqBpC,MAAMzO,CAAA,GAAI4T,WAAA,CAAYG,mBAAZ,CAAgC,IAAA,CAAKD,aAArC,EAAoD9Y,KAApD,EAA2DgZ,KAA3D,EAAkEC,KAAlE,CAAV,CArBoC;AAAA,QAuBpC,MAAMK,WAAA,GAAc1E,OAAA,CAAQnB,KAAR,CAAA,CAAelL,QAAf,CAAwBa,GAAxB,CAApB,CAvBoC;AAAA,QAwBpC,MAAMmQ,WAAA,GAAc3E,OAAA,CAAQnB,KAAA,GAAQ,CAAhB,CAAmBlL,CAAAA,QAAnB,CAA4Ba,GAA5B,CAApB,CAxBoC;AAAA,QA0BpC,IAAI,IAAA,CAAKyP,QAAL,KAAkB,aAAtB,EAAqC;AAAA,YACjC,OAAQH,WAAA,CAAY,IAAKvX,CAAAA,IAAL,CAAU4C,IAAV,CAAenG,WAAf,EAAZ,CAAD,CAAiD0b,WAAjD,EAA8DC,WAA9D,EAA2EvU,CAA3E,CAAP,CAAA;AADiC,SAArC,MAEO,IAAI,IAAA,CAAK6T,QAAL,KAAkB,iBAAtB,EAAyC;AAAA,YAC5C,OAAOF,GAAA,CAAIF,OAAJ,CAAYE,GAAA,CAAID,WAAJ,CAAgBC,GAAA,CAAIH,OAAJ,CAAYc,WAAZ,CAAhB,EAA0CX,GAAA,CAAIH,OAAJ,CAAYe,WAAZ,CAA1C,EAAoEvU,CAApE,CAAZ,CAAP,CAD4C;AAAA,SAAzC,MAEA;AAAA,YACH,OAAOuT,GAAA,CAAIE,OAAJ,CAAYF,GAAA,CAAIG,WAAJ,CAAgBH,GAAA,CAAIC,OAAJ,CAAYc,WAAZ,CAAhB,EAA0Cf,GAAA,CAAIC,OAAJ,CAAYe,WAAZ,CAA1C,EAAoEvU,CAApE,CAAZ,CAAP,CADG;AAAA,SA9B6B;AAAA,KA9HJ;AAAA,IAiKpCwD,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnCA,EAAA,CAAG,IAAKlK,CAAAA,KAAR,CADmC,CAAA;AAAA,QAEnC,KAAWoC,MAAAA,UAAX,IAAyB,IAAA,CAAKqT,OAA9B,EAAuC;AAAA,YACnCvL,EAAA,CAAG9H,UAAH,CADmC,CAAA;AAAA,SAFJ;AAAA,KAjKH;AAAA,IAwKpCkH,aAAA,GAAyB;AAAA,QACrB,OAAO,IAAA,CAAKmM,OAAL,CAAarL,KAAb,CAAmB2L,GAAA,IAAOA,GAAA,CAAIzM,aAAJ,EAA1B,CAAP,CADqB;AAAA,KAxKW;AAAA,IA4KpCpB,SAAA,GAAkC;AAAA,QAC9B,IAAIyR,aAAJ,CAD8B;AAAA,QAE9B,IAAI,IAAKA,CAAAA,aAAL,CAAmBnV,IAAnB,KAA4B,QAAhC,EAA0C;AAAA,YACtCmV,aAAA,GAAgB,CAAC,QAAD,CAAhB,CADsC;AAAA,SAA1C,MAEO,IAAI,IAAKA,CAAAA,aAAL,CAAmBnV,IAAnB,KAA4B,aAAhC,EAA+C;AAAA,YAClD,IAAK,IAAKmV,CAAAA,aAAL,CAAmBrW,IAAnB,KAA4B,CAAjC,EAAoC;AAAA,gBAChCqW,aAAA,GAAgB,CAAC,QAAD,CAAhB,CADgC;AAAA,aAApC,MAEO;AAAA,gBACHA,aAAA,GAAgB;AAAA,oBAAC,aAAD;AAAA,oBAAgB,IAAA,CAAKA,aAAL,CAAmBrW,IAAnC;AAAA,iBAAhB,CADG;AAAA,aAH2C;AAAA,SAA/C,MAMA;AAAA,YACHqW,aAAA,GAAgB,CAAC,cAAD,CAAkBlV,CAAAA,MAAlB,CAAyB,IAAA,CAAKkV,aAAL,CAAmBK,aAA5C,CAAhB,CADG;AAAA,SAVuB;AAAA,QAc9B,MAAM7R,UAAA,GAAa;AAAA,YAAC,KAAKuR,QAAN;AAAA,YAAgBC,aAAhB;AAAA,YAA+B,IAAK3Z,CAAAA,KAAL,CAAWkI,SAAX,EAA/B;AAAA,SAAnB,CAd8B;AAAA,QAgB9B,KAAK,IAAI3K,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAI,IAAA,CAAKiY,MAAL,CAAY1X,MAAhC,EAAwCP,CAAA,EAAxC,EAA6C;AAAA,YACzC4K,UAAA,CAAWvF,IAAX,CACI,IAAA,CAAK4S,MAAL,CAAYjY,CAAZ,CADJ,EAEI,KAAKkY,OAAL,CAAalY,CAAb,CAAgB2K,CAAAA,SAAhB,EAFJ,CADyC,CAAA;AAAA,SAhBf;AAAA,QAsB9B,OAAOC,UAAP,CAtB8B;AAAA,KA5KE;AAAA,CArBxC;AA8PA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAAS4R,wBAAT,CAAkC/Z,KAAlC,EAAyCsD,IAAzC,EAA+C+W,UAA/C,EAA2DC,UAA3D,EAAuE;AAAA,IACnE,MAAMC,UAAA,GAAaD,UAAA,GAAaD,UAAhC,CADmE;AAAA,IAEnE,MAAMG,QAAA,GAAWxa,KAAA,GAAQqa,UAAzB,CAFmE;AAAA,IAInE,IAAIE,UAAA,KAAe,CAAnB,EAAsB;AAAA,QAClB,OAAO,CAAP,CADkB;AAAA,KAAtB,MAEO,IAAIjX,IAAA,KAAS,CAAb,EAAgB;AAAA,QACnB,OAAOkX,QAAA,GAAWD,UAAlB,CADmB;AAAA,KAAhB,MAEA;AAAA,QACH,OAAQ,CAAA/c,IAAA,CAAKoS,GAAL,CAAStM,IAAT,EAAekX,QAAf,CAAA,GAA2B,CAA3B,KAAiChd,IAAA,CAAKoS,GAAL,CAAStM,IAAT,EAAeiX,UAAf,CAAA,GAA6B,CAA7B,CAAzC,CADG;AAAA,KAR4D;AAAA,CA9PvE;AA2QA,oBAAA,WAAA;;AC/PA,MAAME,QAAN,CAAqC;AAAA,IAIjC/a,WAAA,CAAYsC,IAAZ,EAAwBgH,IAAxB,EAAiD;AAAA,QAC7C,IAAKhH,CAAAA,IAAL,GAAYA,IAAZ,CAD6C;AAAA,QAE7C,IAAKgH,CAAAA,IAAL,GAAYA,IAAZ,CAF6C;AAAA,KAJhB;AAAA,IASjC,OAAOjJ,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAA8E;AAAA,QAC1E,IAAID,IAAA,CAAKlL,MAAL,GAAc,CAAlB,EAAqB;AAAA,YACjB,OAAOmL,OAAA,CAAQC,KAAR,CAAc,oCAAd,CAAP,CADiB;AAAA,SADqD;AAAA,QAI1E,IAAIyM,UAAA,GAAoB,IAAxB,CAJ0E;AAAA,QAK1E,MAAMxM,YAAA,GAAeF,OAAA,CAAQE,YAA7B,CAL0E;AAAA,QAM1E,IAAIA,YAAA,IAAgBA,YAAA,CAAavE,IAAb,KAAsB,OAA1C,EAAmD;AAAA,YAC/C+Q,UAAA,GAAaxM,YAAb,CAD+C;AAAA,SANuB;AAAA,QAS1E,MAAM8E,UAAA,GAAa,EAAnB,CAT0E;AAAA,QAW1E,KAAA,MAAW5D,GAAX,IAAkBrB,IAAA,CAAKtK,KAAL,CAAW,CAAX,CAAlB,EAAiC;AAAA,YAC7B,MAAMsL,MAAA,GAASf,OAAA,CAAQlJ,KAAR,CAAcsK,GAAd,EAAmB,CAAA,GAAI4D,UAAA,CAAWnQ,MAAlC,EAA0C6X,UAA1C,EAAsD1V,SAAtD,EAAiE,EAACwU,cAAA,EAAgB,MAAjB,EAAjE,CAAf,CAD6B;AAAA,YAE7B,IAAI,CAACzK,MAAL;AAAA,gBAAa,OAAO,IAAP,CAFgB;AAAA,YAG7B2L,UAAA,GAAaA,UAAA,IAAc3L,MAAA,CAAOhI,IAAlC,CAH6B;AAAA,YAI7BiM,UAAA,CAAWrL,IAAX,CAAgBoH,MAAhB,CAJ6B,CAAA;AAAA,SAXyC;AAAA;AAwB1E;AAAA;AAAA;AAAA;AAAA,QAAA,MAAM0Q,eAAA,GAAkBvR,YAAA,IACpB8E,UAAA,CAAW/H,IAAX,CAAgBmE,GAAA,IAAO1E,YAAA,CAAawD,YAAb,EAA2BkB,GAAA,CAAIrI,IAA/B,CAAvB,CADJ,CAxB0E;AAAA,QA2B1E,OAAO0Y,eAAA,GACH,IAAID,QAAJ,CAAavV,SAAb,EAAwB+I,UAAxB,CADG,GAEH,IAAIwM,QAAJ,CAAc9E,UAAd,EAAgC1H,UAAhC,CAFJ,CA3B0E;AAAA,KAT7C;AAAA,IAyCjC7E,QAAA,CAASa,GAAT,EAA6C;AAAA,QACzC,IAAItG,MAAA,GAAS,IAAb,CADyC;AAAA,QAEzC,IAAIgX,QAAA,GAAW,CAAf,CAFyC;AAAA,QAGzC,IAAIC,UAAJ,CAHyC;AAAA,QAIzC,KAAWvQ,MAAAA,GAAX,IAAkB,IAAA,CAAKrB,IAAvB,EAA6B;AAAA,YACzB2R,QAAA,EADyB,CAAA;AAAA,YAEzBhX,MAAA,GAAS0G,GAAA,CAAIjB,QAAJ,CAAaa,GAAb,CAAT,CAFyB;AAAA;AAKzB;AAAA,YAAItG,IAAAA,MAAA,IAAUA,MAAA,YAAkB0E,aAA5B,IAA6C,CAAC1E,MAAA,CAAO2E,SAAzD,EAAoE;AAAA;AAEhE,gBAAI,IAAA,CAACsS,UAAL,EAAiB;AAAA,oBACbA,UAAA,GAAajX,MAAb,CADa;AAAA,iBAF+C;AAAA,gBAKhEA,MAAA,GAAS,IAAT,CALgE;AAAA;AAOhE,gBAAA,IAAIgX,QAAA,KAAa,IAAA,CAAK3R,IAAL,CAAUlL,MAA3B,EAAmC;AAAA,oBAC/B,OAAO8c,UAAP,CAD+B;AAAA,iBAP6B;AAAA,aAL3C;AAAA,YAiBzB,IAAIjX,MAAA,KAAW,IAAf;AAAA,gBAAqB,MAjBI;AAAA,SAJY;AAAA,QAuBzC,OAAOA,MAAP,CAvByC;AAAA,KAzCZ;AAAA,IAmEjC0F,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnC,KAAKlB,IAAL,CAAUmB,OAAV,CAAkBD,EAAlB,CADmC,CAAA;AAAA,KAnEN;AAAA,IAuEjCZ,aAAA,GAAyB;AAAA,QACrB,OAAO,IAAA,CAAKN,IAAL,CAAUoB,KAAV,CAAgBC,GAAA,IAAOA,GAAA,CAAIf,aAAJ,EAAvB,CAAP,CADqB;AAAA,KAvEQ;AAAA,IA2EjCpB,SAAA,GAAkC;AAAA,QAC9B,MAAMC,UAAA,GAAa,CAAC,UAAD,CAAnB,CAD8B;AAAA,QAE9B,IAAKkB,CAAAA,SAAL,CAAeoC,KAAA,IAAS;AAAA,YAAEtD,UAAA,CAAWvF,IAAX,CAAgB6I,KAAA,CAAMvD,SAAN,EAAhB,CAAF,CAAA;AAAA,SAAxB,CAF8B,CAAA;AAAA,QAG9B,OAAOC,UAAP,CAH8B;AAAA,KA3ED;AAAA,CAZrC;AA8FA,iBAAA,QAAA;;ACvFA;AAAA,MAAM0S,GAAN,CAAgC;AAAA,IAK5Bnb,WAAA,CAAY6E,QAAZ,EAAmDZ,MAAnD,EAAuE;AAAA,QACnE,KAAK3B,IAAL,GAAY2B,MAAA,CAAO3B,IAAnB,CADmE;AAAA,QAEnE,IAAA,CAAKuC,QAAL,GAAgB,EAAA,CAAGE,MAAH,CAAUF,QAAV,CAAhB,CAFmE;AAAA,QAGnE,IAAKZ,CAAAA,MAAL,GAAcA,MAAd,CAHmE;AAAA,KAL3C;AAAA,IAW5ByF,QAAA,CAASa,GAAT,EAAsC;AAAA,QAClC,OAAO,KAAKtG,MAAL,CAAYyF,QAAZ,CAAqBa,GAArB,CAAP,CADkC;AAAA,KAXV;AAAA,IAe5BZ,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnC,KAAW4Q,MAAAA,OAAX,IAAsB,IAAA,CAAKvW,QAA3B,EAAqC;AAAA,YACjC2F,EAAA,CAAG4Q,OAAA,CAAQ,CAAR,CAAH,CADiC,CAAA;AAAA,SADF;AAAA,QAInC5Q,EAAA,CAAG,IAAKvG,CAAAA,MAAR,CAJmC,CAAA;AAAA,KAfX;AAAA,IAsB5B,OAAO5D,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAAyE;AAAA,QACrE,IAAID,IAAA,CAAKlL,MAAL,GAAc,CAAlB;AAAA,YACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,yCAAD,GAA4CF,IAAA,CAAKlL,MAAL,GAAc,CAA1D,EAA4D,SAA5D,CAAd,CAAP,CAFiE;AAAA,QAIrE,MAAMyG,QAAA,GAAwC,EAA9C,CAJqE;AAAA,QAKrE,KAAK,IAAIhH,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIyL,IAAA,CAAKlL,MAAL,GAAc,CAAlC,EAAqCP,CAAA,IAAK,CAA1C,EAA6C;AAAA,YACzC,MAAMiH,IAAA,GAAOwE,IAAA,CAAKzL,CAAL,CAAb,CADyC;AAAA,YAGzC,IAAI,OAAOiH,IAAP,KAAgB,QAApB,EAA8B;AAAA,gBAC1B,OAAOyE,OAAA,CAAQC,KAAR,CAAc,CAAC,2BAAD,GAA8B,OAAO1E,IAArC,EAA0C,SAA1C,CAAd,EAAoEjH,CAApE,CAAP,CAD0B;AAAA,aAHW;AAAA,YAOzC,IAAI,eAAgBwW,CAAAA,IAAhB,CAAqBvP,IAArB,CAAJ,EAAgC;AAAA,gBAC5B,OAAOyE,OAAA,CAAQC,KAAR,CAAc,CAAC,gEAAD,CAAd,EAAkF3L,CAAlF,CAAP,CAD4B;AAAA,aAPS;AAAA,YAWzC,MAAMsD,KAAA,GAAQoI,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAKzL,CAAA,GAAI,CAAT,CAAd,EAA2BA,CAAA,GAAI,CAA/B,CAAd,CAXyC;AAAA,YAYzC,IAAI,CAACsD,KAAL;AAAA,gBAAY,OAAO,IAAP,CAZ6B;AAAA,YAczC0D,QAAA,CAAS3B,IAAT,CAAc;AAAA,gBAAC4B,IAAD;AAAA,gBAAO3D,KAAP;AAAA,aAAd,CAdyC,CAAA;AAAA,SALwB;AAAA,QAsBrE,MAAM8C,MAAA,GAASsF,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAKA,IAAA,CAAKlL,MAAL,GAAc,CAAnB,CAAd,EAAqCkL,IAAA,CAAKlL,MAAL,GAAc,CAAnD,EAAsDmL,OAAA,CAAQE,YAA9D,EAA4E5E,QAA5E,CAAf,CAtBqE;AAAA,QAuBrE,IAAI,CAACZ,MAAL;AAAA,YAAa,OAAO,IAAP,CAvBwD;AAAA,QAyBrE,OAAO,IAAIkX,GAAJ,CAAQtW,QAAR,EAAkBZ,MAAlB,CAAP,CAzBqE;AAAA,KAtB7C;AAAA,IAkD5B2F,aAAA,GAAyB;AAAA,QACrB,OAAO,IAAK3F,CAAAA,MAAL,CAAY2F,aAAZ,EAAP,CADqB;AAAA,KAlDG;AAAA,IAsD5BpB,SAAA,GAAkC;AAAA,QAC9B,MAAMC,UAAA,GAAa,CAAC,KAAD,CAAnB,CAD8B;AAAA,QAE9B,KAAA,MAAW,CAAC3D,IAAD,EAAO6P,IAAP,CAAX,IAA2B,IAAK9P,CAAAA,QAAhC,EAA0C;AAAA,YACtC4D,UAAA,CAAWvF,IAAX,CAAgB4B,IAAhB,EAAsB6P,IAAA,CAAKnM,SAAL,EAAtB,CADsC,CAAA;AAAA,SAFZ;AAAA,QAK9BC,UAAA,CAAWvF,IAAX,CAAgB,KAAKe,MAAL,CAAYuE,SAAZ,EAAhB,CAL8B,CAAA;AAAA,QAM9B,OAAOC,UAAP,CAN8B;AAAA,KAtDN;AAAA,CAPhC;AAuEA,YAAA,GAAA;;ACrEA;AAUA,MAAM4S,EAAN,CAA+B;AAAA,IAK3Brb,WAAA,CAAYsC,IAAZ,EAAwBsS,KAAxB,EAA2CtU,KAA3C,EAA8D;AAAA,QAC1D,IAAKgC,CAAAA,IAAL,GAAYA,IAAZ,CAD0D;AAAA,QAE1D,IAAKsS,CAAAA,KAAL,GAAaA,KAAb,CAF0D;AAAA,QAG1D,IAAKtU,CAAAA,KAAL,GAAaA,KAAb,CAH0D;AAAA,KALnC;AAAA,IAW3B,OAAOD,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAAwE;AAAA,QACpE,IAAID,IAAA,CAAKlL,MAAL,KAAgB,CAApB;AAAA,YACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,gCAAD,GAAmCF,IAAA,CAAKlL,MAAL,GAAc,CAAjD,EAAmD,SAAnD,CAAd,CAAP,CAFgE;AAAA,QAIpE,MAAMwW,KAAA,GAAQrL,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0BnE,UAA1B,CAAd,CAJoE;AAAA,QAKpE,MAAM7E,KAAA,GAAQiJ,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0BzD,OAAA,CAAM0D,OAAA,CAAQE,YAAR,IAAwBjE,SAA9B,CAA1B,CAAd,CALoE;AAAA,QAOpE,IAAI,CAACoP,KAAD,IAAU,CAACtU,KAAf;AAAA,YAAsB,OAAO,IAAP,CAP8C;AAAA,QASpE,MAAM6F,CAAA,GAAgB7F,KAAA,CAAMgC,IAA5B,CAToE;AAAA,QAUpE,OAAO,IAAI+Y,EAAJ,CAAOlV,CAAA,CAAEL,QAAT,EAAmB8O,KAAnB,EAA0BtU,KAA1B,CAAP,CAVoE;AAAA,KAX7C;AAAA,IAwB3BoJ,QAAA,CAASa,GAAT,EAAwC;AAAA,QACpC,MAAMqK,KAAA,GAAU,IAAKA,CAAAA,KAAL,CAAWlL,QAAX,CAAoBa,GAApB,CAAhB,CADoC;AAAA,QAEpC,MAAM1E,KAAA,GAAU,IAAKvF,CAAAA,KAAL,CAAWoJ,QAAX,CAAoBa,GAApB,CAAhB,CAFoC;AAAA,QAIpC,IAAIqK,KAAA,GAAQ,CAAZ,EAAe;AAAA,YACX,MAAM,IAAI/K,cAAJ,CAAiB,CAAC,2BAAD,GAA8B+K,KAA9B,EAAoC,KAApC,CAAjB,CAAN,CADW;AAAA,SAJqB;AAAA,QAQpC,IAAIA,KAAA,IAAS/O,KAAA,CAAMzH,MAAnB,EAA2B;AAAA,YACvB,MAAM,IAAIyL,cAAJ,CAAiB,CAAC,2BAAD,GAA8B+K,KAA9B,EAAoC,GAApC,GAAyC/O,KAAA,CAAMzH,MAAN,GAAe,CAAxD,EAA0D,CAA1D,CAAjB,CAAN,CADuB;AAAA,SARS;AAAA,QAYpC,IAAIwW,KAAA,KAAU9W,IAAA,CAAKuM,KAAL,CAAWuK,KAAX,CAAd,EAAiC;AAAA,YAC7B,MAAM,IAAI/K,cAAJ,CAAiB,CAAC,0CAAD,GAA6C+K,KAA7C,EAAmD,SAAnD,CAAjB,CAAN,CAD6B;AAAA,SAZG;AAAA,QAgBpC,OAAO/O,KAAA,CAAM+O,KAAN,CAAP,CAhBoC;AAAA,KAxBb;AAAA,IA2C3BjL,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnCA,EAAA,CAAG,IAAKoK,CAAAA,KAAR,CADmC,CAAA;AAAA,QAEnCpK,EAAA,CAAG,IAAKlK,CAAAA,KAAR,CAFmC,CAAA;AAAA,KA3CZ;AAAA,IAgD3BsJ,aAAA,GAAyB;AAAA,QACrB,OAAO,KAAP,CADqB;AAAA,KAhDE;AAAA,IAoD3BpB,SAAA,GAAkC;AAAA,QAC9B,OAAO;AAAA,YAAC,IAAD;AAAA,YAAO,IAAKoM,CAAAA,KAAL,CAAWpM,SAAX,EAAP;AAAA,YAA+B,IAAKlI,CAAAA,KAAL,CAAWkI,SAAX,EAA/B;AAAA,SAAP,CAD8B;AAAA,KApDP;AAAA,CAZ/B;AAqEA,WAAA,EAAA;;ACnEA;AASA,MAAM8S,EAAN,CAA+B;AAAA,IAK3Btb,WAAA,CAAYub,MAAZ,EAAgCC,QAAhC,EAAsD;AAAA,QAClD,IAAKlZ,CAAAA,IAAL,GAAY+C,WAAZ,CADkD;AAAA,QAElD,IAAKkW,CAAAA,MAAL,GAAcA,MAAd,CAFkD;AAAA,QAGlD,IAAKC,CAAAA,QAAL,GAAgBA,QAAhB,CAHkD;AAAA,KAL3B;AAAA,IAW3B,OAAOnb,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAAwE;AAAA,QACpE,IAAID,IAAA,CAAKlL,MAAL,KAAgB,CAApB,EAAuB;AAAA,YACnB,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,gCAAD,GAAmCF,IAAA,CAAKlL,MAAL,GAAc,CAAjD,EAAmD,SAAnD,CAAd,CAAP,CADmB;AAAA,SAD6C;AAAA,QAKpE,MAAMmd,MAAA,GAAShS,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0B9D,SAA1B,CAAf,CALoE;AAAA,QAOpE,MAAMgW,QAAA,GAAWjS,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0B9D,SAA1B,CAAjB,CAPoE;AAAA,QASpE,IAAI,CAAC+V,MAAD,IAAW,CAACC,QAAhB;AAAA,YAA0B,OAAO,IAAP,CAT0C;AAAA,QAWpE,IAAI,CAACnV,WAAA,CAAYkV,MAAA,CAAOjZ,IAAnB,EAAyB;AAAA,gBAAC+C,WAAD;AAAA,gBAAcD,UAAd;AAAA,gBAA0BD,UAA1B;AAAA,gBAAsCF,QAAtC;AAAA,gBAAgDO,SAAhD;AAAA,aAAzB,CAAL,EAA2F;AAAA,YACvF,OAAO+D,OAAA,CAAQC,KAAR,CAAc,CAAC,iFAAD,GAAoF/I,UAAA,CAAS8a,MAAA,CAAOjZ,IAAhB,CAApF,EAA0G,QAA1G,CAAd,CAAP,CADuF;AAAA,SAXvB;AAAA,QAepE,OAAO,IAAIgZ,EAAJ,CAAOC,MAAP,EAAeC,QAAf,CAAP,CAfoE;AAAA,KAX7C;AAAA,IA6B3B9R,QAAA,CAASa,GAAT,EAA0C;AAAA,QACtC,MAAMgR,MAAA,GAAU,IAAKA,CAAAA,MAAL,CAAY7R,QAAZ,CAAqBa,GAArB,CAAhB,CADsC;AAAA,QAEtC,MAAMiR,QAAA,GAAY,IAAKA,CAAAA,QAAL,CAAc9R,QAAd,CAAuBa,GAAvB,CAAlB,CAFsC;AAAA,QAItC,IAAIiR,QAAA,IAAY,IAAhB;AAAA,YAAsB,OAAO,KAAP,CAJgB;AAAA,QAMtC,IAAI,CAAC/U,iBAAA,CAAkB8U,MAAlB,EAA0B;AAAA,gBAAC,SAAD;AAAA,gBAAY,QAAZ;AAAA,gBAAsB,QAAtB;AAAA,gBAAgC,MAAhC;AAAA,aAA1B,CAAL,EAAyE;AAAA,YACrE,MAAM,IAAI1R,cAAJ,CAAiB,CAAC,iFAAD,GAAoFpJ,UAAA,CAASwI,MAAA,CAAOsS,MAAP,CAAT,CAApF,EAA6G,SAA7G,CAAjB,CAAN,CADqE;AAAA,SANnC;AAAA,QAUtC,IAAI,CAAC9U,iBAAA,CAAkB+U,QAAlB,EAA4B;AAAA,gBAAC,QAAD;AAAA,gBAAW,OAAX;AAAA,aAA5B,CAAL,EAAuD;AAAA,YACnD,MAAM,IAAI3R,cAAJ,CAAiB,CAAC,kEAAD,GAAqEpJ,UAAA,CAASwI,MAAA,CAAOuS,QAAP,CAAT,CAArE,EAAgG,SAAhG,CAAjB,CAAN,CADmD;AAAA,SAVjB;AAAA,QActC,OAAOA,QAAA,CAASpc,OAAT,CAAiBmc,MAAjB,CAAA,IAA4B,CAAnC,CAdsC;AAAA,KA7Bf;AAAA,IA8C3B5R,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnCA,EAAA,CAAG,IAAK+Q,CAAAA,MAAR,CADmC,CAAA;AAAA,QAEnC/Q,EAAA,CAAG,IAAKgR,CAAAA,QAAR,CAFmC,CAAA;AAAA,KA9CZ;AAAA,IAmD3B5R,aAAA,GAAyB;AAAA,QACrB,OAAO,IAAP,CADqB;AAAA,KAnDE;AAAA,IAuD3BpB,SAAA,GAAkC;AAAA,QAC9B,OAAO;AAAA,YAAC,IAAD;AAAA,YAAO,IAAK+S,CAAAA,MAAL,CAAY/S,SAAZ,EAAP;AAAA,YAAgC,IAAKgT,CAAAA,QAAL,CAAchT,SAAd,EAAhC;AAAA,SAAP,CAD8B;AAAA,KAvDP;AAAA,CAX/B;AAuEA,WAAA,EAAA;;ACrEA;AASA,MAAMiT,OAAN,CAAoC;AAAA,IAMhCzb,WAAA,CAAYub,MAAZ,EAAgCC,QAAhC,EAAsDE,SAAtD,EAA8E;AAAA,QAC1E,IAAKpZ,CAAAA,IAAL,GAAY6C,UAAZ,CAD0E;AAAA,QAE1E,IAAKoW,CAAAA,MAAL,GAAcA,MAAd,CAF0E;AAAA,QAG1E,IAAKC,CAAAA,QAAL,GAAgBA,QAAhB,CAH0E;AAAA,QAI1E,IAAKE,CAAAA,SAAL,GAAiBA,SAAjB,CAJ0E;AAAA,KAN9C;AAAA,IAahC,OAAOrb,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAA6E;AAAA,QACzE,IAAID,IAAA,CAAKlL,MAAL,IAAe,CAAf,IAAqBkL,IAAA,CAAKlL,MAAL,IAAe,CAAxC,EAA2C;AAAA,YACvC,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,qCAAD,GAAwCF,IAAA,CAAKlL,MAAL,GAAc,CAAtD,EAAwD,SAAxD,CAAd,CAAP,CADuC;AAAA,SAD8B;AAAA,QAKzE,MAAMmd,MAAA,GAAShS,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0B9D,SAA1B,CAAf,CALyE;AAAA,QAOzE,MAAMgW,QAAA,GAAWjS,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0B9D,SAA1B,CAAjB,CAPyE;AAAA,QASzE,IAAI,CAAC+V,MAAD,IAAW,CAACC,QAAhB;AAAA,YAA0B,OAAO,IAAP,CAT+C;AAAA,QAUzE,IAAI,CAACnV,WAAA,CAAYkV,MAAA,CAAOjZ,IAAnB,EAAyB;AAAA,gBAAC+C,WAAD;AAAA,gBAAcD,UAAd;AAAA,gBAA0BD,UAA1B;AAAA,gBAAsCF,QAAtC;AAAA,gBAAgDO,SAAhD;AAAA,aAAzB,CAAL,EAA2F;AAAA,YACvF,OAAO+D,OAAA,CAAQC,KAAR,CAAc,CAAC,iFAAD,GAAoF/I,UAAA,CAAS8a,MAAA,CAAOjZ,IAAhB,CAApF,EAA0G,QAA1G,CAAd,CAAP,CADuF;AAAA,SAVlB;AAAA,QAczE,IAAIgH,IAAA,CAAKlL,MAAL,KAAgB,CAApB,EAAuB;AAAA,YACnB,MAAMsd,SAAA,GAAYnS,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0BnE,UAA1B,CAAlB,CADmB;AAAA,YAEnB,IAAI,CAACuW,SAAL;AAAA,gBAAgB,OAAO,IAAP,CAFG;AAAA,YAGnB,OAAO,IAAID,OAAJ,CAAYF,MAAZ,EAAoBC,QAApB,EAA8BE,SAA9B,CAAP,CAHmB;AAAA,SAAvB,MAIO;AAAA,YACH,OAAO,IAAID,OAAJ,CAAYF,MAAZ,EAAoBC,QAApB,CAAP,CADG;AAAA,SAlBkE;AAAA,KAb7C;AAAA,IAoChC9R,QAAA,CAASa,GAAT,EAAsC;AAAA,QAClC,MAAMgR,MAAA,GAAU,IAAKA,CAAAA,MAAL,CAAY7R,QAAZ,CAAqBa,GAArB,CAAhB,CADkC;AAAA,QAElC,MAAMiR,QAAA,GAAY,IAAKA,CAAAA,QAAL,CAAc9R,QAAd,CAAuBa,GAAvB,CAAlB,CAFkC;AAAA,QAIlC,IAAI,CAAC9D,iBAAA,CAAkB8U,MAAlB,EAA0B;AAAA,gBAAC,SAAD;AAAA,gBAAY,QAAZ;AAAA,gBAAsB,QAAtB;AAAA,gBAAgC,MAAhC;AAAA,aAA1B,CAAL,EAAyE;AAAA,YACrE,MAAM,IAAI1R,cAAJ,CAAiB,CAAC,iFAAD,GAAoFpJ,UAAA,CAASwI,MAAA,CAAOsS,MAAP,CAAT,CAApF,EAA6G,SAA7G,CAAjB,CAAN,CADqE;AAAA,SAJvC;AAAA,QAQlC,IAAI,CAAC9U,iBAAA,CAAkB+U,QAAlB,EAA4B;AAAA,gBAAC,QAAD;AAAA,gBAAW,OAAX;AAAA,aAA5B,CAAL,EAAuD;AAAA,YACnD,MAAM,IAAI3R,cAAJ,CAAiB,CAAC,kEAAD,GAAqEpJ,UAAA,CAASwI,MAAA,CAAOuS,QAAP,CAAT,CAArE,EAAgG,SAAhG,CAAjB,CAAN,CADmD;AAAA,SARrB;AAAA,QAYlC,IAAI,IAAKE,CAAAA,SAAT,EAAoB;AAAA,YAChB,MAAMA,SAAA,GAAa,IAAKA,CAAAA,SAAL,CAAehS,QAAf,CAAwBa,GAAxB,CAAnB,CADgB;AAAA,YAEhB,OAAOiR,QAAA,CAASpc,OAAT,CAAiBmc,MAAjB,EAAyBG,SAAzB,CAAP,CAFgB;AAAA,SAZc;AAAA,QAiBlC,OAAOF,QAAA,CAASpc,OAAT,CAAiBmc,MAAjB,CAAP,CAjBkC;AAAA,KApCN;AAAA,IAwDhC5R,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnCA,EAAA,CAAG,IAAK+Q,CAAAA,MAAR,CADmC,CAAA;AAAA,QAEnC/Q,EAAA,CAAG,IAAKgR,CAAAA,QAAR,CAFmC,CAAA;AAAA,QAGnC,IAAI,IAAKE,CAAAA,SAAT,EAAoB;AAAA,YAChBlR,EAAA,CAAG,IAAKkR,CAAAA,SAAR,CADgB,CAAA;AAAA,SAHe;AAAA,KAxDP;AAAA,IAgEhC9R,aAAA,GAAyB;AAAA,QACrB,OAAO,KAAP,CADqB;AAAA,KAhEO;AAAA,IAoEhCpB,SAAA,GAAkC;AAAA,QAC9B,IAAI,IAAKkT,CAAAA,SAAL,IAAkB,IAAlB,IAA0B,IAAKA,CAAAA,SAAL,KAAmBnb,SAAjD,EAA4D;AAAA,YACxD,MAAMmb,SAAA,GAAY,IAAA,CAAKA,SAAL,CAAelT,SAAf,EAAlB,CADwD;AAAA,YAExD,OAAO;AAAA,gBAAC,UAAD;AAAA,gBAAa,IAAK+S,CAAAA,MAAL,CAAY/S,SAAZ,EAAb;AAAA,gBAAsC,IAAKgT,CAAAA,QAAL,CAAchT,SAAd,EAAtC;AAAA,gBAAiEkT,SAAjE;AAAA,aAAP,CAFwD;AAAA,SAD9B;AAAA,QAK9B,OAAO;AAAA,YAAC,UAAD;AAAA,YAAa,IAAKH,CAAAA,MAAL,CAAY/S,SAAZ,EAAb;AAAA,YAAsC,IAAKgT,CAAAA,QAAL,CAAchT,SAAd,EAAtC;AAAA,SAAP,CAL8B;AAAA,KApEF;AAAA,CAXpC;AAwFA,gBAAA,OAAA;;AC1EA;AAAA,MAAMmT,KAAN,CAAkC;AAAA,IAS9B3b,WAAA,CAAY4b,SAAZ,EAA6B3F,UAA7B,EAA+C3V,KAA/C,EAAkEub,KAAlE,EAAgF9F,OAAhF,EAA4G+F,SAA5G,EAAmI;AAAA,QAC/H,IAAKF,CAAAA,SAAL,GAAiBA,SAAjB,CAD+H;AAAA,QAE/H,IAAKtZ,CAAAA,IAAL,GAAY2T,UAAZ,CAF+H;AAAA,QAG/H,IAAK3V,CAAAA,KAAL,GAAaA,KAAb,CAH+H;AAAA,QAI/H,IAAKub,CAAAA,KAAL,GAAaA,KAAb,CAJ+H;AAAA,QAK/H,IAAK9F,CAAAA,OAAL,GAAeA,OAAf,CAL+H;AAAA,QAM/H,IAAK+F,CAAAA,SAAL,GAAiBA,SAAjB,CAN+H;AAAA,KATrG;AAAA,IAkB9B,OAAOzb,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAA2E;AAAA,QACvE,IAAID,IAAA,CAAKlL,MAAL,GAAc,CAAlB;AAAA,YACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,8CAAD,GAAiDF,IAAA,CAAKlL,MAAL,GAAc,CAA/D,EAAiE,CAAjE,CAAd,CAAP,CAFmE;AAAA,QAGvE,IAAIkL,IAAA,CAAKlL,MAAL,GAAc,CAAd,KAAoB,CAAxB;AAAA,YACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,qCAAD,CAAd,CAAP,CAJmE;AAAA,QAMvE,IAAIoS,SAAJ,CANuE;AAAA,QAOvE,IAAI3F,UAAJ,CAPuE;AAAA,QAQvE,IAAI1M,OAAA,CAAQE,YAAR,IAAwBF,OAAA,CAAQE,YAAR,CAAqBvE,IAArB,KAA8B,OAA1D,EAAmE;AAAA,YAC/D+Q,UAAA,GAAa1M,OAAA,CAAQE,YAArB,CAD+D;AAAA,SARI;AAAA,QAWvE,MAAMoS,KAAA,GAAQ,EAAd,CAXuE;AAAA,QAYvE,MAAM9F,OAAA,GAAU,EAAhB,CAZuE;AAAA,QAavE,KAAK,IAAIlY,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIyL,IAAA,CAAKlL,MAAL,GAAc,CAAlC,EAAqCP,CAAA,IAAK,CAA1C,EAA6C;AAAA,YACzC,IAAIiY,MAAA,GAASxM,IAAA,CAAKzL,CAAL,CAAb,CADyC;AAAA,YAEzC,MAAMsD,KAAA,GAAQmI,IAAA,CAAKzL,CAAA,GAAI,CAAT,CAAd,CAFyC;AAAA,YAIzC,IAAI,CAAC6I,KAAA,CAAMC,OAAN,CAAcmP,MAAd,CAAL,EAA4B;AAAA,gBACxBA,MAAA,GAAS,CAACA,MAAD,CAAT,CADwB;AAAA,aAJa;AAAA,YAQzC,MAAMiG,YAAA,GAAexS,OAAA,CAAQxE,MAAR,CAAelH,CAAf,CAArB,CARyC;AAAA,YASzC,IAAIiY,MAAA,CAAO1X,MAAP,KAAkB,CAAtB,EAAyB;AAAA,gBACrB,OAAO2d,YAAA,CAAavS,KAAb,CAAmB,qCAAnB,CAAP,CADqB;AAAA,aATgB;AAAA,YAazC,KAAWwM,MAAAA,KAAX,IAAoBF,MAApB,EAA4B;AAAA,gBACxB,IAAI,OAAOE,KAAP,KAAiB,QAAjB,IAA6B,OAAOA,KAAP,KAAiB,QAAlD,EAA4D;AAAA,oBACxD,OAAO+F,YAAA,CAAavS,KAAb,CAAmB,CAAC,yCAAD,CAAnB,CAAP,CADwD;AAAA,iBAA5D,MAEO,IAAI,OAAOwM,KAAP,KAAiB,QAAjB,IAA6BlY,IAAA,CAAK6Z,GAAL,CAAS3B,KAAT,CAAA,GAAkBpK,MAAA,CAAOoQ,gBAA1D,EAA4E;AAAA,oBAC/E,OAAOD,YAAA,CAAavS,KAAb,CAAmB,CAAC,8CAAD,GAAiDoC,MAAA,CAAOoQ,gBAAxD,EAAyE,CAAzE,CAAnB,CAAP,CAD+E;AAAA,iBAA5E,MAGA,IAAI,OAAOhG,KAAP,KAAiB,QAAjB,IAA6BlY,IAAA,CAAKuM,KAAL,CAAW2L,KAAX,CAAA,KAAsBA,KAAvD,EAA8D;AAAA,oBACjE,OAAO+F,YAAA,CAAavS,KAAb,CAAmB,CAAC,6CAAD,CAAnB,CAAP,CADiE;AAAA,iBAA9D,MAGA,IAAI,CAACoS,SAAL,EAAgB;AAAA,oBACnBA,SAAA,GAAY3S,MAAA,CAAO+M,KAAP,CAAZ,CADmB;AAAA,iBAAhB,MAEA,IAAI+F,YAAA,CAAa9V,YAAb,CAA0B2V,SAA1B,EAAqC3S,MAAA,CAAO+M,KAAP,CAArC,CAAJ,EAAyD;AAAA,oBAC5D,OAAO,IAAP,CAD4D;AAAA,iBAXxC;AAAA,gBAexB,IAAI,OAAO6F,KAAA,CAAM3S,MAAA,CAAO8M,KAAP,CAAN,CAAP,KAAgC,WAApC,EAAiD;AAAA,oBAC7C,OAAO+F,YAAA,CAAavS,KAAb,CAAmB,+BAAnB,CAAP,CAD6C;AAAA,iBAfzB;AAAA,gBAmBxBqS,KAAA,CAAM3S,MAAA,CAAO8M,KAAP,CAAN,CAAuBD,GAAAA,OAAA,CAAQ3X,MAA/B,CAnBwB;AAAA,aAba;AAAA,YAmCzC,MAAM6F,MAAA,GAASsF,OAAA,CAAQlJ,KAAR,CAAcc,KAAd,EAAqBtD,CAArB,EAAwBoY,UAAxB,CAAf,CAnCyC;AAAA,YAoCzC,IAAI,CAAChS,MAAL;AAAA,gBAAa,OAAO,IAAP,CApC4B;AAAA,YAqCzCgS,UAAA,GAAaA,UAAA,IAAchS,MAAA,CAAO3B,IAAlC,CArCyC;AAAA,YAsCzCyT,OAAA,CAAQ7S,IAAR,CAAae,MAAb,CAtCyC,CAAA;AAAA,SAb0B;AAAA,QAsDvE,MAAM3D,KAAA,GAAQiJ,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0B9D,SAA1B,CAAd,CAtDuE;AAAA,QAuDvE,IAAI,CAAClF,KAAL;AAAA,YAAY,OAAO,IAAP,CAvD2D;AAAA,QAyDvE,MAAMwb,SAAA,GAAYvS,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAKA,IAAA,CAAKlL,MAAL,GAAc,CAAnB,CAAd,EAAqCkL,IAAA,CAAKlL,MAAL,GAAc,CAAnD,EAAsD6X,UAAtD,CAAlB,CAzDuE;AAAA,QA0DvE,IAAI,CAAC6F,SAAL;AAAA,YAAgB,OAAO,IAAP,CA1DuD;AAAA,QA8DvE,IAAIxb,KAAA,CAAMgC,IAAN,CAAW4C,IAAX,KAAoB,OAApB,IAA+BqE,OAAA,CAAQxE,MAAR,CAAe,CAAf,CAAkBkB,CAAAA,YAAlB,CAAgC2V,SAAhC,EAAiDtb,KAAA,CAAMgC,IAAvD,CAAnC,EAAiG;AAAA,YAC7F,OAAO,IAAP,CAD6F;AAAA,SA9D1B;AAAA,QAkEvE,OAAO,IAAIqZ,KAAJ,CAAWC,SAAX,EAA6B3F,UAA7B,EAA+C3V,KAA/C,EAAsDub,KAAtD,EAA6D9F,OAA7D,EAAsE+F,SAAtE,CAAP,CAlEuE;AAAA,KAlB7C;AAAA,IAuF9BpS,QAAA,CAASa,GAAT,EAAsC;AAAA,QAClC,MAAMjK,KAAA,GAAS,IAAKA,CAAAA,KAAL,CAAWoJ,QAAX,CAAoBa,GAApB,CAAf,CADkC;AAAA,QAElC,MAAMjH,MAAA,GAAU2F,MAAA,CAAO3I,KAAP,CAAA,KAAkB,IAAKsb,CAAAA,SAAvB,IAAoC,IAAA,CAAK7F,OAAL,CAAa,IAAA,CAAK8F,KAAL,CAAWvb,KAAX,CAAb,CAArC,IAAyE,IAAKwb,CAAAA,SAA7F,CAFkC;AAAA,QAGlC,OAAOxY,MAAA,CAAOoG,QAAP,CAAgBa,GAAhB,CAAP,CAHkC;AAAA,KAvFR;AAAA,IA6F9BZ,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnCA,EAAA,CAAG,IAAKlK,CAAAA,KAAR,CADmC,CAAA;AAAA,QAEnC,KAAKyV,OAAL,CAAatL,OAAb,CAAqBD,EAArB,CAFmC,CAAA;AAAA,QAGnCA,EAAA,CAAG,IAAKsR,CAAAA,SAAR,CAHmC,CAAA;AAAA,KA7FT;AAAA,IAmG9BlS,aAAA,GAAyB;AAAA,QACrB,OAAO,IAAKmM,CAAAA,OAAL,CAAarL,KAAb,CAAmB2L,GAAA,IAAOA,GAAA,CAAIzM,aAAJ,EAA1B,CAAkD,IAAA,IAAA,CAAKkS,SAAL,CAAelS,aAAf,EAAzD,CADqB;AAAA,KAnGK;AAAA,IAuG9BpB,SAAA,GAAkC;AAAA,QAC9B,MAAMC,UAAA,GAAa;AAAA,YAAC,OAAD;AAAA,YAAU,IAAKnI,CAAAA,KAAL,CAAWkI,SAAX,EAAV;AAAA,SAAnB,CAD8B;AAAA;AAK9B;AAAA,QAAMyT,MAAAA,YAAA,GAAe1Z,MAAA,CAAOC,IAAP,CAAY,IAAA,CAAKqZ,KAAjB,CAAA,CAAwBK,IAAxB,EAArB,CAL8B;AAAA;AAS9B;AAAA,QAAMC,MAAAA,eAAA,GAA2D,EAAjE,CAT8B;AAAA,QAU9B,MAAMC,YAAA,GAA0C,EAAhD,CAV8B;AAAA;AAW9B,QAAWpG,KAAAA,MAAAA,KAAX,IAAoBiG,YAApB,EAAkC;AAAA,YAC9B,MAAMI,WAAA,GAAcD,YAAA,CAAa,IAAKP,CAAAA,KAAL,CAAW7F,KAAX,CAAb,CAApB,CAD8B;AAAA,YAE9B,IAAIqG,WAAA,KAAgB9b,SAApB,EAA+B;AAAA;AAE3B,gBAAA6b,YAAA,CAAa,IAAA,CAAKP,KAAL,CAAW7F,KAAX,CAAb,CAAkCmG,GAAAA,eAAA,CAAgB/d,MAAlD,CAF2B;AAAA,gBAG3B+d,eAAA,CAAgBjZ,IAAhB,CAAqB;AAAA,oBAAC,IAAK2Y,CAAAA,KAAL,CAAW7F,KAAX,CAAD;AAAA,oBAAoB,CAACA,KAAD,CAApB;AAAA,iBAArB,CAH2B,CAAA;AAAA,aAA/B,MAIO;AAAA;AAEH,gBAAAmG,eAAA,CAAgBE,WAAhB,CAAA,CAA6B,CAA7B,CAAgCnZ,CAAAA,IAAhC,CAAqC8S,KAArC,CAFG,CAAA;AAAA,aANuB;AAAA,SAXJ;AAAA,QAuB9B,MAAMsG,WAAA,GAAetG,KAAD,IAAW,IAAA,CAAK4F,SAAL,CAAe1W,IAAf,KAAwB,QAAxB,GAAmC0G,MAAA,CAAOoK,KAAP,CAAnC,GAAmDA,KAAlF,CAvB8B;AAAA,QAyB9B,KAAA,MAAW,CAACqG,WAAD,EAAcvG,MAAd,CAAX,IAAoCqG,eAApC,EAAqD;AAAA,YACjD,IAAIrG,MAAA,CAAO1X,MAAP,KAAkB,CAAtB,EAAyB;AAAA;AAErB,gBAAAqK,UAAA,CAAWvF,IAAX,CAAgBoZ,WAAA,CAAYxG,MAAA,CAAO,CAAP,CAAZ,CAAhB,CAFqB,CAAA;AAAA,aAAzB,MAGO;AAAA;AAEH,gBAAArN,UAAA,CAAWvF,IAAX,CAAgB4S,MAAA,CAAOjU,GAAP,CAAWya,WAAX,CAAhB,CAFG,CAAA;AAAA,aAJ0C;AAAA,YAQjD7T,UAAA,CAAWvF,IAAX,CAAgB,IAAA,CAAK6S,OAAL,CAAasG,WAAb,CAAA,CAA0B7T,SAA1B,EAAhB,CARiD,CAAA;AAAA,SAzBvB;AAAA,QAmC9BC,UAAA,CAAWvF,IAAX,CAAgB,KAAK4Y,SAAL,CAAetT,SAAf,EAAhB,CAnC8B,CAAA;AAAA,QAoC9B,OAAOC,UAAP,CApC8B;AAAA,KAvGJ;AAAA,CAdlC;AA6JA,cAAA,KAAA;;AChJA,MAAM8T,IAAN,CAAiC;AAAA,IAM7Bvc,WAAA,CAAYsC,IAAZ,EAAwBka,QAAxB,EAA4CV,SAA5C,EAAmE;AAAA,QAC/D,IAAKxZ,CAAAA,IAAL,GAAYA,IAAZ,CAD+D;AAAA,QAE/D,IAAKka,CAAAA,QAAL,GAAgBA,QAAhB,CAF+D;AAAA,QAG/D,IAAKV,CAAAA,SAAL,GAAiBA,SAAjB,CAH+D;AAAA,KANtC;AAAA,IAY7B,OAAOzb,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAA0E;AAAA,QACtE,IAAID,IAAA,CAAKlL,MAAL,GAAc,CAAlB;AAAA,YACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,8CAAD,GAAiDF,IAAA,CAAKlL,MAAL,GAAc,CAA/D,EAAiE,CAAjE,CAAd,CAAP,CAFkE;AAAA,QAGtE,IAAIkL,IAAA,CAAKlL,MAAL,GAAc,CAAd,KAAoB,CAAxB;AAAA,YACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,oCAAD,CAAd,CAAP,CAJkE;AAAA,QAMtE,IAAIyM,UAAJ,CANsE;AAAA,QAOtE,IAAI1M,OAAA,CAAQE,YAAR,IAAwBF,OAAA,CAAQE,YAAR,CAAqBvE,IAArB,KAA8B,OAA1D,EAAmE;AAAA,YAC/D+Q,UAAA,GAAa1M,OAAA,CAAQE,YAArB,CAD+D;AAAA,SAPG;AAAA,QAWtE,MAAM+S,QAAA,GAAW,EAAjB,CAXsE;AAAA,QAYtE,KAAK,IAAI3e,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIyL,IAAA,CAAKlL,MAAL,GAAc,CAAlC,EAAqCP,CAAA,IAAK,CAA1C,EAA6C;AAAA,YACzC,MAAMwW,IAAA,GAAO9K,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAKzL,CAAL,CAAd,EAAuBA,CAAvB,EAA0BwH,WAA1B,CAAb,CADyC;AAAA,YAEzC,IAAI,CAACgP,IAAL;AAAA,gBAAW,OAAO,IAAP,CAF8B;AAAA,YAIzC,MAAMpQ,MAAA,GAASsF,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAKzL,CAAA,GAAI,CAAT,CAAd,EAA2BA,CAAA,GAAI,CAA/B,EAAkCoY,UAAlC,CAAf,CAJyC;AAAA,YAKzC,IAAI,CAAChS,MAAL;AAAA,gBAAa,OAAO,IAAP,CAL4B;AAAA,YAOzCuY,QAAA,CAAStZ,IAAT,CAAc;AAAA,gBAACmR,IAAD;AAAA,gBAAOpQ,MAAP;AAAA,aAAd,CAPyC,CAAA;AAAA,YASzCgS,UAAA,GAAaA,UAAA,IAAchS,MAAA,CAAO3B,IAAlC,CATyC;AAAA,SAZyB;AAAA,QAwBtE,MAAMwZ,SAAA,GAAYvS,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAKA,IAAA,CAAKlL,MAAL,GAAc,CAAnB,CAAd,EAAqCkL,IAAA,CAAKlL,MAAL,GAAc,CAAnD,EAAsD6X,UAAtD,CAAlB,CAxBsE;AAAA,QAyBtE,IAAI,CAAC6F,SAAL;AAAA,YAAgB,OAAO,IAAP,CAzBsD;AAAA,QA4BtE,OAAO,IAAIS,IAAJ,CAAUtG,UAAV,EAA4BuG,QAA5B,EAAsCV,SAAtC,CAAP,CA5BsE;AAAA,KAZ7C;AAAA,IA2C7BpS,QAAA,CAASa,GAAT,EAAsC;AAAA,QAClC,KAAA,MAAW,CAAC8J,IAAD,EAAO3R,UAAP,CAAX,IAAiC,IAAK8Z,CAAAA,QAAtC,EAAgD;AAAA,YAC5C,IAAInI,IAAA,CAAK3K,QAAL,CAAca,GAAd,CAAJ,EAAwB;AAAA,gBACpB,OAAO7H,UAAA,CAAWgH,QAAX,CAAoBa,GAApB,CAAP,CADoB;AAAA,aADoB;AAAA,SADd;AAAA,QAMlC,OAAO,KAAKuR,SAAL,CAAepS,QAAf,CAAwBa,GAAxB,CAAP,CANkC;AAAA,KA3CT;AAAA,IAoD7BZ,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnC,KAAA,MAAW,CAAC6J,IAAD,EAAO3R,UAAP,CAAX,IAAiC,IAAK8Z,CAAAA,QAAtC,EAAgD;AAAA,YAC5ChS,EAAA,CAAG6J,IAAH,CAD4C,CAAA;AAAA,YAE5C7J,EAAA,CAAG9H,UAAH,CAF4C,CAAA;AAAA,SADb;AAAA,QAKnC8H,EAAA,CAAG,IAAKsR,CAAAA,SAAR,CALmC,CAAA;AAAA,KApDV;AAAA,IA4D7BlS,aAAA,GAAyB;AAAA,QACrB,OAAO,KAAK4S,QAAL,CAAc9R,KAAd,CAAoB,CAAC,CAAC+R,CAAD,EAAIpG,GAAJ,CAAD,KAAcA,GAAA,CAAIzM,aAAJ,EAAlC,CAAA,IAA0D,KAAKkS,SAAL,CAAelS,aAAf,EAAjE,CADqB;AAAA,KA5DI;AAAA,IAgE7BpB,SAAA,GAAkC;AAAA,QAC9B,MAAMC,UAAA,GAAa,CAAC,MAAD,CAAnB,CAD8B;AAAA,QAE9B,IAAKkB,CAAAA,SAAL,CAAeoC,KAAA,IAAS;AAAA,YAAEtD,UAAA,CAAWvF,IAAX,CAAgB6I,KAAA,CAAMvD,SAAN,EAAhB,CAAF,CAAA;AAAA,SAAxB,CAF8B,CAAA;AAAA,QAG9B,OAAOC,UAAP,CAH8B;AAAA,KAhEL;AAAA,CAbjC;AAoFA,aAAA,IAAA;;AClFA;AASA,MAAMiU,KAAN,CAAkC;AAAA,IAM9B1c,WAAA,CAAYsC,IAAZ,EAAwBhC,KAAxB,EAA2Cqc,UAA3C,EAAmEC,QAAnE,EAA0F;AAAA,QACtF,IAAKta,CAAAA,IAAL,GAAYA,IAAZ,CADsF;AAAA,QAEtF,IAAKhC,CAAAA,KAAL,GAAaA,KAAb,CAFsF;AAAA,QAGtF,IAAKqc,CAAAA,UAAL,GAAkBA,UAAlB,CAHsF;AAAA,QAItF,IAAKC,CAAAA,QAAL,GAAgBA,QAAhB,CAJsF;AAAA,KAN5D;AAAA,IAc9B,OAAOvc,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAA2E;AAAA,QACvE,IAAID,IAAA,CAAKlL,MAAL,IAAe,CAAf,IAAqBkL,IAAA,CAAKlL,MAAL,IAAe,CAAxC,EAA2C;AAAA,YACvC,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,qCAAD,GAAwCF,IAAA,CAAKlL,MAAL,GAAc,CAAtD,EAAwD,SAAxD,CAAd,CAAP,CADuC;AAAA,SAD4B;AAAA,QAKvE,MAAMkC,KAAA,GAAQiJ,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0B9D,SAA1B,CAAd,CALuE;AAAA,QAMvE,MAAMmX,UAAA,GAAapT,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0BnE,UAA1B,CAAnB,CANuE;AAAA,QAQvE,IAAI,CAAC7E,KAAD,IAAU,CAACqc,UAAf;AAAA,YAA2B,OAAO,IAAP,CAR4C;AAAA,QAUvE,IAAI,CAACtW,WAAA,CAAY/F,KAAA,CAAMgC,IAAlB,EAAwB;AAAA,gBAACuD,OAAA,CAAML,SAAN,CAAD;AAAA,gBAAmBJ,UAAnB;AAAA,gBAA+BI,SAA/B;AAAA,aAAxB,CAAL,EAAyE;AAAA,YACrE,OAAO+D,OAAA,CAAQC,KAAR,CAAc,CAAC,iEAAD,GAAoE/I,UAAA,CAASH,KAAA,CAAMgC,IAAf,CAApE,EAAyF,QAAzF,CAAd,CAAP,CADqE;AAAA,SAVF;AAAA,QAcvE,IAAIgH,IAAA,CAAKlL,MAAL,KAAgB,CAApB,EAAuB;AAAA,YACnB,MAAMwe,QAAA,GAAWrT,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0BnE,UAA1B,CAAjB,CADmB;AAAA,YAEnB,IAAI,CAACyX,QAAL;AAAA,gBAAe,OAAO,IAAP,CAFI;AAAA,YAGnB,OAAO,IAAIF,KAAJ,CAAUpc,KAAA,CAAMgC,IAAhB,EAAsBhC,KAAtB,EAA6Bqc,UAA7B,EAAyCC,QAAzC,CAAP,CAHmB;AAAA,SAAvB,MAIO;AAAA,YACH,OAAO,IAAIF,KAAJ,CAAUpc,KAAA,CAAMgC,IAAhB,EAAsBhC,KAAtB,EAA6Bqc,UAA7B,CAAP,CADG;AAAA,SAlBgE;AAAA,KAd7C;AAAA,IAqC9BjT,QAAA,CAASa,GAAT,EAAsC;AAAA,QAClC,MAAMjK,KAAA,GAAS,IAAKA,CAAAA,KAAL,CAAWoJ,QAAX,CAAoBa,GAApB,CAAf,CADkC;AAAA,QAElC,MAAMoS,UAAA,GAAc,IAAKA,CAAAA,UAAL,CAAgBjT,QAAhB,CAAyBa,GAAzB,CAApB,CAFkC;AAAA,QAIlC,IAAI,CAAC9D,iBAAA,CAAkBnG,KAAlB,EAAyB;AAAA,gBAAC,QAAD;AAAA,gBAAW,OAAX;AAAA,aAAzB,CAAL,EAAoD;AAAA,YAChD,MAAM,IAAIuJ,cAAJ,CAAiB,CAAC,iEAAD,GAAoEpJ,UAAA,CAASwI,MAAA,CAAO3I,KAAP,CAAT,CAApE,EAA4F,SAA5F,CAAjB,CAAN,CADgD;AAAA,SAJlB;AAAA,QAQlC,IAAI,IAAKsc,CAAAA,QAAT,EAAmB;AAAA,YACf,MAAMA,QAAA,GAAY,IAAKA,CAAAA,QAAL,CAAclT,QAAd,CAAuBa,GAAvB,CAAlB,CADe;AAAA,YAEf,OAAOjK,KAAA,CAAMtB,KAAN,CAAY2d,UAAZ,EAAwBC,QAAxB,CAAP,CAFe;AAAA,SARe;AAAA,QAalC,OAAOtc,KAAA,CAAMtB,KAAN,CAAY2d,UAAZ,CAAP,CAbkC;AAAA,KArCR;AAAA,IAqD9BhT,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnCA,EAAA,CAAG,IAAKlK,CAAAA,KAAR,CADmC,CAAA;AAAA,QAEnCkK,EAAA,CAAG,IAAKmS,CAAAA,UAAR,CAFmC,CAAA;AAAA,QAGnC,IAAI,IAAKC,CAAAA,QAAT,EAAmB;AAAA,YACfpS,EAAA,CAAG,IAAKoS,CAAAA,QAAR,CADe,CAAA;AAAA,SAHgB;AAAA,KArDT;AAAA,IA6D9BhT,aAAA,GAAyB;AAAA,QACrB,OAAO,KAAP,CADqB;AAAA,KA7DK;AAAA,IAiE9BpB,SAAA,GAAkC;AAAA,QAC9B,IAAI,IAAKoU,CAAAA,QAAL,IAAiB,IAAjB,IAAyB,IAAKA,CAAAA,QAAL,KAAkBrc,SAA/C,EAA0D;AAAA,YACtD,MAAMqc,QAAA,GAAW,IAAA,CAAKA,QAAL,CAAcpU,SAAd,EAAjB,CADsD;AAAA,YAEtD,OAAO;AAAA,gBAAC,OAAD;AAAA,gBAAU,IAAKlI,CAAAA,KAAL,CAAWkI,SAAX,EAAV;AAAA,gBAAkC,IAAKmU,CAAAA,UAAL,CAAgBnU,SAAhB,EAAlC;AAAA,gBAA+DoU,QAA/D;AAAA,aAAP,CAFsD;AAAA,SAD5B;AAAA,QAK9B,OAAO;AAAA,YAAC,OAAD;AAAA,YAAU,IAAKtc,CAAAA,KAAL,CAAWkI,SAAX,EAAV;AAAA,YAAkC,IAAKmU,CAAAA,UAAL,CAAgBnU,SAAhB,EAAlC;AAAA,SAAP,CAL8B;AAAA,KAjEJ;AAAA,CAXlC;AAqFA,cAAA,KAAA;;ACnFA;AAYA,SAASqU,gBAAT,CAA0B1d,EAA1B,EAAkDmD,IAAlD,EAA8D;AAAA,IAC1D,IAAInD,EAAA,KAAO,IAAP,IAAeA,EAAA,KAAO,IAA1B,EAAgC;AAAA;AAE5B,QAAA,OAAOmD,IAAA,CAAK4C,IAAL,KAAc,SAAd,IACH5C,IAAA,CAAK4C,IAAL,KAAc,QADX,IAEH5C,IAAA,CAAK4C,IAAL,KAAc,QAFX,IAGH5C,IAAA,CAAK4C,IAAL,KAAc,MAHX,IAIH5C,IAAA,CAAK4C,IAAL,KAAc,OAJlB,CAF4B;AAAA,KAAhC,MAOO;AAAA;AAEH,QAAA,OAAO5C,IAAA,CAAK4C,IAAL,KAAc,QAAd,IACH5C,IAAA,CAAK4C,IAAL,KAAc,QADX,IAEH5C,IAAA,CAAK4C,IAAL,KAAc,OAFlB,CAFG;AAAA,KARmD;AAAA,CAd9D;AA8BA,SAAS4X,EAAT,CAAYvS,GAAZ,EAAoCnK,CAApC,EAA4CD,CAA5C,EAA6D;AAAA,IAAE,OAAOC,CAAA,KAAMD,CAAb,CAAF;AAAA,CA9B7D;AA+BA,SAAS4c,GAAT,CAAaxS,GAAb,EAAqCnK,CAArC,EAA6CD,CAA7C,EAA8D;AAAA,IAAE,OAAOC,CAAA,KAAMD,CAAb,CAAF;AAAA,CA/B9D;AAgCA,SAAS6c,EAAT,CAAYzS,GAAZ,EAAoCnK,CAApC,EAA4CD,CAA5C,EAA6D;AAAA,IAAE,OAAOC,CAAA,GAAID,CAAX,CAAF;AAAA,CAhC7D;AAiCA,SAAS8c,EAAT,CAAY1S,GAAZ,EAAoCnK,CAApC,EAA4CD,CAA5C,EAA6D;AAAA,IAAE,OAAOC,CAAA,GAAID,CAAX,CAAF;AAAA,CAjC7D;AAkCA,SAAS+c,IAAT,CAAc3S,GAAd,EAAsCnK,CAAtC,EAA8CD,CAA9C,EAA+D;AAAA,IAAE,OAAOC,CAAA,IAAKD,CAAZ,CAAF;AAAA,CAlC/D;AAmCA,SAASgd,IAAT,CAAc5S,GAAd,EAAsCnK,CAAtC,EAA8CD,CAA9C,EAA+D;AAAA,IAAE,OAAOC,CAAA,IAAKD,CAAZ,CAAF;AAAA,CAnC/D;AAqCA,SAASid,SAAT,CAAmB7S,GAAnB,EAA2CnK,CAA3C,EAAmDD,CAAnD,EAA2DsL,CAA3D,EAA4E;AAAA,IAAE,OAAOA,CAAA,CAAErE,OAAF,CAAUhH,CAAV,EAAaD,CAAb,CAAoB,KAAA,CAA3B,CAAF;AAAA,CArC5E;AAsCA,SAASkd,UAAT,CAAoB9S,GAApB,EAA4CnK,CAA5C,EAAoDD,CAApD,EAA4DsL,CAA5D,EAA6E;AAAA,IAAE,OAAO,CAAC2R,SAAA,CAAU7S,GAAV,EAAenK,CAAf,EAAkBD,CAAlB,EAAqBsL,CAArB,CAAR,CAAF;AAAA,CAtC7E;AAuCA,SAAS6R,SAAT,CAAmB/S,GAAnB,EAA2CnK,CAA3C,EAAmDD,CAAnD,EAA2DsL,CAA3D,EAA4E;AAAA,IAAE,OAAOA,CAAA,CAAErE,OAAF,CAAUhH,CAAV,EAAaD,CAAb,CAAkB,GAAA,CAAzB,CAAF;AAAA,CAvC5E;AAwCA,SAASod,SAAT,CAAmBhT,GAAnB,EAA2CnK,CAA3C,EAAmDD,CAAnD,EAA2DsL,CAA3D,EAA4E;AAAA,IAAE,OAAOA,CAAA,CAAErE,OAAF,CAAUhH,CAAV,EAAaD,CAAb,CAAkB,GAAA,CAAzB,CAAF;AAAA,CAxC5E;AAyCA,SAASqd,WAAT,CAAqBjT,GAArB,EAA6CnK,CAA7C,EAAqDD,CAArD,EAA6DsL,CAA7D,EAA8E;AAAA,IAAE,OAAOA,CAAA,CAAErE,OAAF,CAAUhH,CAAV,EAAaD,CAAb,CAAmB,IAAA,CAA1B,CAAF;AAAA,CAzC9E;AA0CA,SAASsd,WAAT,CAAqBlT,GAArB,EAA6CnK,CAA7C,EAAqDD,CAArD,EAA6DsL,CAA7D,EAA8E;AAAA,IAAE,OAAOA,CAAA,CAAErE,OAAF,CAAUhH,CAAV,EAAaD,CAAb,CAAmB,IAAA,CAA1B,CAAF;AAAA,CA1C9E;AA6DA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAASud,cAAT,CAAwBve,EAAxB,EAAgDwe,YAAhD,EAAwGC,mBAAxG,EAAoM;AAAA,IAChM,MAAMC,iBAAA,GAAoB1e,EAAA,KAAO,IAAP,IAAeA,EAAA,KAAO,IAAhD,CADgM;AAAA,IAGhM,OAAO,MAAM2e,UAAN,CAAuC;AAAA,QAO1C9d,WAAA,CAAYqH,GAAZ,EAA6BC,GAA7B,EAA8CL,QAA9C,EAAqE;AAAA,YACjE,IAAK3E,CAAAA,IAAL,GAAY+C,WAAZ,CADiE;AAAA,YAEjE,IAAKgC,CAAAA,GAAL,GAAWA,GAAX,CAFiE;AAAA,YAGjE,IAAKC,CAAAA,GAAL,GAAWA,GAAX,CAHiE;AAAA,YAIjE,IAAKL,CAAAA,QAAL,GAAgBA,QAAhB,CAJiE;AAAA,YAKjE,KAAK8W,kBAAL,GAA0B1W,GAAA,CAAI/E,IAAJ,CAAS4C,IAAT,KAAkB,OAAlB,IAA6BoC,GAAA,CAAIhF,IAAJ,CAAS4C,IAAT,KAAkB,OAAzE,CALiE;AAAA,SAP3B;AAAA,QAe1C,OAAO7E,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAAgF;AAAA,YAC5E,IAAID,IAAA,CAAKlL,MAAL,KAAgB,CAAhB,IAAqBkL,IAAA,CAAKlL,MAAL,KAAgB,CAAzC;AAAA,gBACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,gCAAD,CAAd,CAAP,CAFwE;AAAA,YAI5E,MAAMrK,EAAA,GAA0BmK,IAAA,CAAK,CAAL,CAAhC,CAJ4E;AAAA,YAM5E,IAAIjC,GAAA,GAAMkC,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0B9D,SAA1B,CAAV,CAN4E;AAAA,YAO5E,IAAI,CAAC6B,GAAL;AAAA,gBAAU,OAAO,IAAP,CAPkE;AAAA,YAQ5E,IAAI,CAACwV,gBAAA,CAAiB1d,EAAjB,EAAqBkI,GAAA,CAAI/E,IAAzB,CAAL,EAAqC;AAAA,gBACjC,OAAOiH,OAAA,CAAQxE,MAAR,CAAe,CAAf,CAAA,CAAkByE,KAAlB,CAAwB,CAAC,CAAD,GAAIrK,EAAJ,EAAO,0CAAP,GAAmDsB,UAAA,CAAS4G,GAAA,CAAI/E,IAAb,CAAnD,EAAsE,EAAtE,CAAxB,CAAP,CADiC;AAAA,aARuC;AAAA,YAW5E,IAAIgF,GAAA,GAAMiC,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0B9D,SAA1B,CAAV,CAX4E;AAAA,YAY5E,IAAI,CAAC8B,GAAL;AAAA,gBAAU,OAAO,IAAP,CAZkE;AAAA,YAa5E,IAAI,CAACuV,gBAAA,CAAiB1d,EAAjB,EAAqBmI,GAAA,CAAIhF,IAAzB,CAAL,EAAqC;AAAA,gBACjC,OAAOiH,OAAA,CAAQxE,MAAR,CAAe,CAAf,CAAA,CAAkByE,KAAlB,CAAwB,CAAC,CAAD,GAAIrK,EAAJ,EAAO,0CAAP,GAAmDsB,UAAA,CAAS6G,GAAA,CAAIhF,IAAb,CAAnD,EAAsE,EAAtE,CAAxB,CAAP,CADiC;AAAA,aAbuC;AAAA,YAiB5E,IACI+E,GAAA,CAAI/E,IAAJ,CAAS4C,IAAT,KAAkBoC,GAAA,CAAIhF,IAAJ,CAAS4C,IAA3B,IACAmC,GAAA,CAAI/E,IAAJ,CAAS4C,IAAT,KAAkB,OADlB,IAEAoC,GAAA,CAAIhF,IAAJ,CAAS4C,IAAT,KAAkB,OAHtB,EAIE;AAAA,gBACE,OAAOqE,OAAA,CAAQC,KAAR,CAAc,CAAC,sBAAD,GAAyB/I,UAAA,CAAS4G,GAAA,CAAI/E,IAAb,CAAzB,EAA4C,OAA5C,GAAqD7B,UAAA,CAAS6G,GAAA,CAAIhF,IAAb,CAArD,EAAwE,EAAxE,CAAd,CAAP,CADF;AAAA,aArB0E;AAAA,YAyB5E,IAAIub,iBAAJ,EAAuB;AAAA;AAEnB,gBAAA,IAAIxW,GAAA,CAAI/E,IAAJ,CAAS4C,IAAT,KAAkB,OAAlB,IAA6BoC,GAAA,CAAIhF,IAAJ,CAAS4C,IAAT,KAAkB,OAAnD,EAA4D;AAAA;AAExD,oBAAAmC,GAAA,GAAM,IAAI+C,WAAJ,CAAc9C,GAAA,CAAIhF,IAAlB,EAAwB,CAAC+E,GAAD,CAAxB,CAAN,CAFwD;AAAA,iBAA5D,MAGO,IAAIA,GAAA,CAAI/E,IAAJ,CAAS4C,IAAT,KAAkB,OAAlB,IAA6BoC,GAAA,CAAIhF,IAAJ,CAAS4C,IAAT,KAAkB,OAAnD,EAA4D;AAAA;AAE/D,oBAAAoC,GAAA,GAAM,IAAI8C,WAAJ,CAAc/C,GAAA,CAAI/E,IAAlB,EAAwB,CAACgF,GAAD,CAAxB,CAAN,CAF+D;AAAA,iBALhD;AAAA,aAzBqD;AAAA,YAoC5E,IAAIL,QAAA,GAAW,IAAf,CApC4E;AAAA,YAqC5E,IAAIqC,IAAA,CAAKlL,MAAL,KAAgB,CAApB,EAAuB;AAAA,gBACnB,IACIiJ,GAAA,CAAI/E,IAAJ,CAAS4C,IAAT,KAAkB,QAAlB,IACAoC,GAAA,CAAIhF,IAAJ,CAAS4C,IAAT,KAAkB,QADlB,IAEAmC,GAAA,CAAI/E,IAAJ,CAAS4C,IAAT,KAAkB,OAFlB,IAGAoC,GAAA,CAAIhF,IAAJ,CAAS4C,IAAT,KAAkB,OAJtB,EAKE;AAAA,oBACE,OAAOqE,OAAA,CAAQC,KAAR,CAAc,CAAC,gDAAD,CAAd,CAAP,CADF;AAAA,iBANiB;AAAA,gBASnBvC,QAAA,GAAWsC,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0B5D,YAA1B,CAAX,CATmB;AAAA,gBAUnB,IAAI,CAACuB,QAAL;AAAA,oBAAe,OAAO,IAAP,CAVI;AAAA,aArCqD;AAAA,YAkD5E,OAAO,IAAI6W,UAAJ,CAAezW,GAAf,EAAoBC,GAApB,EAAyBL,QAAzB,CAAP,CAlD4E;AAAA,SAftC;AAAA,QAoE1CyC,QAAA,CAASa,GAAT,EAA0C;AAAA,YACtC,MAAMlD,GAAA,GAAM,IAAKA,CAAAA,GAAL,CAASqC,QAAT,CAAkBa,GAAlB,CAAZ,CADsC;AAAA,YAEtC,MAAMjD,GAAA,GAAM,IAAKA,CAAAA,GAAL,CAASoC,QAAT,CAAkBa,GAAlB,CAAZ,CAFsC;AAAA,YAItC,IAAIsT,iBAAA,IAAqB,IAAA,CAAKE,kBAA9B,EAAkD;AAAA,gBAC9C,MAAMf,EAAA,GAAK/T,MAAA,CAAO5B,GAAP,CAAX,CAD8C;AAAA,gBAE9C,MAAM2W,EAAA,GAAK/U,MAAA,CAAO3B,GAAP,CAAX,CAF8C;AAAA;AAI9C,gBAAI0V,IAAAA,EAAA,CAAG9X,IAAH,KAAY8Y,EAAA,CAAG9Y,IAAf,IAAuB,EAAE8X,EAAA,CAAG9X,IAAH,KAAY,QAAZ,IAAwB8X,EAAA,CAAG9X,IAAH,KAAY,QAApC,CAA7B,EAA4E;AAAA,oBACxE,MAAM,IAAI2E,cAAJ,CAAiB,CAAC,wBAAD,GAA2B1K,EAA3B,EAA8B,yDAA9B,GAAyF6d,EAAA,CAAG9X,IAA5F,EAAiG,EAAjG,GAAqG8Y,EAAA,CAAG9Y,IAAxG,EAA6G,UAA7G,CAAjB,CAAN,CADwE;AAAA,iBAJ9B;AAAA,aAJZ;AAAA,YAatC,IAAI,KAAK+B,QAAL,IAAiB,CAAC4W,iBAAlB,IAAuC,IAAKE,CAAAA,kBAAhD,EAAoE;AAAA,gBAChE,MAAMf,EAAA,GAAK/T,MAAA,CAAO5B,GAAP,CAAX,CADgE;AAAA,gBAEhE,MAAM2W,EAAA,GAAK/U,MAAA,CAAO3B,GAAP,CAAX,CAFgE;AAAA,gBAGhE,IAAI0V,EAAA,CAAG9X,IAAH,KAAY,QAAZ,IAAwB8Y,EAAA,CAAG9Y,IAAH,KAAY,QAAxC,EAAkD;AAAA,oBAC9C,OAAOyY,YAAA,CAAapT,GAAb,EAAkBlD,GAAlB,EAAuBC,GAAvB,CAAP,CAD8C;AAAA,iBAHc;AAAA,aAb9B;AAAA,YAqBtC,OAAO,IAAA,CAAKL,QAAL,GACH2W,mBAAA,CAAoBrT,GAApB,EAAyBlD,GAAzB,EAA8BC,GAA9B,EAAmC,IAAKL,CAAAA,QAAL,CAAcyC,QAAd,CAAuBa,GAAvB,CAAnC,CADG,GAEHoT,YAAA,CAAapT,GAAb,EAAkBlD,GAAlB,EAAuBC,GAAvB,CAFJ,CArBsC;AAAA,SApEA;AAAA,QA8F1CqC,SAAA,CAAUa,EAAV,EAAuC;AAAA,YACnCA,EAAA,CAAG,IAAKnD,CAAAA,GAAR,CADmC,CAAA;AAAA,YAEnCmD,EAAA,CAAG,IAAKlD,CAAAA,GAAR,CAFmC,CAAA;AAAA,YAGnC,IAAI,IAAKL,CAAAA,QAAT,EAAmB;AAAA,gBACfuD,EAAA,CAAG,IAAKvD,CAAAA,QAAR,CADe,CAAA;AAAA,aAHgB;AAAA,SA9FG;AAAA,QAsG1C2C,aAAA,GAAyB;AAAA,YACrB,OAAO,IAAP,CADqB;AAAA,SAtGiB;AAAA,QA0G1CpB,SAAA,GAAkC;AAAA,YAC9B,MAAMC,UAAA,GAAa,CAACtJ,EAAD,CAAnB,CAD8B;AAAA,YAE9B,IAAKwK,CAAAA,SAAL,CAAeoC,KAAA,IAAS;AAAA,gBAAEtD,UAAA,CAAWvF,IAAX,CAAgB6I,KAAA,CAAMvD,SAAN,EAAhB,CAAF,CAAA;AAAA,aAAxB,CAF8B,CAAA;AAAA,YAG9B,OAAOC,UAAP,CAH8B;AAAA,SA1GQ;AAAA,KAA9C,CAHgM;AAAA,CA7DpM;AAkLO,MAAMwV,MAAA,GAA0EP,cAAA,CAAe,IAAf,EAAqBZ,EAArB,EAAyBM,SAAzB,CAAhF,CAlLP;AAmLO,MAAMc,SAAA,GAA+ER,cAAA,CAAe,IAAf,EAAqBX,GAArB,EAA0BM,UAA1B,CAArF,CAnLP;AAoLO,MAAMc,QAAA,GAA2ET,cAAA,CAAe,GAAf,EAAoBV,EAApB,EAAwBM,SAAxB,CAAjF,CApLP;AAqLO,MAAMc,WAAA,GAA8EV,cAAA,CAAe,GAAf,EAAoBT,EAApB,EAAwBM,SAAxB,CAApF,CArLP;AAsLO,MAAMc,eAAA,GAAuFX,cAAA,CAAe,IAAf,EAAqBR,IAArB,EAA2BM,WAA3B,CAA7F,CAtLP;AAuLO,MAAMc,kBAAA,GAA0FZ,cAAA,CAAe,IAAf,EAAqBP,IAArB,EAA2BM,WAA3B,CAAhG;;ACrLP;AAmCe,MAAMc,YAAN,CAAyC;AAAA;AASpD;AAAA;AAAA;AAAA;AAAA,IAAAve,WAAA,CAAYiK,MAAZ,EACYlD,MADZ,EAEYyX,QAFZ,EAGYC,IAHZ,EAIYC,iBAJZ,EAKYC,iBALZ,EAKkD;AAAA,QAC9C,IAAKrc,CAAAA,IAAL,GAAY8C,UAAZ,CAD8C;AAAA,QAE9C,IAAK6E,CAAAA,MAAL,GAAcA,MAAd,CAF8C;AAAA,QAG9C,IAAKlD,CAAAA,MAAL,GAAcA,MAAd,CAH8C;AAAA,QAI9C,IAAKyX,CAAAA,QAAL,GAAgBA,QAAhB,CAJ8C;AAAA,QAK9C,IAAKC,CAAAA,IAAL,GAAYA,IAAZ,CAL8C;AAAA,QAM9C,IAAKC,CAAAA,iBAAL,GAAyBA,iBAAzB,CAN8C;AAAA,QAO9C,IAAKC,CAAAA,iBAAL,GAAyBA,iBAAzB,CAP8C;AAAA,KAdE;AAAA,IAwBpD,OAAOte,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAAgF;AAAA,QAC5E,IAAID,IAAA,CAAKlL,MAAL,KAAgB,CAApB;AAAA,YACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,uBAAD,CAAd,CAAP,CAFwE;AAAA,QAI5E,MAAMS,MAAA,GAASV,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,EAA0BnE,UAA1B,CAAf,CAJ4E;AAAA,QAK5E,IAAI,CAAC8E,MAAL;AAAA,YAAa,OAAO,IAAP,CAL+D;AAAA,QAO5E,MAAMvB,OAAA,GAAWY,IAAA,CAAK,CAAL,CAAjB,CAP4E;AAAA,QAQ5E,IAAI,OAAOZ,OAAP,KAAmB,QAAnB,IAA+BhC,KAAA,CAAMC,OAAN,CAAc+B,OAAd,CAAnC;AAAA,YACI,OAAOa,OAAA,CAAQC,KAAR,CAAc,CAAC,gDAAD,CAAd,CAAP,CATwE;AAAA,QAW5E,IAAIzC,MAAA,GAAS,IAAb,CAX4E;AAAA,QAY5E,IAAI2B,OAAA,CAAQ,QAAR,CAAJ,EAAuB;AAAA,YACnB3B,MAAA,GAASwC,OAAA,CAAQlJ,KAAR,CAAcqI,OAAA,CAAQ,QAAR,CAAd,EAAiC,CAAjC,EAAoCtD,UAApC,CAAT,CADmB;AAAA,YAEnB,IAAI,CAAC2B,MAAL;AAAA,gBAAa,OAAO,IAAP,CAFM;AAAA,SAZqD;AAAA,QAiB5E,IAAIyX,QAAA,GAAW,IAAf,CAjB4E;AAAA,QAkB5E,IAAI9V,OAAA,CAAQ,UAAR,CAAJ,EAAyB;AAAA,YACrB8V,QAAA,GAAWjV,OAAA,CAAQlJ,KAAR,CAAcqI,OAAA,CAAQ,UAAR,CAAd,EAAmC,CAAnC,EAAsCtD,UAAtC,CAAX,CADqB;AAAA,YAErB,IAAI,CAACoZ,QAAL;AAAA,gBAAe,OAAO,IAAP,CAFM;AAAA,SAlBmD;AAAA,QAuB5E,IAAIC,IAAA,GAAO,IAAX,CAvB4E;AAAA,QAwB5E,IAAI/V,OAAA,CAAQ,MAAR,CAAJ,EAAqB;AAAA,YACjB+V,IAAA,GAAOlV,OAAA,CAAQlJ,KAAR,CAAcqI,OAAA,CAAQ,MAAR,CAAd,EAA+B,CAA/B,EAAkCtD,UAAlC,CAAP,CADiB;AAAA,YAEjB,IAAI,CAACqZ,IAAL;AAAA,gBAAW,OAAO,IAAP,CAFM;AAAA,SAxBuD;AAAA,QA6B5E,IAAIC,iBAAA,GAAoB,IAAxB,CA7B4E;AAAA,QA8B5E,IAAIhW,OAAA,CAAQ,qBAAR,CAAJ,EAAoC;AAAA,YAChCgW,iBAAA,GAAoBnV,OAAA,CAAQlJ,KAAR,CAAcqI,OAAA,CAAQ,qBAAR,CAAd,EAA8C,CAA9C,EAAiDvD,UAAjD,CAApB,CADgC;AAAA,YAEhC,IAAI,CAACuZ,iBAAL;AAAA,gBAAwB,OAAO,IAAP,CAFQ;AAAA,SA9BwC;AAAA,QAmC5E,IAAIC,iBAAA,GAAoB,IAAxB,CAnC4E;AAAA,QAoC5E,IAAIjW,OAAA,CAAQ,qBAAR,CAAJ,EAAoC;AAAA,YAChCiW,iBAAA,GAAoBpV,OAAA,CAAQlJ,KAAR,CAAcqI,OAAA,CAAQ,qBAAR,CAAd,EAA8C,CAA9C,EAAiDvD,UAAjD,CAApB,CADgC;AAAA,YAEhC,IAAI,CAACwZ,iBAAL;AAAA,gBAAwB,OAAO,IAAP,CAFQ;AAAA,SApCwC;AAAA,QAyC5E,OAAO,IAAIJ,YAAJ,CAAiBtU,MAAjB,EAAyBlD,MAAzB,EAAiCyX,QAAjC,EAA2CC,IAA3C,EAAiDC,iBAAjD,EAAoEC,iBAApE,CAAP,CAzC4E;AAAA,KAxB5B;AAAA,IAoEpDjV,QAAA,CAASa,GAAT,EAAyC;AAAA,QACrC,OAAO,IAAIrD,IAAA,CAAKqX,YAAT,CAAsB,KAAKxX,MAAL,GAAc,IAAKA,CAAAA,MAAL,CAAY2C,QAAZ,CAAqBa,GAArB,CAAd,GAA0C,EAAhE,EACH;AAAA,YACIqU,KAAA,EACK,IAAKJ,CAAAA,QAAL,IAAiB,UAAlB,IACC,IAAA,CAAKC,IAAL,IAAa,MADd,IAEA,SAJR;AAAA,YAKID,QAAA,EAAU,IAAKA,CAAAA,QAAL,GAAgB,IAAA,CAAKA,QAAL,CAAc9U,QAAd,CAAuBa,GAAvB,CAAhB,GAA8ChK,SAL5D;AAAA,YAMIke,IAAA,EAAM,IAAKA,CAAAA,IAAL,GAAY,IAAA,CAAKA,IAAL,CAAU/U,QAAV,CAAmBa,GAAnB,CAAZ,GAAsChK,SANhD;AAAA,YAOIse,qBAAA,EAAuB,IAAKH,CAAAA,iBAAL,GAAyB,IAAA,CAAKA,iBAAL,CAAuBhV,QAAvB,CAAgCa,GAAhC,CAAzB,GAAgEhK,SAP3F;AAAA,YAQIue,qBAAA,EAAuB,IAAKH,CAAAA,iBAAL,GAAyB,IAAA,CAAKA,iBAAL,CAAuBjV,QAAvB,CAAgCa,GAAhC,CAAzB,GAAgEhK,SAR3F;AAAA,SADG,CAAA,CAUAwe,MAVA,CAUO,IAAK9U,CAAAA,MAAL,CAAYP,QAAZ,CAAqBa,GAArB,CAVP,CAAP,CADqC;AAAA,KApEW;AAAA,IAkFpDZ,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnCA,EAAA,CAAG,IAAKP,CAAAA,MAAR,CADmC,CAAA;AAAA,QAEnC,IAAI,IAAKlD,CAAAA,MAAT,EAAiB;AAAA,YACbyD,EAAA,CAAG,IAAKzD,CAAAA,MAAR,CADa,CAAA;AAAA,SAFkB;AAAA,QAKnC,IAAI,IAAKyX,CAAAA,QAAT,EAAmB;AAAA,YACfhU,EAAA,CAAG,IAAKgU,CAAAA,QAAR,CADe,CAAA;AAAA,SALgB;AAAA,QAQnC,IAAI,IAAKC,CAAAA,IAAT,EAAe;AAAA,YACXjU,EAAA,CAAG,IAAKiU,CAAAA,IAAR,CADW,CAAA;AAAA,SARoB;AAAA,QAWnC,IAAI,IAAKC,CAAAA,iBAAT,EAA4B;AAAA,YACxBlU,EAAA,CAAG,IAAKkU,CAAAA,iBAAR,CADwB,CAAA;AAAA,SAXO;AAAA,QAcnC,IAAI,IAAKC,CAAAA,iBAAT,EAA4B;AAAA,YACxBnU,EAAA,CAAG,IAAKmU,CAAAA,iBAAR,CADwB,CAAA;AAAA,SAdO;AAAA,KAlFa;AAAA,IAqGpD/U,aAAA,GAAyB;AAAA,QACrB,OAAO,KAAP,CADqB;AAAA,KArG2B;AAAA,IAyGpDpB,SAAA,GAAkC;AAAA,QAC9B,MAAME,OAAA,GAAU,EAAhB,CAD8B;AAAA,QAE9B,IAAI,IAAK3B,CAAAA,MAAT,EAAiB;AAAA,YACb2B,OAAA,CAAQ,QAAR,CAAA,GAAoB,KAAK3B,MAAL,CAAYyB,SAAZ,EAApB,CADa;AAAA,SAFa;AAAA,QAK9B,IAAI,IAAKgW,CAAAA,QAAT,EAAmB;AAAA,YACf9V,OAAA,CAAQ,UAAR,CAAA,GAAsB,KAAK8V,QAAL,CAAchW,SAAd,EAAtB,CADe;AAAA,SALW;AAAA,QAQ9B,IAAI,IAAKiW,CAAAA,IAAT,EAAe;AAAA,YACX/V,OAAA,CAAQ,MAAR,CAAA,GAAkB,KAAK+V,IAAL,CAAUjW,SAAV,EAAlB,CADW;AAAA,SARe;AAAA,QAW9B,IAAI,IAAKkW,CAAAA,iBAAT,EAA4B;AAAA,YACxBhW,OAAA,CAAQ,qBAAR,CAAA,GAAiC,KAAKgW,iBAAL,CAAuBlW,SAAvB,EAAjC,CADwB;AAAA,SAXE;AAAA,QAc9B,IAAI,IAAKmW,CAAAA,iBAAT,EAA4B;AAAA,YACxBjW,OAAA,CAAQ,qBAAR,CAAA,GAAiC,KAAKiW,iBAAL,CAAuBnW,SAAvB,EAAjC,CADwB;AAAA,SAdE;AAAA,QAiB9B,OAAO;AAAA,YAAC,eAAD;AAAA,YAAkB,IAAKyB,CAAAA,MAAL,CAAYzB,SAAZ,EAAlB;AAAA,YAA2CE,OAA3C;AAAA,SAAP,CAjB8B;AAAA,KAzGkB;AAAA;;ACnCxD;AAUA,MAAMsW,MAAN,CAAmC;AAAA,IAI/Bhf,WAAA,CAAYM,KAAZ,EAA+B;AAAA,QAC3B,IAAKgC,CAAAA,IAAL,GAAY6C,UAAZ,CAD2B;AAAA,QAE3B,IAAK7E,CAAAA,KAAL,GAAaA,KAAb,CAF2B;AAAA,KAJA;AAAA,IAS/B,OAAOD,KAAP,CAAaiJ,IAAb,EAA0CC,OAA1C,EAA4E;AAAA,QACxE,IAAID,IAAA,CAAKlL,MAAL,KAAgB,CAApB;AAAA,YACI,OAAOmL,OAAA,CAAQC,KAAR,CAAc,CAAC,+BAAD,GAAkCF,IAAA,CAAKlL,MAAL,GAAc,CAAhD,EAAkD,SAAlD,CAAd,CAAP,CAFoE;AAAA,QAIxE,MAAMkC,KAAA,GAAQiJ,OAAA,CAAQlJ,KAAR,CAAciJ,IAAA,CAAK,CAAL,CAAd,EAAuB,CAAvB,CAAd,CAJwE;AAAA,QAKxE,IAAI,CAAChJ,KAAL;AAAA,YAAY,OAAO,IAAP,CAL4D;AAAA,QAOxE,IAAIA,KAAA,CAAMgC,IAAN,CAAW4C,IAAX,KAAoB,OAApB,IAA+B5E,KAAA,CAAMgC,IAAN,CAAW4C,IAAX,KAAoB,QAAnD,IAA+D5E,KAAA,CAAMgC,IAAN,CAAW4C,IAAX,KAAoB,OAAvF;AAAA,YACI,OAAOqE,OAAA,CAAQC,KAAR,CAAc,CAAC,qDAAD,GAAwD/I,UAAA,CAASH,KAAA,CAAMgC,IAAf,CAAxD,EAA6E,SAA7E,CAAd,CAAP,CARoE;AAAA,QAUxE,OAAO,IAAI0c,MAAJ,CAAW1e,KAAX,CAAP,CAVwE;AAAA,KAT7C;AAAA,IAsB/BoJ,QAAA,CAASa,GAAT,EAA+C;AAAA,QAC3C,MAAMjK,KAAA,GAAQ,IAAKA,CAAAA,KAAL,CAAWoJ,QAAX,CAAoBa,GAApB,CAAd,CAD2C;AAAA,QAE3C,IAAI,OAAOjK,KAAP,KAAiB,QAArB,EAA+B;AAAA,YAC3B,OAAOA,KAAA,CAAMlC,MAAb,CAD2B;AAAA,SAA/B,MAEO,IAAIsI,KAAA,CAAMC,OAAN,CAAcrG,KAAd,CAAJ,EAA0B;AAAA,YAC7B,OAAOA,KAAA,CAAMlC,MAAb,CAD6B;AAAA,SAA1B,MAEA;AAAA,YACH,MAAM,IAAIyL,cAAJ,CAAiB,CAAC,wDAAD,GAA2DpJ,UAAA,CAASwI,MAAA,CAAO3I,KAAP,CAAT,CAA3D,EAAmF,SAAnF,CAAjB,CAAN,CADG;AAAA,SANoC;AAAA,KAtBhB;AAAA,IAiC/BqJ,SAAA,CAAUa,EAAV,EAAuC;AAAA,QACnCA,EAAA,CAAG,IAAKlK,CAAAA,KAAR,CADmC,CAAA;AAAA,KAjCR;AAAA,IAqC/BsJ,aAAA,GAAyB;AAAA,QACrB,OAAO,KAAP,CADqB;AAAA,KArCM;AAAA,IAyC/BpB,SAAA,GAAkC;AAAA,QAC9B,MAAMC,UAAA,GAAa,CAAC,QAAD,CAAnB,CAD8B;AAAA,QAE9B,IAAKkB,CAAAA,SAAL,CAAeoC,KAAA,IAAS;AAAA,YAAEtD,UAAA,CAAWvF,IAAX,CAAgB6I,KAAA,CAAMvD,SAAN,EAAhB,CAAF,CAAA;AAAA,SAAxB,CAF8B,CAAA;AAAA,QAG9B,OAAOC,UAAP,CAH8B;AAAA,KAzCH;AAAA,CAZnC;AA4DA,eAAA,MAAA;;AC1DA;AAiDA,MAAMwW,WAAA,GAAkC;AAAA;AAEpC,IAAA,IAAA,EAAMhB,MAF8B;AAAA,IAGpC,MAAMC,SAH8B;AAAA,IAIpC,KAAKE,WAJ+B;AAAA,IAKpC,KAAKD,QAL+B;AAAA,IAMpC,MAAMG,kBAN8B;AAAA,IAOpC,MAAMD,eAP8B;AAAA,IAQpC,SAASjU,WAR2B;AAAA,IASpC,MAAMiR,IAT8B;AAAA,IAUpC,WAAWjR,WAVyB;AAAA,IAWpC,QAAQmS,MAX4B;AAAA,IAYpC,YAAYxB,UAZwB;AAAA,IAapC,YAAYjM,kBAbwB;AAAA,IAcpC,UAAUlE,gBAd0B;AAAA,IAepC,SAASQ,eAf2B;AAAA,IAgBpC,MAAMkQ,IAhB8B;AAAA,IAiBpC,YAAYG,SAjBwB;AAAA,IAkBpC,eAAe1B,aAlBqB;AAAA,IAmBpC,mBAAmBA,aAnBiB;AAAA,IAoBpC,mBAAmBA,aApBiB;AAAA,IAqBpC,UAAUiF,QArB0B;AAAA,IAsBpC,OAAO7D,KAtB6B;AAAA,IAuBpC,WAAW9R,SAvByB;AAAA,IAwBpC,SAASsS,OAxB2B;AAAA,IAyBpC,UAAUvR,WAzB0B;AAAA,IA0BpC,iBAAiBmU,YA1BmB;AAAA,IA2BpC,UAAUnU,WA3B0B;AAAA,IA4BpC,SAASsS,OA5B2B;AAAA,IA6BpC,QAAQ7G,MA7B4B;AAAA,IA8BpC,UAAUzL,WA9B0B;AAAA,IA+BpC,cAAcmB,UA/BsB;AAAA,IAgCpC,YAAYA,UAhCwB;AAAA,IAiCpC,aAAaA,UAjCuB;AAAA,IAkCpC,aAAaA,UAlCuB;AAAA,IAmCpC,OAAOiJ,KAnC6B;AAAA,IAoCpC,UAAUR,QApC0B;AAAA,CAAxC,CAnDA;AA0FA,SAASxT,IAAT,CAAc+J,GAAd,EAAmB,CAACtK,CAAD,EAAIC,CAAJ,EAAOC,CAAP,EAAUC,CAAV,CAAnB,EAAiC;AAAA,IAC7BH,CAAA,GAAIA,CAAA,CAAEyJ,QAAF,CAAWa,GAAX,CAAJ,CAD6B;AAAA,IAE7BrK,CAAA,GAAIA,CAAA,CAAEwJ,QAAF,CAAWa,GAAX,CAAJ,CAF6B;AAAA,IAG7BpK,CAAA,GAAIA,CAAA,CAAEuJ,QAAF,CAAWa,GAAX,CAAJ,CAH6B;AAAA,IAI7B,MAAM9K,KAAA,GAAQW,CAAA,GAAIA,CAAA,CAAEsJ,QAAF,CAAWa,GAAX,CAAJ,GAAsB,CAApC,CAJ6B;AAAA,IAK7B,MAAMf,KAAA,GAAQX,YAAA,CAAa5I,CAAb,EAAgBC,CAAhB,EAAmBC,CAAnB,EAAsBV,KAAtB,CAAd,CAL6B;AAAA,IAM7B,IAAI+J,KAAJ;AAAA,QAAW,MAAM,IAAIK,cAAJ,CAAiBL,KAAjB,CAAN,CANkB;AAAA,IAO7B,OAAO,IAAIzJ,OAAJ,CAAUE,CAAA,GAAI,GAAJ,GAAUR,KAApB,EAA2BS,CAAA,GAAI,GAAJ,GAAUT,KAArC,EAA4CU,CAAA,GAAI,GAAJ,GAAUV,KAAtD,EAA6DA,KAA7D,CAAP,CAP6B;AAAA,CA1FjC;AAoGA,SAASuF,GAAT,CAAaP,GAAb,EAAkBya,GAAlB,EAAuB;AAAA,IACnB,OAAOza,GAAA,IAAOya,GAAd,CADmB;AAAA,CApGvB;AAwGA,SAAS9c,GAAT,CAAaqC,GAAb,EAAkBya,GAAlB,EAAuB;AAAA,IACnB,MAAMC,CAAA,GAAID,GAAA,CAAIza,GAAJ,CAAV,CADmB;AAAA,IAEnB,OAAO,OAAO0a,CAAP,KAAa,WAAb,GAA2B,IAA3B,GAAkCA,CAAzC,CAFmB;AAAA,CAxGvB;AA6GA,SAASC,YAAT,CAAsBD,CAAtB,EAAyB/e,CAAzB,EAA4BvC,CAA5B,EAA+BoT,CAA/B,EAAkC;AAAA,IAC9B,OAAOpT,CAAA,IAAKoT,CAAZ,EAAe;AAAA,QACX,MAAMoO,CAAA,GAAKxhB,CAAA,GAAIoT,CAAL,IAAW,CAArB,CADW;AAAA,QAEX,IAAI7Q,CAAA,CAAEif,CAAF,MAASF,CAAb;AAAA,YACI,OAAO,IAAP,CAHO;AAAA,QAIX,IAAI/e,CAAA,CAAEif,CAAF,IAAOF,CAAX;AAAA,YACIlO,CAAA,GAAIoO,CAAA,GAAI,CAAR,CADJ;AAAA;AAAA,YAGIxhB,CAAA,GAAIwhB,CAAA,GAAI,CAAR,CAPO;AAAA,KADe;AAAA,IAU9B,OAAO,KAAP,CAV8B;AAAA,CA7GlC;AA0HA,SAASC,OAAT,CAAiBhd,IAAjB,EAAsC;AAAA,IAClC,OAAO,EAACA,IAAD,EAAP,CADkC;AAAA,CA1HtC;AA8HAoL,oBAAA,CAAmBmB,QAAnB,CAA4BoQ,WAA5B,EAAyC;AAAA,IACrC,OAAS,EAAA;AAAA,QACLxZ,SADK;AAAA,QAEL,CAACL,UAAD,CAFK;AAAA,QAGL,CAACmF,GAAD,EAAM,CAAC4U,CAAD,CAAN,KAAc;AAAA,YAAE,MAAM,IAAItV,cAAJ,CAAiBsV,CAAA,CAAEzV,QAAF,CAAWa,GAAX,CAAjB,CAAN,CAAF;AAAA,SAHT;AAAA,KAD4B;AAAA,IAMrC,QAAU,EAAA;AAAA,QACNnF,UADM;AAAA,QAEN,CAACI,SAAD,CAFM;AAAA,QAGN,CAAC+E,GAAD,EAAM,CAAC4U,CAAD,CAAN,KAAcI,UAAA,CAAatW,MAAA,CAAOkW,CAAA,CAAEzV,QAAF,CAAWa,GAAX,CAAP,CAAb,CAHR;AAAA,KAN2B;AAAA,IAWrC,SAAW,EAAA;AAAA,QACP1E,OAAA,CAAMV,UAAN,EAAkB,CAAlB,CADO;AAAA,QAEP,CAACG,SAAD,CAFO;AAAA,QAGP,CAACiF,GAAD,EAAM,CAAC4U,CAAD,CAAN,KAAc;AAAA,YACV,OAAOA,CAAA,CAAEzV,QAAF,CAAWa,GAAX,CAAA,CAAgB7J,OAAhB,EAAP,CADU;AAAA,SAHP;AAAA,KAX0B;AAAA,IAkBrC,KAAO,EAAA;AAAA,QACH4E,SADG;AAAA,QAEH;AAAA,YAACH,UAAD;AAAA,YAAaA,UAAb;AAAA,YAAyBA,UAAzB;AAAA,SAFG;AAAA,QAGH3E,IAHG;AAAA,KAlB8B;AAAA,IAuBrC,MAAQ,EAAA;AAAA,QACJ8E,SADI;AAAA,QAEJ;AAAA,YAACH,UAAD;AAAA,YAAaA,UAAb;AAAA,YAAyBA,UAAzB;AAAA,YAAqCA,UAArC;AAAA,SAFI;AAAA,QAGJ3E,IAHI;AAAA,KAvB6B;AAAA,IA4BrC,KAAO,EAAA;AAAA,QACH8B,IAAA,EAAM+C,WADH;AAAA,QAEH0I,SAAA,EAAW;AAAA,YACP;AAAA,gBACI,CAAC3I,UAAD,CADJ;AAAA,gBAEI,CAACmF,GAAD,EAAM,CAAC9F,GAAD,CAAN,KAAgBO,GAAA,CAAIP,GAAA,CAAIiF,QAAJ,CAAaa,GAAb,CAAJ,EAAuBA,GAAA,CAAIuC,UAAJ,EAAvB,CAFpB;AAAA,aADO;AAAA,YAIJ;AAAA,gBACC;AAAA,oBAAC1H,UAAD;AAAA,oBAAaG,UAAb;AAAA,iBADD;AAAA,gBAEC,CAACgF,GAAD,EAAM,CAAC9F,GAAD,EAAMya,GAAN,CAAN,KAAqBla,GAAA,CAAIP,GAAA,CAAIiF,QAAJ,CAAaa,GAAb,CAAJ,EAAuB2U,GAAA,CAAIxV,QAAJ,CAAaa,GAAb,CAAvB,CAFtB;AAAA,aAJI;AAAA,SAFR;AAAA,KA5B8B;AAAA,IAwCrC,KAAO,EAAA;AAAA,QACHjI,IAAA,EAAMkD,SADH;AAAA,QAEHuI,SAAA,EAAW;AAAA,YACP;AAAA,gBACI,CAAC3I,UAAD,CADJ;AAAA,gBAEI,CAACmF,GAAD,EAAM,CAAC9F,GAAD,CAAN,KAAgBrC,GAAA,CAAIqC,GAAA,CAAIiF,QAAJ,CAAaa,GAAb,CAAJ,EAAuBA,GAAA,CAAIuC,UAAJ,EAAvB,CAFpB;AAAA,aADO;AAAA,YAIJ;AAAA,gBACC;AAAA,oBAAC1H,UAAD;AAAA,oBAAaG,UAAb;AAAA,iBADD;AAAA,gBAEC,CAACgF,GAAD,EAAM,CAAC9F,GAAD,EAAMya,GAAN,CAAN,KAAqB9c,GAAA,CAAIqC,GAAA,CAAIiF,QAAJ,CAAaa,GAAb,CAAJ,EAAuB2U,GAAA,CAAIxV,QAAJ,CAAaa,GAAb,CAAvB,CAFtB;AAAA,aAJI;AAAA,SAFR;AAAA,KAxC8B;AAAA,IAoDrC,eAAiB,EAAA;AAAA,QACb/E,SADa;AAAA,QAEb,CAACJ,UAAD,CAFa;AAAA,QAGb,CAACmF,GAAD,EAAM,CAAC9F,GAAD,CAAN,KAAgBrC,GAAA,CAAIqC,GAAA,CAAIiF,QAAJ,CAAaa,GAAb,CAAJ,EAAuBA,GAAA,CAAI6B,YAAJ,IAAoB,EAA3C,CAHH;AAAA,KApDoB;AAAA,IAyDrC,YAAc,EAAA;AAAA,QACV7G,UADU;AAAA,QAEV,EAFU;AAAA,QAGTgF,GAAD,IAASA,GAAA,CAAIuC,UAAJ,EAHC;AAAA,KAzDuB;AAAA,IA8DrC,eAAiB,EAAA;AAAA,QACb1H,UADa;AAAA,QAEb,EAFa;AAAA,QAGZmF,GAAD,IAASA,GAAA,CAAIoC,YAAJ,EAHI;AAAA,KA9DoB;AAAA,IAmErC,IAAM,EAAA;AAAA,QACFnH,SADE;AAAA,QAEF,EAFE;AAAA,QAGD+E,GAAD,IAASA,GAAA,CAAImC,EAAJ,EAHP;AAAA,KAnE+B;AAAA,IAwErC,MAAQ,EAAA;AAAA,QACJvH,UADI;AAAA,QAEJ,EAFI;AAAA,QAGHoF,GAAD,IAASA,GAAA,CAAI2B,OAAJ,CAAYjJ,IAHjB;AAAA,KAxE6B;AAAA,IA6ErC,OAAS,EAAA;AAAA,QACLkC,UADK;AAAA,QAEL,EAFK;AAAA,QAGJoF,GAAD,IAASA,GAAA,CAAI2B,OAAJ,CAAYsT,KAAZ,IAAqB,CAHzB;AAAA,KA7E4B;AAAA,IAkFrC,sBAAwB,EAAA;AAAA,QACpBra,UADoB;AAAA,QAEpB,EAFoB;AAAA,QAGnBoF,GAAD,IAASA,GAAA,CAAIwC,kBAAJ,EAHW;AAAA,KAlFa;AAAA,IAuFrC,iBAAmB,EAAA;AAAA,QACf5H,UADe;AAAA,QAEf,EAFe;AAAA,QAGdoF,GAAD,IAASA,GAAA,CAAI2B,OAAJ,CAAYuT,cAAZ,IAA8B,CAHxB;AAAA,KAvFkB;AAAA,IA4FrC,eAAiB,EAAA;AAAA,QACbta,UADa;AAAA,QAEb,EAFa;AAAA,QAGZoF,GAAD,IAASA,GAAA,CAAI2B,OAAJ,CAAYwT,YAAZ,IAA4B,CAHxB;AAAA,KA5FoB;AAAA,IAiGrC,qBAAuB,EAAA;AAAA,QACnBva,UADmB;AAAA,QAEnB,EAFmB;AAAA,QAGlBoF,GAAD,IAASA,GAAA,CAAI2B,OAAJ,CAAYyT,iBAAZ,IAAiC,CAHvB;AAAA,KAjGc;AAAA,IAsGrC,aAAe,EAAA;AAAA,QACXna,SADW;AAAA,QAEX,EAFW;AAAA,QAGV+E,GAAD,IAASA,GAAA,CAAI2B,OAAJ,CAAY0T,WAAZ,KAA4Brf,SAA5B,GAAwC,IAAxC,GAA+CgK,GAAA,CAAI2B,OAAJ,CAAY0T,WAHzD;AAAA,KAtGsB;AAAA,IA2GrC,GAAK,EAAA;AAAA,QACDza,UADC;AAAA,QAEDma,OAAA,CAAQna,UAAR,CAFC;AAAA,QAGD,CAACoF,GAAD,EAAMjB,IAAN,KAAe;AAAA,YACX,IAAIrF,MAAA,GAAS,CAAb,CADW;AAAA,YAEX,KAAW0G,MAAAA,GAAX,IAAkBrB,IAAlB,EAAwB;AAAA,gBACpBrF,MAAA,IAAU0G,GAAA,CAAIjB,QAAJ,CAAaa,GAAb,CAAV,CADoB;AAAA,aAFb;AAAA,YAKX,OAAOtG,MAAP,CALW;AAAA,SAHd;AAAA,KA3GgC;AAAA,IAsHrC,GAAK,EAAA;AAAA,QACDkB,UADC;AAAA,QAEDma,OAAA,CAAQna,UAAR,CAFC;AAAA,QAGD,CAACoF,GAAD,EAAMjB,IAAN,KAAe;AAAA,YACX,IAAIrF,MAAA,GAAS,CAAb,CADW;AAAA,YAEX,KAAW0G,MAAAA,GAAX,IAAkBrB,IAAlB,EAAwB;AAAA,gBACpBrF,MAAA,IAAU0G,GAAA,CAAIjB,QAAJ,CAAaa,GAAb,CAAV,CADoB;AAAA,aAFb;AAAA,YAKX,OAAOtG,MAAP,CALW;AAAA,SAHd;AAAA,KAtHgC;AAAA,IAiIrC,GAAK,EAAA;AAAA,QACD3B,IAAA,EAAM6C,UADL;AAAA,QAED4I,SAAA,EAAW;AAAA,YACP;AAAA,gBACI;AAAA,oBAAC5I,UAAD;AAAA,oBAAaA,UAAb;AAAA,iBADJ;AAAA,gBAEI,CAACoF,GAAD,EAAM,CAACnK,CAAD,EAAID,CAAJ,CAAN,KAAiBC,CAAA,CAAEsJ,QAAF,CAAWa,GAAX,CAAkBpK,GAAAA,CAAA,CAAEuJ,QAAF,CAAWa,GAAX,CAFvC;AAAA,aADO;AAAA,YAIJ;AAAA,gBACC,CAACpF,UAAD,CADD;AAAA,gBAEC,CAACoF,GAAD,EAAM,CAACnK,CAAD,CAAN,KAAc,CAACA,CAAA,CAAEsJ,QAAF,CAAWa,GAAX,CAFhB;AAAA,aAJI;AAAA,SAFV;AAAA,KAjIgC;AAAA,IA6IrC,GAAK,EAAA;AAAA,QACDpF,UADC;AAAA,QAED;AAAA,YAACA,UAAD;AAAA,YAAaA,UAAb;AAAA,SAFC;AAAA,QAGD,CAACoF,GAAD,EAAM,CAACnK,CAAD,EAAID,CAAJ,CAAN,KAAiBC,CAAA,CAAEsJ,QAAF,CAAWa,GAAX,CAAkBpK,GAAAA,CAAA,CAAEuJ,QAAF,CAAWa,GAAX,CAHlC;AAAA,KA7IgC;AAAA,IAkJrC,GAAK,EAAA;AAAA,QACDpF,UADC;AAAA,QAED;AAAA,YAACA,UAAD;AAAA,YAAaA,UAAb;AAAA,SAFC;AAAA,QAGD,CAACoF,GAAD,EAAM,CAACnK,CAAD,EAAID,CAAJ,CAAN,KAAiBC,CAAA,CAAEsJ,QAAF,CAAWa,GAAX,CAAkBpK,GAAAA,CAAA,CAAEuJ,QAAF,CAAWa,GAAX,CAHlC;AAAA,KAlJgC;AAAA,IAuJrC,KAAO,EAAA;AAAA,QACHpF,UADG;AAAA,QAEH,EAFG;AAAA,QAGH,MAAMrH,IAAA,CAAK+hB,GAHR;AAAA,KAvJ8B;AAAA,IA4JrC,IAAM,EAAA;AAAA,QACF1a,UADE;AAAA,QAEF,EAFE;AAAA,QAGF,MAAMrH,IAAA,CAAK2R,EAHT;AAAA,KA5J+B;AAAA,IAiKrC,GAAK,EAAA;AAAA,QACDtK,UADC;AAAA,QAED,EAFC;AAAA,QAGD,MAAMrH,IAAA,CAAKgiB,CAHV;AAAA,KAjKgC;AAAA,IAsKrC,GAAK,EAAA;AAAA,QACD3a,UADC;AAAA,QAED;AAAA,YAACA,UAAD;AAAA,YAAaA,UAAb;AAAA,SAFC;AAAA,QAGD,CAACoF,GAAD,EAAM,CAACpK,CAAD,EAAIL,CAAJ,CAAN,KAAiBhC,IAAA,CAAKoS,GAAL,CAAS/P,CAAA,CAAEuJ,QAAF,CAAWa,GAAX,CAAT,EAA0BzK,CAAA,CAAE4J,QAAF,CAAWa,GAAX,CAA1B,CAHhB;AAAA,KAtKgC;AAAA,IA2KrC,MAAQ,EAAA;AAAA,QACJpF,UADI;AAAA,QAEJ,CAACA,UAAD,CAFI;AAAA,QAGJ,CAACoF,GAAD,EAAM,CAAC0C,CAAD,CAAN,KAAcnP,IAAA,CAAKqb,IAAL,CAAUlM,CAAA,CAAEvD,QAAF,CAAWa,GAAX,CAAV,CAHV;AAAA,KA3K6B;AAAA,IAgLrC,OAAS,EAAA;AAAA,QACLpF,UADK;AAAA,QAEL,CAACA,UAAD,CAFK;AAAA,QAGL,CAACoF,GAAD,EAAM,CAACwV,CAAD,CAAN,KAAcjiB,IAAA,CAAK4R,GAAL,CAASqQ,CAAA,CAAErW,QAAF,CAAWa,GAAX,CAAT,CAA4BzM,GAAAA,IAAA,CAAKkiB,IAH1C;AAAA,KAhL4B;AAAA,IAqLrC,IAAM,EAAA;AAAA,QACF7a,UADE;AAAA,QAEF,CAACA,UAAD,CAFE;AAAA,QAGF,CAACoF,GAAD,EAAM,CAACwV,CAAD,CAAN,KAAcjiB,IAAA,CAAK4R,GAAL,CAASqQ,CAAA,CAAErW,QAAF,CAAWa,GAAX,CAAT,CAHZ;AAAA,KArL+B;AAAA,IA0LrC,MAAQ,EAAA;AAAA,QACJpF,UADI;AAAA,QAEJ,CAACA,UAAD,CAFI;AAAA,QAGJ,CAACoF,GAAD,EAAM,CAACwV,CAAD,CAAN,KAAcjiB,IAAA,CAAK4R,GAAL,CAASqQ,CAAA,CAAErW,QAAF,CAAWa,GAAX,CAAT,CAA4BzM,GAAAA,IAAA,CAAK+hB,GAH3C;AAAA,KA1L6B;AAAA,IA+LrC,KAAO,EAAA;AAAA,QACH1a,UADG;AAAA,QAEH,CAACA,UAAD,CAFG;AAAA,QAGH,CAACoF,GAAD,EAAM,CAACwV,CAAD,CAAN,KAAcjiB,IAAA,CAAKyb,GAAL,CAASwG,CAAA,CAAErW,QAAF,CAAWa,GAAX,CAAT,CAHX;AAAA,KA/L8B;AAAA,IAoMrC,KAAO,EAAA;AAAA,QACHpF,UADG;AAAA,QAEH,CAACA,UAAD,CAFG;AAAA,QAGH,CAACoF,GAAD,EAAM,CAACwV,CAAD,CAAN,KAAcjiB,IAAA,CAAKwb,GAAL,CAASyG,CAAA,CAAErW,QAAF,CAAWa,GAAX,CAAT,CAHX;AAAA,KApM8B;AAAA,IAyMrC,KAAO,EAAA;AAAA,QACHpF,UADG;AAAA,QAEH,CAACA,UAAD,CAFG;AAAA,QAGH,CAACoF,GAAD,EAAM,CAACwV,CAAD,CAAN,KAAcjiB,IAAA,CAAK6R,GAAL,CAASoQ,CAAA,CAAErW,QAAF,CAAWa,GAAX,CAAT,CAHX;AAAA,KAzM8B;AAAA,IA8MrC,MAAQ,EAAA;AAAA,QACJpF,UADI;AAAA,QAEJ,CAACA,UAAD,CAFI;AAAA,QAGJ,CAACoF,GAAD,EAAM,CAACwV,CAAD,CAAN,KAAcjiB,IAAA,CAAKmiB,IAAL,CAAUF,CAAA,CAAErW,QAAF,CAAWa,GAAX,CAAV,CAHV;AAAA,KA9M6B;AAAA,IAmNrC,MAAQ,EAAA;AAAA,QACJpF,UADI;AAAA,QAEJ,CAACA,UAAD,CAFI;AAAA,QAGJ,CAACoF,GAAD,EAAM,CAACwV,CAAD,CAAN,KAAcjiB,IAAA,CAAKoiB,IAAL,CAAUH,CAAA,CAAErW,QAAF,CAAWa,GAAX,CAAV,CAHV;AAAA,KAnN6B;AAAA,IAwNrC,MAAQ,EAAA;AAAA,QACJpF,UADI;AAAA,QAEJ,CAACA,UAAD,CAFI;AAAA,QAGJ,CAACoF,GAAD,EAAM,CAACwV,CAAD,CAAN,KAAcjiB,IAAA,CAAKqiB,IAAL,CAAUJ,CAAA,CAAErW,QAAF,CAAWa,GAAX,CAAV,CAHV;AAAA,KAxN6B;AAAA,IA6NrC,KAAO,EAAA;AAAA,QACHpF,UADG;AAAA,QAEHma,OAAA,CAAQna,UAAR,CAFG;AAAA,QAGH,CAACoF,GAAD,EAAMjB,IAAN,KAAexL,IAAA,CAAKqR,GAAL,CAAS,GAAG7F,IAAA,CAAKzH,GAAL,CAAS8I,GAAA,IAAOA,GAAA,CAAIjB,QAAJ,CAAaa,GAAb,CAAhB,CAAZ,CAHZ;AAAA,KA7N8B;AAAA,IAkOrC,KAAO,EAAA;AAAA,QACHpF,UADG;AAAA,QAEHma,OAAA,CAAQna,UAAR,CAFG;AAAA,QAGH,CAACoF,GAAD,EAAMjB,IAAN,KAAexL,IAAA,CAAKsR,GAAL,CAAS,GAAG9F,IAAA,CAAKzH,GAAL,CAAS8I,GAAA,IAAOA,GAAA,CAAIjB,QAAJ,CAAaa,GAAb,CAAhB,CAAZ,CAHZ;AAAA,KAlO8B;AAAA,IAuOrC,KAAO,EAAA;AAAA,QACHpF,UADG;AAAA,QAEH,CAACA,UAAD,CAFG;AAAA,QAGH,CAACoF,GAAD,EAAM,CAACwV,CAAD,CAAN,KAAcjiB,IAAA,CAAK6Z,GAAL,CAASoI,CAAA,CAAErW,QAAF,CAAWa,GAAX,CAAT,CAHX;AAAA,KAvO8B;AAAA,IA4OrC,OAAS,EAAA;AAAA,QACLpF,UADK;AAAA,QAEL,CAACA,UAAD,CAFK;AAAA,QAGL,CAACoF,GAAD,EAAM,CAACwV,CAAD,CAAN,KAAc;AAAA,YACV,MAAMZ,CAAA,GAAIY,CAAA,CAAErW,QAAF,CAAWa,GAAX,CAAV,CADU;AAAA;AAKV;AAAA;AAAA,YAAA,OAAO4U,CAAA,GAAI,CAAJ,GAAQ,CAACrhB,IAAA,CAAKC,KAAL,CAAW,CAACohB,CAAZ,CAAT,GAA0BrhB,IAAA,CAAKC,KAAL,CAAWohB,CAAX,CAAjC,CALU;AAAA,SAHT;AAAA,KA5O4B;AAAA,IAuPrC,OAAS,EAAA;AAAA,QACLha,UADK;AAAA,QAEL,CAACA,UAAD,CAFK;AAAA,QAGL,CAACoF,GAAD,EAAM,CAACwV,CAAD,CAAN,KAAcjiB,IAAA,CAAKuM,KAAL,CAAW0V,CAAA,CAAErW,QAAF,CAAWa,GAAX,CAAX,CAHT;AAAA,KAvP4B;AAAA,IA4PrC,MAAQ,EAAA;AAAA,QACJpF,UADI;AAAA,QAEJ,CAACA,UAAD,CAFI;AAAA,QAGJ,CAACoF,GAAD,EAAM,CAACwV,CAAD,CAAN,KAAcjiB,IAAA,CAAKsiB,IAAL,CAAUL,CAAA,CAAErW,QAAF,CAAWa,GAAX,CAAV,CAHV;AAAA,KA5P6B;AAAA,IAiQrC,WAAa,EAAA;AAAA,QACTlF,WADS;AAAA,QAET;AAAA,YAACD,UAAD;AAAA,YAAaI,SAAb;AAAA,SAFS;AAAA,QAGT,CAAC+E,GAAD,EAAM,CAAC6K,CAAD,EAAI+J,CAAJ,CAAN,KAAiB5U,GAAA,CAAIuC,UAAJ,GAAkBsI,CAAD,CAASjU,KAA1B,CAAsCge,KAAAA,CAAD,CAAShe,KAHtD;AAAA,KAjQwB;AAAA,IAsQrC,cAAgB,EAAA;AAAA,QACZkE,WADY;AAAA,QAEZ,CAACG,SAAD,CAFY;AAAA,QAGZ,CAAC+E,GAAD,EAAM,CAAC4U,CAAD,CAAN,KAAc5U,GAAA,CAAImC,EAAJ,EAAcyS,KAAAA,CAAD,CAAShe,KAHxB;AAAA,KAtQqB;AAAA,IA2QrC,gBAAkB,EAAA;AAAA,QACdkE,WADc;AAAA,QAEd,CAACD,UAAD,CAFc;AAAA,QAGd,CAACmF,GAAD,EAAM,CAAC4U,CAAD,CAAN,KAAc5U,GAAA,CAAIoC,YAAJ,EAAwBwS,KAAAA,CAAD,CAAShe,KAHhC;AAAA,KA3QmB;AAAA,IAgRrC,UAAY,EAAA;AAAA,QACRkE,WADQ;AAAA,QAER;AAAA,YAACD,UAAD;AAAA,YAAaI,SAAb;AAAA,SAFQ;AAAA,QAGR,CAAC+E,GAAD,EAAM,CAAC6K,CAAD,EAAI+J,CAAJ,CAAN,KAAiB;AAAA,YACb,MAAM/e,CAAA,GAAImK,GAAA,CAAIuC,UAAJ,EAAA,CAAkBsI,CAAD,CAASjU,KAA1B,CAAV,CADa;AAAA,YAEb,MAAMhB,CAAA,GAAKgf,CAAD,CAAShe,KAAnB,CAFa;AAAA,YAGb,OAAO,OAAOf,CAAP,KAAa,OAAOD,CAApB,IAAyBC,CAAA,GAAID,CAApC,CAHa;AAAA,SAHT;AAAA,KAhRyB;AAAA,IAyRrC,aAAe,EAAA;AAAA,QACXkF,WADW;AAAA,QAEX,CAACG,SAAD,CAFW;AAAA,QAGX,CAAC+E,GAAD,EAAM,CAAC4U,CAAD,CAAN,KAAc;AAAA,YACV,MAAM/e,CAAA,GAAImK,GAAA,CAAImC,EAAJ,EAAV,CADU;AAAA,YAEV,MAAMvM,CAAA,GAAKgf,CAAD,CAAShe,KAAnB,CAFU;AAAA,YAGV,OAAO,OAAOf,CAAP,KAAa,OAAOD,CAApB,IAAyBC,CAAA,GAAID,CAApC,CAHU;AAAA,SAHH;AAAA,KAzRsB;AAAA,IAkSrC,UAAY,EAAA;AAAA,QACRkF,WADQ;AAAA,QAER;AAAA,YAACD,UAAD;AAAA,YAAaI,SAAb;AAAA,SAFQ;AAAA,QAGR,CAAC+E,GAAD,EAAM,CAAC6K,CAAD,EAAI+J,CAAJ,CAAN,KAAiB;AAAA,YACb,MAAM/e,CAAA,GAAImK,GAAA,CAAIuC,UAAJ,EAAA,CAAkBsI,CAAD,CAASjU,KAA1B,CAAV,CADa;AAAA,YAEb,MAAMhB,CAAA,GAAKgf,CAAD,CAAShe,KAAnB,CAFa;AAAA,YAGb,OAAO,OAAOf,CAAP,KAAa,OAAOD,CAApB,IAAyBC,CAAA,GAAID,CAApC,CAHa;AAAA,SAHT;AAAA,KAlSyB;AAAA,IA2SrC,aAAe,EAAA;AAAA,QACXkF,WADW;AAAA,QAEX,CAACG,SAAD,CAFW;AAAA,QAGX,CAAC+E,GAAD,EAAM,CAAC4U,CAAD,CAAN,KAAc;AAAA,YACV,MAAM/e,CAAA,GAAImK,GAAA,CAAImC,EAAJ,EAAV,CADU;AAAA,YAEV,MAAMvM,CAAA,GAAKgf,CAAD,CAAShe,KAAnB,CAFU;AAAA,YAGV,OAAO,OAAOf,CAAP,KAAa,OAAOD,CAApB,IAAyBC,CAAA,GAAID,CAApC,CAHU;AAAA,SAHH;AAAA,KA3SsB;AAAA,IAoTrC,WAAa,EAAA;AAAA,QACTkF,WADS;AAAA,QAET;AAAA,YAACD,UAAD;AAAA,YAAaI,SAAb;AAAA,SAFS;AAAA,QAGT,CAAC+E,GAAD,EAAM,CAAC6K,CAAD,EAAI+J,CAAJ,CAAN,KAAiB;AAAA,YACb,MAAM/e,CAAA,GAAImK,GAAA,CAAIuC,UAAJ,EAAA,CAAkBsI,CAAD,CAASjU,KAA1B,CAAV,CADa;AAAA,YAEb,MAAMhB,CAAA,GAAKgf,CAAD,CAAShe,KAAnB,CAFa;AAAA,YAGb,OAAO,OAAOf,CAAP,KAAa,OAAOD,CAApB,IAAyBC,CAAA,IAAKD,CAArC,CAHa;AAAA,SAHR;AAAA,KApTwB;AAAA,IA6TrC,cAAgB,EAAA;AAAA,QACZkF,WADY;AAAA,QAEZ,CAACG,SAAD,CAFY;AAAA,QAGZ,CAAC+E,GAAD,EAAM,CAAC4U,CAAD,CAAN,KAAc;AAAA,YACV,MAAM/e,CAAA,GAAImK,GAAA,CAAImC,EAAJ,EAAV,CADU;AAAA,YAEV,MAAMvM,CAAA,GAAKgf,CAAD,CAAShe,KAAnB,CAFU;AAAA,YAGV,OAAO,OAAOf,CAAP,KAAa,OAAOD,CAApB,IAAyBC,CAAA,IAAKD,CAArC,CAHU;AAAA,SAHF;AAAA,KA7TqB;AAAA,IAsUrC,WAAa,EAAA;AAAA,QACTkF,WADS;AAAA,QAET;AAAA,YAACD,UAAD;AAAA,YAAaI,SAAb;AAAA,SAFS;AAAA,QAGT,CAAC+E,GAAD,EAAM,CAAC6K,CAAD,EAAI+J,CAAJ,CAAN,KAAiB;AAAA,YACb,MAAM/e,CAAA,GAAImK,GAAA,CAAIuC,UAAJ,EAAA,CAAkBsI,CAAD,CAASjU,KAA1B,CAAV,CADa;AAAA,YAEb,MAAMhB,CAAA,GAAKgf,CAAD,CAAShe,KAAnB,CAFa;AAAA,YAGb,OAAO,OAAOf,CAAP,KAAa,OAAOD,CAApB,IAAyBC,CAAA,IAAKD,CAArC,CAHa;AAAA,SAHR;AAAA,KAtUwB;AAAA,IA+UrC,cAAgB,EAAA;AAAA,QACZkF,WADY;AAAA,QAEZ,CAACG,SAAD,CAFY;AAAA,QAGZ,CAAC+E,GAAD,EAAM,CAAC4U,CAAD,CAAN,KAAc;AAAA,YACV,MAAM/e,CAAA,GAAImK,GAAA,CAAImC,EAAJ,EAAV,CADU;AAAA,YAEV,MAAMvM,CAAA,GAAKgf,CAAD,CAAShe,KAAnB,CAFU;AAAA,YAGV,OAAO,OAAOf,CAAP,KAAa,OAAOD,CAApB,IAAyBC,CAAA,IAAKD,CAArC,CAHU;AAAA,SAHF;AAAA,KA/UqB;AAAA,IAwVrC,YAAc,EAAA;AAAA,QACVkF,WADU;AAAA,QAEV,CAACG,SAAD,CAFU;AAAA,QAGV,CAAC+E,GAAD,EAAM,CAAC6K,CAAD,CAAN,KAAeA,CAAD,CAASjU,KAAT,IAAkBoJ,GAAA,CAAIuC,UAAJ,EAHtB;AAAA,KAxVuB;AAAA,IA6VrC,eAAiB,EAAA;AAAA,QACbzH,WADa;AAAA,QAEb,EAFa;AAAA,QAGZkF,GAAD,IAAUA,GAAA,CAAImC,EAAJ,EAAA,KAAa,IAAb,IAAqBnC,GAAA,CAAImC,EAAJ,EAAA,KAAanM,SAH/B;AAAA,KA7VoB;AAAA,IAkWrC,gBAAkB,EAAA;AAAA,QACd8E,WADc;AAAA,QAEd,CAACQ,OAAA,CAAMT,UAAN,CAAD,CAFc;AAAA,QAGd,CAACmF,GAAD,EAAM,CAAC4U,CAAD,CAAN,KAAeA,CAAD,CAAShe,KAAT,CAAe/B,OAAf,CAAuBmL,GAAA,CAAIoC,YAAJ,EAAvB,KAA8C,CAH9C;AAAA,KAlWmB;AAAA,IAuWrC,cAAgB,EAAA;AAAA,QACZtH,WADY;AAAA,QAEZ,CAACQ,OAAA,CAAML,SAAN,CAAD,CAFY;AAAA,QAGZ,CAAC+E,GAAD,EAAM,CAAC4U,CAAD,CAAN,KAAeA,CAAD,CAAShe,KAAT,CAAe/B,OAAf,CAAuBmL,GAAA,CAAImC,EAAJ,EAAvB,KAAoC,CAHtC;AAAA,KAvWqB;AAAA,IA4WrC,iBAAmB,EAAA;AAAA,QACfrH,WADe;AAAA,QAEf;AAAA,YAACD,UAAD;AAAA,YAAaS,OAAA,CAAML,SAAN,CAAb;AAAA,SAFe;AAAA;AAIf,QAAC+E,CAAAA,GAAD,EAAM,CAAC6K,CAAD,EAAI+J,CAAJ,CAAN,KAAkBA,CAAD,CAAShe,KAAT,CAAe/B,OAAf,CAAuBmL,GAAA,CAAIuC,UAAJ,EAAA,CAAkBsI,CAAD,CAASjU,KAA1B,CAAvB,CAAA,IAA4D,CAJ9D;AAAA,KA5WkB;AAAA,IAkXrC,iBAAmB,EAAA;AAAA,QACfkE,WADe;AAAA,QAEf;AAAA,YAACD,UAAD;AAAA,YAAaS,OAAA,CAAML,SAAN,CAAb;AAAA,SAFe;AAAA;AAIf,QAAA,CAAC+E,GAAD,EAAM,CAAC6K,CAAD,EAAI+J,CAAJ,CAAN,KAAiBC,YAAA,CAAa7U,GAAA,CAAIuC,UAAJ,GAAkBsI,CAAD,CAASjU,KAA1B,CAAb,EAAgDge,CAAD,CAAShe,KAAxD,EAA+D,CAA/D,EAAmEge,CAAD,CAAShe,KAAT,CAAe/C,MAAf,GAAwB,CAA1F,CAJF;AAAA,KAlXkB;AAAA,IAwXrC,KAAO,EAAA;AAAA,QACHkE,IAAA,EAAM+C,WADH;AAAA,QAEH0I,SAAA,EAAW;AAAA,YACP;AAAA,gBACI;AAAA,oBAAC1I,WAAD;AAAA,oBAAcA,WAAd;AAAA,iBADJ;AAAA,gBAEI,CAACkF,GAAD,EAAM,CAACnK,CAAD,EAAID,CAAJ,CAAN,KAAiBC,CAAA,CAAEsJ,QAAF,CAAWa,GAAX,CAAmBpK,IAAAA,CAAA,CAAEuJ,QAAF,CAAWa,GAAX,CAFxC;AAAA,aADO;AAAA,YAKP;AAAA,gBACI+U,OAAA,CAAQja,WAAR,CADJ;AAAA,gBAEI,CAACkF,GAAD,EAAMjB,IAAN,KAAe;AAAA,oBACX,KAAWqB,MAAAA,GAAX,IAAkBrB,IAAlB,EAAwB;AAAA,wBACpB,IAAI,CAACqB,GAAA,CAAIjB,QAAJ,CAAaa,GAAb,CAAL;AAAA,4BACI,OAAO,KAAP,CAFgB;AAAA,qBADb;AAAA,oBAKX,OAAO,IAAP,CALW;AAAA,iBAFnB;AAAA,aALO;AAAA,SAFR;AAAA,KAxX8B;AAAA,IA2YrC,KAAO,EAAA;AAAA,QACHjI,IAAA,EAAM+C,WADH;AAAA,QAEH0I,SAAA,EAAW;AAAA,YACP;AAAA,gBACI;AAAA,oBAAC1I,WAAD;AAAA,oBAAcA,WAAd;AAAA,iBADJ;AAAA,gBAEI,CAACkF,GAAD,EAAM,CAACnK,CAAD,EAAID,CAAJ,CAAN,KAAiBC,CAAA,CAAEsJ,QAAF,CAAWa,GAAX,CAAmBpK,IAAAA,CAAA,CAAEuJ,QAAF,CAAWa,GAAX,CAFxC;AAAA,aADO;AAAA,YAKP;AAAA,gBACI+U,OAAA,CAAQja,WAAR,CADJ;AAAA,gBAEI,CAACkF,GAAD,EAAMjB,IAAN,KAAe;AAAA,oBACX,KAAWqB,MAAAA,GAAX,IAAkBrB,IAAlB,EAAwB;AAAA,wBACpB,IAAIqB,GAAA,CAAIjB,QAAJ,CAAaa,GAAb,CAAJ;AAAA,4BACI,OAAO,IAAP,CAFgB;AAAA,qBADb;AAAA,oBAKX,OAAO,KAAP,CALW;AAAA,iBAFnB;AAAA,aALO;AAAA,SAFR;AAAA,KA3Y8B;AAAA,IA8ZrC,GAAK,EAAA;AAAA,QACDlF,WADC;AAAA,QAED,CAACA,WAAD,CAFC;AAAA,QAGD,CAACkF,GAAD,EAAM,CAACpK,CAAD,CAAN,KAAc,CAACA,CAAA,CAAEuJ,QAAF,CAAWa,GAAX,CAHd;AAAA,KA9ZgC;AAAA,IAmarC,qBAAuB,EAAA;AAAA,QACnBlF,WADmB;AAAA,QAEnB,CAACD,UAAD,CAFmB;AAAA;AAInB,QAAA,CAACmF,GAAD,EAAM,CAAC5K,CAAD,CAAN,KAAc;AAAA,YACV,MAAM0gB,iBAAA,GAAoB9V,GAAA,CAAI2B,OAAJ,IAAe3B,GAAA,CAAI2B,OAAJ,CAAYmU,iBAArD,CADU;AAAA,YAEV,IAAIA,iBAAJ,EAAuB;AAAA,gBACnB,OAAOA,iBAAA,CAAkB1gB,CAAA,CAAE+J,QAAF,CAAWa,GAAX,CAAlB,CAAP,CADmB;AAAA,aAFb;AAAA,YAKV,OAAO,IAAP,CALU;AAAA,SAJK;AAAA,KAnac;AAAA,IA+arC,QAAU,EAAA;AAAA,QACNnF,UADM;AAAA,QAEN,CAACA,UAAD,CAFM;AAAA,QAGN,CAACmF,GAAD,EAAM,CAAC5K,CAAD,CAAN,KAAcA,CAAA,CAAE+J,QAAF,CAAWa,GAAX,CAAA,CAAgB+V,WAAhB,EAHR;AAAA,KA/a2B;AAAA,IAobrC,UAAY,EAAA;AAAA,QACRlb,UADQ;AAAA,QAER,CAACA,UAAD,CAFQ;AAAA,QAGR,CAACmF,GAAD,EAAM,CAAC5K,CAAD,CAAN,KAAcA,CAAA,CAAE+J,QAAF,CAAWa,GAAX,CAAA,CAAgBxL,WAAhB,EAHN;AAAA,KApbyB;AAAA,IAybrC,QAAU,EAAA;AAAA,QACNqG,UADM;AAAA,QAENka,OAAA,CAAQ9Z,SAAR,CAFM;AAAA,QAGN,CAAC+E,GAAD,EAAMjB,IAAN,KAAeA,IAAA,CAAKzH,GAAL,CAAS8I,GAAA,IAAOmB,QAAA,CAAcnB,GAAA,CAAIjB,QAAJ,CAAaa,GAAb,CAAd,CAAhB,CAAkDhC,CAAAA,IAAlD,CAAuD,EAAvD,CAHT;AAAA,KAzb2B;AAAA,IA8brC,iBAAmB,EAAA;AAAA,QACfnD,UADe;AAAA,QAEf,CAACM,YAAD,CAFe;AAAA,QAGf,CAAC6E,GAAD,EAAM,CAACtD,QAAD,CAAN,KAAqBA,QAAA,CAASyC,QAAT,CAAkBa,GAAlB,CAAA,CAAuBhD,cAAvB,EAHN;AAAA,KA9bkB;AAAA,CAAzC,CA9HA,CAAA;AAmkBA,kBAAA,WAAA;;ACvjBA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASgZ,OAAT,CAAuBpf,KAAvB,EAA+C;AAAA,IAClD,OAAO;AAAA,QAAC8C,MAAA,EAAQ,SAAT;AAAA,QAAoB9C,KAApB;AAAA,KAAP,CADkD;AAAA,CAZtD;AAgBO,SAASqI,KAAT,CAAqBrI,KAArB,EAA6C;AAAA,IAChD,OAAO;AAAA,QAAC8C,MAAA,EAAQ,OAAT;AAAA,QAAkB9C,KAAlB;AAAA,KAAP,CADgD;AAAA;;ACZpD;AAAO,SAASqf,0BAAT,CAAoCC,IAApC,EAA+E;AAAA,IAClF,OAAOA,IAAA,CAAK,eAAL,CAAA,KAA0B,aAAjC,CADkF;AAAA,CAJtF;AAQO,SAASC,sBAAT,CAAgCD,IAAhC,EAA2E;AAAA,IAC9E,OAAO,CAAC,CAACA,IAAA,CAAK/d,UAAP,IAAqB+d,IAAA,CAAK/d,UAAL,CAAgBrB,UAAhB,CAA2BjC,OAA3B,CAAmC,MAAnC,CAA6C,GAAA,CAAC,CAA1E,CAD8E;AAAA,CARlF;AAYO,SAASuhB,qBAAT,CAA+BF,IAA/B,EAA0E;AAAA,IAC7E,OAAO,CAAC,CAACA,IAAA,CAAK/d,UAAP,IAAqB+d,IAAA,CAAK/d,UAAL,CAAgBsB,YAA5C,CAD6E;AAAA;;ACA1E,SAAS4c,UAAT,CAAoBzf,KAApB,EAA2B;AAAA,IAC9B,OAAO,OAAOA,KAAP,KAAiB,QAAjB,IAA6BA,KAAA,KAAU,IAAvC,IAA+C,CAACuF,KAAA,CAAMC,OAAN,CAAcxF,KAAd,CAAvD,CAD8B;AAAA;;ACuC3B,MAAM0f,eAAN,CAAsB;AAAA,IAQzB7gB,WAAA,CAAY0C,UAAZ,EAAoCpB,YAApC,EAA+E;AAAA,QAC3E,IAAKoB,CAAAA,UAAL,GAAkBA,UAAlB,CAD2E;AAAA,QAE3E,IAAKoe,CAAAA,eAAL,GAAuB,EAAvB,CAF2E;AAAA,QAG3E,KAAKC,UAAL,GAAkB,IAAI9U,mBAAJ,EAAlB,CAH2E;AAAA,QAI3E,IAAA,CAAK+U,aAAL,GAAqB1f,YAAA,GAAe2f,eAAA,CAAgB3f,YAAhB,CAAf,GAA+C,IAApE,CAJ2E;AAAA,QAK3E,KAAK4f,WAAL,GAAmB5f,YAAA,IAAgBA,YAAA,CAAagB,IAAb,KAAsB,MAAtC,GAA+ChB,YAAA,CAAamB,MAA5D,GAAqE,IAAxF,CAL2E;AAAA,KARtD;AAAA,IAgBzB0e,4BAAA,CAA6BjV,OAA7B,EAAwDC,OAAxD,EAA2EC,YAA3E,EAAwGG,SAAxG,EAAqIjB,eAArI,EAAsKe,gBAAtK,EAA2MG,gBAA3M,EAAqOC,mBAArO,EAAqR;AAAA,QACjR,KAAKsU,UAAL,CAAgB7U,OAAhB,GAA0BA,OAA1B,CADiR;AAAA,QAEjR,KAAK6U,UAAL,CAAgB5U,OAAhB,GAA0BA,OAA1B,CAFiR;AAAA,QAGjR,KAAK4U,UAAL,CAAgB3U,YAAhB,GAA+BA,YAA/B,CAHiR;AAAA,QAIjR,IAAA,CAAK2U,UAAL,CAAgBxU,SAAhB,GAA4BA,SAAA,IAAa,IAAzC,CAJiR;AAAA,QAKjR,IAAA,CAAKwU,UAAL,CAAgBzV,eAAhB,GAAkCA,eAAA,IAAmB,IAArD,CALiR;AAAA,QAMjR,KAAKyV,UAAL,CAAgB1U,gBAAhB,GAAmCA,gBAAnC,CANiR;AAAA,QAOjR,IAAA,CAAK0U,UAAL,CAAgBvU,gBAAhB,GAAmCA,gBAAA,IAAoB,IAAvD,CAPiR;AAAA,QAQjR,IAAA,CAAKuU,UAAL,CAAgBtU,mBAAhB,GAAsCA,mBAAA,IAAuB,IAA7D,CARiR;AAAA,QAUjR,OAAO,KAAK/J,UAAL,CAAgBgH,QAAhB,CAAyB,IAAA,CAAKqX,UAA9B,CAAP,CAViR;AAAA,KAhB5P;AAAA,IA6BzBrX,QAAA,CAASwC,OAAT,EAAoCC,OAApC,EAAuDC,YAAvD,EAAoFG,SAApF,EAAiHjB,eAAjH,EAAkJe,gBAAlJ,EAAuLG,gBAAvL,EAAiNC,mBAAjN,EAAiQ;AAAA,QAC7P,KAAKsU,UAAL,CAAgB7U,OAAhB,GAA0BA,OAA1B,CAD6P;AAAA,QAE7P,IAAA,CAAK6U,UAAL,CAAgB5U,OAAhB,GAA0BA,OAAA,IAAW,IAArC,CAF6P;AAAA,QAG7P,IAAA,CAAK4U,UAAL,CAAgB3U,YAAhB,GAA+BA,YAAA,IAAgB,IAA/C,CAH6P;AAAA,QAI7P,IAAA,CAAK2U,UAAL,CAAgBxU,SAAhB,GAA4BA,SAAA,IAAa,IAAzC,CAJ6P;AAAA,QAK7P,IAAA,CAAKwU,UAAL,CAAgBzV,eAAhB,GAAkCA,eAAA,IAAmB,IAArD,CAL6P;AAAA,QAM7P,IAAA,CAAKyV,UAAL,CAAgB1U,gBAAhB,GAAmCA,gBAAA,IAAoB,IAAvD,CAN6P;AAAA,QAO7P,IAAA,CAAK0U,UAAL,CAAgBvU,gBAAhB,GAAmCA,gBAAA,IAAoB,IAAvD,CAP6P;AAAA,QAQ7P,IAAA,CAAKuU,UAAL,CAAgBtU,mBAAhB,GAAsCA,mBAAA,IAAuB,IAA7D,CAR6P;AAAA,QAU7P,IAAI;AAAA,YACA,MAAM2U,GAAA,GAAM,IAAK1e,CAAAA,UAAL,CAAgBgH,QAAhB,CAAyB,IAAA,CAAKqX,UAA9B,CAAZ,CADA;AAAA;AAGA,YAAA,IAAIK,GAAA,KAAQ,IAAR,IAAgBA,GAAA,KAAQ7gB,SAAxB,IAAsC,OAAO6gB,GAAP,KAAe,QAAf,IAA2BA,GAAA,KAAQA,GAA7E,EAAmF;AAAA,gBAC/E,OAAO,IAAKJ,CAAAA,aAAZ,CAD+E;AAAA,aAHnF;AAAA,YAMA,IAAI,IAAKE,CAAAA,WAAL,IAAoB,EAAEE,GAAA,IAAO,IAAA,CAAKF,WAAZ,CAA1B,EAAoD;AAAA,gBAChD,MAAM,IAAIrX,cAAJ,CAAiB,CAAC,4BAAD,GAA+BtH,MAAA,CAAOC,IAAP,CAAY,IAAA,CAAK0e,WAAjB,CAA8Brf,CAAAA,GAA9B,CAAkCsd,CAAA,IAAKhW,IAAA,CAAKC,SAAL,CAAe+V,CAAf,CAAvC,CAA0D5W,CAAAA,IAA1D,CAA+D,IAA/D,CAA/B,EAAoG,YAApG,GAAkHY,IAAA,CAAKC,SAAL,CAAegY,GAAf,CAAlH,EAAsI,SAAtI,CAAjB,CAAN,CADgD;AAAA,aANpD;AAAA,YASA,OAAOA,GAAP,CATA;AAAA,SAAJ,CAUE,OAAOthB,CAAP,EAAU;AAAA,YACR,IAAI,CAAC,IAAKghB,CAAAA,eAAL,CAAqBhhB,CAAA,CAAE4E,OAAvB,CAAL,EAAsC;AAAA,gBAClC,IAAA,CAAKoc,eAAL,CAAqBhhB,CAAA,CAAE4E,OAAvB,CAAA,GAAkC,IAAlC,CADkC;AAAA,gBAElC,IAAI,OAAO2c,OAAP,KAAmB,WAAvB,EAAoC;AAAA,oBAChCA,OAAA,CAAQC,IAAR,CAAaxhB,CAAA,CAAE4E,OAAf,CADgC,CAAA;AAAA,iBAFF;AAAA,aAD9B;AAAA,YAOR,OAAO,IAAKsc,CAAAA,aAAZ,CAPQ;AAAA,SApBiP;AAAA,KA7BxO;AAAA,CAnD7B;AAgHO,SAASO,YAAT,CAAsB7e,UAAtB,EAAkD;AAAA,IACrD,OAAOgE,KAAA,CAAMC,OAAN,CAAcjE,UAAd,CAAA,IAA6BA,UAAA,CAAWtE,MAAX,GAAoB,CAAjD,IACH,OAAOsE,UAAA,CAAW,CAAX,CAAP,KAAyB,QADtB,IACkCA,UAAA,CAAW,CAAX,CAAiBmL,IAAAA,WAD1D,CADqD;AAAA,CAhHzD;AA8HA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAAS2T,gBAAT,CAA0B9e,UAA1B,EAA6CpB,YAA7C,EAAsI;AAAA,IACzI,MAAMmgB,MAAA,GAAS,IAAItT,gBAAJ,CAAmBN,WAAnB,EAAgC,EAAhC,EAAoCvM,YAAA,GAAeogB,eAAA,CAAgBpgB,YAAhB,CAAf,GAA+Cf,SAAnF,CAAf,CADyI;AAAA;AAIzI,IAAA,MAAM+J,MAAA,GAASmX,MAAA,CAAOphB,KAAP,CAAaqC,UAAb,EAAyBnC,SAAzB,EAAoCA,SAApC,EAA+CA,SAA/C,EACXe,YAAA,IAAgBA,YAAA,CAAagB,IAAb,KAAsB,QAAtC,GAAiD,EAACyS,cAAA,EAAgB,QAAjB,EAAjD,GAA8ExU,SADnE,CAAf,CAJyI;AAAA,IAOzI,IAAI,CAAC+J,MAAL,EAAa;AAAA,QAET,OAAOd,KAAA,CAAMiY,MAAA,CAAOhT,MAAb,CAAP,CAFS;AAAA,KAP4H;AAAA,IAYzI,OAAO8R,OAAA,CAAQ,IAAIM,eAAJ,CAAoBvW,MAApB,EAA4BhJ,YAA5B,CAAR,CAAP,CAZyI;AAAA,CA9H7I;AA6IO,MAAMqgB,sBAAN,CAAmD;AAAA,IAKtD3hB,WAAA,CAAYkF,IAAZ,EAAwBxC,UAAxB,EAAqD;AAAA,QACjD,IAAKwC,CAAAA,IAAL,GAAYA,IAAZ,CADiD;AAAA,QAEjD,IAAK0c,CAAAA,gBAAL,GAAwBlf,UAAxB,CAFiD;AAAA,QAGjD,KAAKmf,gBAAL,GAAwB3c,IAAA,KAAU,UAAV,IAAyC,CAACgQ,eAAA,CAA2BxS,UAAA,CAAWA,UAAtC,CAAlE,CAHiD;AAAA,KALC;AAAA,IAWtDye,4BAAA,CAA6BjV,OAA7B,EAAwDC,OAAxD,EAA2EC,YAA3E,EAAwGG,SAAxG,EAAqIjB,eAArI,EAAsKe,gBAAtK,EAAgN;AAAA,QAC5M,OAAO,IAAKuV,CAAAA,gBAAL,CAAsBT,4BAAtB,CAAmDjV,OAAnD,EAA4DC,OAA5D,EAAqEC,YAArE,EAAmFG,SAAnF,EAA8FjB,eAA9F,EAA+Ge,gBAA/G,CAAP,CAD4M;AAAA,KAX1J;AAAA,IAetD3C,QAAA,CAASwC,OAAT,EAAoCC,OAApC,EAAuDC,YAAvD,EAAoFG,SAApF,EAAiHjB,eAAjH,EAAkJe,gBAAlJ,EAA4L;AAAA,QACxL,OAAO,IAAKuV,CAAAA,gBAAL,CAAsBlY,QAAtB,CAA+BwC,OAA/B,EAAwCC,OAAxC,EAAiDC,YAAjD,EAA+DG,SAA/D,EAA0EjB,eAA1E,EAA2Fe,gBAA3F,CAAP,CADwL;AAAA,KAftI;AAAA,CA7I1D;AAiKO,MAAMyV,uBAAN,CAAoD;AAAA,IAQvD9hB,WAAA,CAAYkF,IAAZ,EAAwBxC,UAAxB,EAAqDM,SAArD,EAA+E+e,iBAA/E,EAAsH;AAAA,QAClH,IAAK7c,CAAAA,IAAL,GAAYA,IAAZ,CADkH;AAAA,QAElH,IAAKlC,CAAAA,SAAL,GAAiBA,SAAjB,CAFkH;AAAA,QAGlH,IAAK4e,CAAAA,gBAAL,GAAwBlf,UAAxB,CAHkH;AAAA,QAIlH,KAAKmf,gBAAL,GAAwB3c,IAAA,KAAU,QAAV,IAAuC,CAACgQ,eAAA,CAA2BxS,UAAA,CAAWA,UAAtC,CAAhE,CAJkH;AAAA,QAKlH,IAAKqf,CAAAA,iBAAL,GAAyBA,iBAAzB,CALkH;AAAA,KAR/D;AAAA,IAgBvDZ,4BAAA,CAA6BjV,OAA7B,EAAwDC,OAAxD,EAA2EC,YAA3E,EAAwGG,SAAxG,EAAqIjB,eAArI,EAAsKe,gBAAtK,EAAgN;AAAA,QAC5M,OAAO,IAAKuV,CAAAA,gBAAL,CAAsBT,4BAAtB,CAAmDjV,OAAnD,EAA4DC,OAA5D,EAAqEC,YAArE,EAAmFG,SAAnF,EAA8FjB,eAA9F,EAA+Ge,gBAA/G,CAAP,CAD4M;AAAA,KAhBzJ;AAAA,IAoBvD3C,QAAA,CAASwC,OAAT,EAAoCC,OAApC,EAAuDC,YAAvD,EAAoFG,SAApF,EAAiHjB,eAAjH,EAAkJe,gBAAlJ,EAA4L;AAAA,QACxL,OAAO,IAAKuV,CAAAA,gBAAL,CAAsBlY,QAAtB,CAA+BwC,OAA/B,EAAwCC,OAAxC,EAAiDC,YAAjD,EAA+DG,SAA/D,EAA0EjB,eAA1E,EAA2Fe,gBAA3F,CAAP,CADwL;AAAA,KApBrI;AAAA,IAwBvD6N,mBAAA,CAAoB5Z,KAApB,EAAmC6Z,KAAnC,EAAkDC,KAAlD,EAAyE;AAAA,QACrE,IAAI,IAAK2H,CAAAA,iBAAT,EAA4B;AAAA,YACxB,OAAOhI,aAAA,CAAYG,mBAAZ,CAAgC,IAAK6H,CAAAA,iBAArC,EAAwDzhB,KAAxD,EAA+D6Z,KAA/D,EAAsEC,KAAtE,CAAP,CADwB;AAAA,SAA5B,MAEO;AAAA,YACH,OAAO,CAAP,CADG;AAAA,SAH8D;AAAA,KAxBlB;AAAA,CAjK3D;AAoOO,SAAS4H,wBAAT,CAAkCtf,UAAlC,EAAqDpB,YAArD,EAAqJ;AAAA,IACxJoB,UAAA,GAAa8e,gBAAA,CAAiB9e,UAAjB,EAA6BpB,YAA7B,CAAb,CADwJ;AAAA,IAExJ,IAAIoB,UAAA,CAAWuB,MAAX,KAAsB,OAA1B,EAAmC;AAAA,QAC/B,OAAOvB,UAAP,CAD+B;AAAA,KAFqH;AAAA,IAMxJ,MAAM4H,MAAA,GAAS5H,UAAA,CAAWvB,KAAX,CAAiBuB,UAAhC,CANwJ;AAAA,IAQxJ,MAAM0R,mBAAA,GAAoBc,iBAAA,CAA6B5K,MAA7B,CAA1B,CARwJ;AAAA,IASxJ,IAAI,CAAC8J,mBAAD,IAAsB,CAACoM,0BAAA,CAA2Blf,YAA3B,CAA3B,EAAqE;AAAA,QACjE,OAAOkI,KAAA,CAAM,CAAC,IAAIhF,cAAJ,CAAiB,EAAjB,EAAqB,gCAArB,CAAD,CAAN,CAAP,CADiE;AAAA,KATmF;AAAA,IAaxJ,MAAMyd,cAAA,GAAiB/M,wBAAA,CAAoC5K,MAApC,EAA4C;AAAA,QAAC,MAAD;AAAA,QAAS,OAAT;AAAA,QAAkB,sBAAlB;AAAA,KAA5C,CAAvB,CAbwJ;AAAA,IAcxJ,IAAI,CAAC2X,cAAD,IAAmB,CAACvB,sBAAA,CAAuBpf,YAAvB,CAAxB,EAA8D;AAAA,QAC1D,OAAOkI,KAAA,CAAM,CAAC,IAAIhF,cAAJ,CAAiB,EAAjB,EAAqB,gCAArB,CAAD,CAAN,CAAP,CAD0D;AAAA,KAd0F;AAAA,IAkBxJ,MAAM0d,SAAA,GAAYC,aAAA,CAAc7X,MAAd,CAAlB,CAlBwJ;AAAA,IAmBxJ,IAAI,CAAC4X,SAAD,IAAc,CAACD,cAAnB,EAAmC;AAAA,QAC/B,OAAOzY,KAAA,CAAM,CAAC,IAAIhF,cAAJ,CAAiB,EAAjB,EAAqB,gGAArB,CAAD,CAAN,CAAP,CAD+B;AAAA,KAAnC,MAEO,IAAI0d,SAAA,YAAqB1d,cAAzB,EAAuC;AAAA,QAC1C,OAAOgF,KAAA,CAAM,CAAC0Y,SAAD,CAAN,CAAP,CAD0C;AAAA,KAAvC,MAEA,IAAIA,SAAA,YAAqBnI,aAArB,IAAoC,CAAC4G,qBAAA,CAAsBrf,YAAtB,CAAzC,EAA8E;AAAA,QACjF,OAAOkI,KAAA,CAAM,CAAC,IAAIhF,cAAJ,CAAiB,EAAjB,EAAqB,6DAArB,CAAD,CAAN,CAAP,CADiF;AAAA,KAvBmE;AAAA,IA2BxJ,IAAI,CAAC0d,SAAL,EAAgB;AAAA,QACZ,OAAO3B,OAAA,CAAQnM,mBAAA,GACV,IAAIuN,sBAAJ,CAA2B,UAA3B,EAAuCjf,UAAA,CAAWvB,KAAlD,CADU,GAEV,IAAIwgB,sBAAJ,CAA2B,QAA3B,EAAqCjf,UAAA,CAAWvB,KAAhD,CAFE,CAAP,CADY;AAAA,KA3BwI;AAAA,IAiCxJ,MAAM4gB,iBAAA,GAAoBG,SAAA,YAAqBnI,aAArB,GAAmCmI,SAAA,CAAUjI,aAA7C,GAA6D1Z,SAAvF,CAjCwJ;AAAA,IAmCxJ,OAAOggB,OAAA,CAAQnM,mBAAA,GACV,IAAI0N,uBAAJ,CAA4B,QAA5B,EAAsCpf,UAAA,CAAWvB,KAAjD,EAAwD+gB,SAAA,CAAUpM,MAAlE,EAA0EiM,iBAA1E,CADU,GAEV,IAAID,uBAAJ,CAA4B,WAA5B,EAAyCpf,UAAA,CAAWvB,KAApD,EAA2D+gB,SAAA,CAAUpM,MAArE,EAA6EiM,iBAA7E,CAFE,CAAP,CAnCwJ;AAAA,CApO5J;AAuUA;AAAA;AAAA;AAAA,SAASI,aAAT,CAAuBzf,UAAvB,EAAyF;AAAA,IACrF,IAAIuB,MAAA,GAAS,IAAb,CADqF;AAAA,IAErF,IAAIvB,UAAA,YAAsByY,KAA1B,EAA+B;AAAA,QAC3BlX,MAAA,GAASke,aAAA,CAAczf,UAAA,CAAWuB,MAAzB,CAAT,CAD2B;AAAA,KAA/B,MAGO,IAAIvB,UAAA,YAAsBqY,UAA1B,EAAoC;AAAA,QACvC,WAAWpQ,GAAX,IAAkBjI,UAAA,CAAW4G,IAA7B,EAAmC;AAAA,YAC/BrF,MAAA,GAASke,aAAA,CAAcxX,GAAd,CAAT,CAD+B;AAAA,YAE/B,IAAI1G,MAAJ,EAAY;AAAA,gBACR,MADQ;AAAA,aAFmB;AAAA,SADI;AAAA,KAApC,MAQA,IAAK,CAAAvB,UAAA,YAAsBmT,MAAtB,IAA8BnT,UAAA,YAAsBqX,aAApD,KACRrX,UAAA,CAAWpC,KAAX,YAA4BoN,oBADrB,IAEPhL,UAAA,CAAWpC,KAAX,CAAiBwE,IAAjB,KAA0B,MAFvB,EAE+B;AAAA,QAElCb,MAAA,GAASvB,UAAT,CAFkC;AAAA,KAf+C;AAAA,IAoBrF,IAAIuB,MAAA,YAAkBO,cAAtB,EAAoC;AAAA,QAChC,OAAOP,MAAP,CADgC;AAAA,KApBiD;AAAA,IAwBrFvB,UAAA,CAAWiH,SAAX,CAAsBoC,KAAD,IAAW;AAAA,QAC5B,MAAMqW,WAAA,GAAcD,aAAA,CAAcpW,KAAd,CAApB,CAD4B;AAAA,QAE5B,IAAIqW,WAAA,YAAuB5d,cAA3B,EAAyC;AAAA,YACrCP,MAAA,GAASme,WAAT,CADqC;AAAA,SAAzC,MAEO,IAAI,CAACne,MAAD,IAAWme,WAAf,EAA4B;AAAA,YAC/Bne,MAAA,GAAS,IAAIO,cAAJ,CAAiB,EAAjB,EAAqB,gGAArB,CAAT,CAD+B;AAAA,SAA5B,MAEA,IAAIP,MAAA,IAAUme,WAAV,IAAyBne,MAAA,KAAWme,WAAxC,EAAqD;AAAA,YACxDne,MAAA,GAAS,IAAIO,cAAJ,CAAiB,EAAjB,EAAqB,yFAArB,CAAT,CADwD;AAAA,SANhC;AAAA,KAAhC,CAxBqF,CAAA;AAAA,IAmCrF,OAAOP,MAAP,CAnCqF;AAAA,CAvUzF;AA+WA,SAASyd,eAAT,CAAyBjB,IAAzB,EAAiE;AAAA,IAC7D,MAAM1W,KAAA,GAAQ;AAAA,QACV+N,KAAA,EAAOxS,SADG;AAAA,QAEV0E,MAAA,EAAQ5E,UAFE;AAAA,QAGV6E,MAAA,EAAQ9E,UAHE;AAAA,QAIVkd,IAAA,EAAMjd,UAJI;AAAA,QAKV8E,OAAA,EAAS7E,WALC;AAAA,QAMVid,SAAA,EAAW3c,aAND;AAAA,QAOV4c,aAAA,EAAe3c,iBAPL;AAAA,KAAd,CAD6D;AAAA,IAW7D,IAAI6a,IAAA,CAAKne,IAAL,KAAc,OAAlB,EAA2B;AAAA,QACvB,OAAOuD,OAAA,CAAMkE,KAAA,CAAM0W,IAAA,CAAKtf,KAAX,CAAA,IAAqBqE,SAA3B,EAAsCib,IAAA,CAAKriB,MAA3C,CAAP,CADuB;AAAA,KAXkC;AAAA,IAe7D,OAAO2L,KAAA,CAAM0W,IAAA,CAAKne,IAAX,CAAP,CAf6D;AAAA,CA/WjE;AAiYA,SAAS2e,eAAT,CAAyBR,IAAzB,EAAkE;AAAA,IAC9D,IAAIA,IAAA,CAAKne,IAAL,KAAc,OAAd,KAA0Bse,UAAA,CAAWH,IAAA,CAAKpe,OAAhB,CAAA,IAA4BqE,KAAA,CAAMC,OAAN,CAAc8Z,IAAA,CAAKpe,OAAnB,CAA5B,CAA9B,EAAwF;AAAA;AAIpF;AAAA;AAAA,QAAO,OAAA,IAAItC,OAAJ,CAAU,CAAV,EAAa,CAAb,EAAgB,CAAhB,EAAmB,CAAnB,CAAP,CAJoF;AAAA,KAAxF,MAKO,IAAI0gB,IAAA,CAAKne,IAAL,KAAc,OAAlB,EAA2B;AAAA,QAC9B,OAAOvC,OAAA,CAAMM,KAAN,CAAYogB,IAAA,CAAKpe,OAAjB,CAA6B,IAAA,IAApC,CAD8B;AAAA,KAA3B,MAEA,IAAIoe,IAAA,CAAKpe,OAAL,KAAiB9B,SAArB,EAAgC;AAAA,QACnC,OAAO,IAAP,CADmC;AAAA,KAAhC,MAEA;AAAA,QACH,OAAOkgB,IAAA,CAAKpe,OAAZ,CADG;AAAA,KAVuD;AAAA;;AC9XlE;AAAA;AAAO,SAASmgB,QAAT,CAAkBrhB,KAAlB,EAAuC;AAAA,IAC1C,IAAIA,KAAA,YAAiByK,MAAjB,IAA2BzK,KAAA,YAAiB+H,MAA5C,IAAsD/H,KAAA,YAAiBqK,OAA3E,EAAoF;AAAA,QAChF,OAAOrK,KAAA,CAAMshB,OAAN,EAAP,CADgF;AAAA,KAApF,MAEO;AAAA,QACH,OAAOthB,KAAP,CADG;AAAA,KAHmC;AAAA,CAH9C;AAWO,SAASuhB,YAAT,CAAsBvhB,KAAtB,EAA2C;AAAA,IAC9C,IAAIuF,KAAA,CAAMC,OAAN,CAAcxF,KAAd,CAAJ,EAA0B;AAAA,QACtB,OAAOA,KAAA,CAAMU,GAAN,CAAU6gB,YAAV,CAAP,CADsB;AAAA,KAA1B,MAEO,IAAIvhB,KAAA,YAAiBoB,MAAjB,IAA2B,EAAEpB,KAAA,YAAiByK,MAAjB,IAA2BzK,KAAA,YAAiB+H,MAA5C,IAAsD/H,KAAA,YAAiBqK,OAAvE,CAAjC,EAAkH;AAAA,QACrH,MAAMmX,cAAA,GAA2C,EAAjD,CADqH;AAAA,QAErH,KAAWle,MAAAA,GAAX,IAAkBtD,KAAlB,EAAyB;AAAA,YACrBwhB,cAAA,CAAele,GAAf,CAAsBie,GAAAA,YAAA,CAAavhB,KAAA,CAAMsD,GAAN,CAAb,CAAtB,CADqB;AAAA,SAF4F;AAAA,QAKrH,OAAOke,cAAP,CALqH;AAAA,KAH3E;AAAA,IAW9C,OAAOH,QAAA,CAASrhB,KAAT,CAAP,CAX8C;AAAA;;ACXlD,WAAe,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,MAAM,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,WAAW,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,kBAAkB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,mBAAmB,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,gBAAgB,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,YAAY,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,aAAa,CAAC,eAAe,CAAC,gBAAgB,CAAC,uBAAuB,CAAC,eAAe,CAAC,eAAe,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,YAAY,CAAC,CAAC,mBAAmB,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,4BAA4B,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,kBAAkB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,kBAAkB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,kBAAkB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,oBAAoB,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,YAAY,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,oBAAoB,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,uBAAuB,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,yBAAyB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,kCAAkC,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,uBAAuB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,mBAAmB,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,yBAAyB,CAAC,KAAK,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,aAAa,CAAC,EAAE,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,sBAAsB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,sBAAsB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,yBAAyB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,mBAAmB,CAAC,0BAA0B,CAAC,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,kBAAkB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,kBAAkB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,qBAAqB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,oBAAoB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,aAAa,CAAC,EAAE,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,kBAAkB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,aAAa,CAAC,EAAE,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,kBAAkB,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,mBAAmB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,mBAAmB,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,yBAAyB,CAAC,KAAK,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,oBAAoB,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,uBAAuB,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,uBAAuB,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,eAAe,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,YAAY,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,EAAE,CAAC,aAAa,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,sBAAsB,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,eAAe,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,qBAAqB,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,qBAAqB,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC,eAAe,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,eAAe,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,eAAe,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,eAAe,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,eAAe,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC,eAAe,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,eAAe,CAAC,eAAe,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,eAAe,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,YAAY,CAAC,EAAE,CAAC,iBAAiB,CAAC,EAAE,CAAC,uBAAuB,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,cAAc,CAAC,EAAE,CAAC,cAAc,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,eAAe,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,YAAY,CAAC,YAAY,CAAC,cAAc,CAAC,eAAe,CAAC,sBAAsB,CAAC,cAAc,CAAC,cAAc,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAC,YAAY,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,oBAAoB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,uBAAuB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,gBAAgB,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,wBAAwB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,sBAAsB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,0BAA0B,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,iCAAiC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,0BAA0B,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,wBAAwB,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,uBAAuB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,qBAAqB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,uBAAuB,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,kCAAkC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,4CAA4C,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,yCAAyC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,4BAA4B,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,uBAAuB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,gBAAgB,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,YAAY,CAAC,CAAC,kBAAkB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,kBAAkB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,yBAAyB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,kBAAkB,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,oBAAoB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,wBAAwB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,qBAAqB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,qBAAqB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,uBAAuB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,mBAAmB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,oBAAoB,CAAC,GAAG,CAAC,WAAW,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,eAAe,CAAC,YAAY,CAAC,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,kBAAkB,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,uBAAuB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,kBAAkB,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,uBAAuB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,gBAAgB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,mBAAmB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,uBAAuB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,uBAAuB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,mBAAmB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,iBAAiB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,mBAAmB,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,sBAAsB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,OAAO,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,kCAAkC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,+BAA+B,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,wBAAwB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,wBAAwB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,2BAA2B,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,wBAAwB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,kBAAkB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,oBAAoB,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,oBAAoB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,EAAE,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,oBAAoB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,8BAA8B,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,YAAY,CAAC,KAAK,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,qBAAqB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,qBAAqB,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,eAAe,CAAC,YAAY,CAAC,CAAC,2BAA2B,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,sBAAsB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,eAAe,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;;ACE5pvC;AAeA,SAASyhB,kBAAT,CAA4B5U,MAA5B,EAAkD;AAAA,IAC9C,IAAIA,MAAA,KAAW,IAAX,IAAmBA,MAAA,KAAW,KAAlC,EAAyC;AAAA,QACrC,OAAO,IAAP,CADqC;AAAA,KADK;AAAA,IAK9C,IAAI,CAACtH,KAAA,CAAMC,OAAN,CAAcqH,MAAd,CAAD,IAA0BA,MAAA,CAAO5P,MAAP,KAAkB,CAAhD,EAAmD;AAAA,QAC/C,OAAO,KAAP,CAD+C;AAAA,KALL;AAAA,IAQ9C,QAAQ4P,MAAA,CAAO,CAAP,CAAR;AAAA,IACA,KAAK,KAAL;AAAA,QACI,OAAOA,MAAA,CAAO5P,MAAP,IAAiB,CAAjB,IAAsB4P,MAAA,CAAO,CAAP,CAAA,KAAc,KAApC,IAA6CA,MAAA,CAAO,CAAP,CAAA,KAAc,OAAlE,CAFJ;AAAA,IAIA,KAAK,IAAL;AAAA,QACI,OAAOA,MAAA,CAAO5P,MAAP,IAAiB,CAAjB,KAAuB,OAAO4P,MAAA,CAAO,CAAP,CAAP,KAAqB,QAArB,IAAiCtH,KAAA,CAAMC,OAAN,CAAcqH,MAAA,CAAO,CAAP,CAAd,CAAjC,CAA9B,CALJ;AAAA,IAOA,KAAK,KAAL,CAPA;AAAA,IAQA,KAAK,MAAL,CARA;AAAA,IASA,KAAK,MAAL;AAAA,QACI,OAAO,KAAP,CAVJ;AAAA,IAYA,KAAK,IAAL,CAZA;AAAA,IAaA,KAAK,IAAL,CAbA;AAAA,IAcA,KAAK,GAAL,CAdA;AAAA,IAeA,KAAK,IAAL,CAfA;AAAA,IAgBA,KAAK,GAAL,CAhBA;AAAA,IAiBA,KAAK,IAAL;AAAA,QACI,OAAOA,MAAA,CAAO5P,MAAP,KAAkB,CAAlB,KAAwBsI,KAAA,CAAMC,OAAN,CAAcqH,MAAA,CAAO,CAAP,CAAd,CAAA,IAA4BtH,KAAA,CAAMC,OAAN,CAAcqH,MAAA,CAAO,CAAP,CAAd,CAA5B,CAA/B,CAlBJ;AAAA,IAoBA,KAAK,KAAL,CApBA;AAAA,IAqBA,KAAK,KAAL;AAAA,QACI,KAAA,MAAW/P,CAAX,IAAgB+P,MAAA,CAAOhP,KAAP,CAAa,CAAb,CAAhB,EAAiC;AAAA,YAC7B,IAAI,CAAC4jB,kBAAA,CAAmB3kB,CAAnB,CAAD,IAA0B,OAAOA,CAAP,KAAa,SAA3C,EAAsD;AAAA,gBAClD,OAAO,KAAP,CADkD;AAAA,aADzB;AAAA,SADrC;AAAA,QAMI,OAAO,IAAP,CA3BJ;AAAA,IA6BA;AAAA,QACI,OAAO,IAAP,CA9BJ;AAAA,KAR8C;AAAA,CAjBlD;AAqEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAAS4kB,YAAT,CAAsB7U,MAAtB,EAAmC8U,SAAA,GAAqB,MAAxD,EAA+E;AAAA,IAC3E,IAAI9U,MAAA,KAAW,IAAX,IAAmBA,MAAA,KAAWzN,SAAlC,EAA6C;AAAA,QACzC,OAAO;AAAA,YAACyN,MAAA,EAAQ,MAAM,IAAf;AAAA,YAAqB+U,YAAA,EAAc,KAAnC;AAAA,YAA0CC,WAAA,EAAa,KAAvD;AAAA,SAAP,CADyC;AAAA,KAD8B;AAAA,IAK3E,IAAI,CAACJ,kBAAA,CAAmB5U,MAAnB,CAAL,EAAiC;AAAA,QAC7BA,MAAA,GAASiV,aAAA,CAAcjV,MAAd,CAAT,CAD6B;AAAA,KAL0C;AAAA,IAQ3E,MAAMkV,SAAA,GAAclV,MAApB,CAR2E;AAAA,IAU3E,IAAImV,YAAA,GAAe,IAAnB,CAV2E;AAAA,IAW3E,IAAI;AAAA,QACAA,YAAA,GAAeC,mBAAA,CAAoBF,SAApB,CAAf,CADA;AAAA,KAAJ,CAEE,OAAOpjB,CAAP,EAAU;AAAA,QACRuhB,OAAA,CAAQC,IAAR,CACR,CAAC;AAAA;AAAA;AAAA;AAAA;AAAD,GAKEnY,IAAA,CAAKC,SAAL,CAAe8Z,SAAf,EAA0B,IAA1B,EAAgC,CAAhC,CALF,EAKqC;AAAA,QALrC,CADQ,CADQ,CAAA;AAAA,KAb+D;AAAA;AAyB3E,IAAMG,MAAAA,UAAA,GAAaC,IAAA,CAAO,CAAC,OAAD,GAAUR,SAAV,EAAP,CAAA,CAAnB,CAzB2E;AAAA,IA0B3E,MAAMS,oBAAA,GAAuB/B,gBAAA,CAAiB2B,YAAjB,EAA+BE,UAA/B,CAA7B,CA1B2E;AAAA,IA4B3E,IAAIG,UAAA,GAAa,IAAjB,CA5B2E;AAAA,IA6B3E,IAAID,oBAAA,CAAqBtf,MAArB,KAAgC,OAApC,EAA6C;AAAA,QACzC,MAAM,IAAIJ,KAAJ,CAAU0f,oBAAA,CAAqBpiB,KAArB,CAA2BU,GAA3B,CAA+B4hB,GAAA,IAAO,CAAGA,GAAAA,GAAA,CAAIhf,GAAP,EAAW,EAAX,GAAegf,GAAA,CAAI/e,OAAnB,EAAtC,CAAA,CAAA,CAAoE6D,IAApE,CAAyE,IAAzE,CAAV,CAAN,CADyC;AAAA,KAA7C,MAEO;AAAA,QACHib,UAAA,GAAa,CAACE,gBAAD,EAAqCvX,OAArC,EAAuDI,SAAvD,KAAuFgX,oBAAA,CAAqBpiB,KAArB,CAA2BuI,QAA3B,CAAoCga,gBAApC,EAAsDvX,OAAtD,EAA+D,EAA/D,EAAmEI,SAAnE,CAApG,CADG;AAAA,KA/BoE;AAAA;AAqC3E;AAAA,IAAIoX,IAAAA,iBAAA,GAAoB,IAAxB,CArC2E;AAAA,IAsC3E,IAAIX,WAAA,GAAc,IAAlB,CAtC2E;AAAA,IAuC3E,IAAIG,YAAA,KAAiBD,SAArB,EAAgC;AAAA,QAC5B,MAAMU,qBAAA,GAAwBpC,gBAAA,CAAiB0B,SAAjB,EAA4BG,UAA5B,CAA9B,CAD4B;AAAA,QAG5B,IAAIO,qBAAA,CAAsB3f,MAAtB,KAAiC,OAArC,EAA8C;AAAA,YAC1C,MAAM,IAAIJ,KAAJ,CAAU+f,qBAAA,CAAsBziB,KAAtB,CAA4BU,GAA5B,CAAgC4hB,GAAA,IAAO,CAAGA,GAAAA,GAAA,CAAIhf,GAAP,EAAW,EAAX,GAAegf,GAAA,CAAI/e,OAAnB,EAAvC,CAAA,CAAA,CAAqE6D,IAArE,CAA0E,IAA1E,CAAV,CAAN,CAD0C;AAAA,SAA9C,MAEO;AAAA,YACHob,iBAAA,GAAoB,CAACD,gBAAD,EAAqCvX,OAArC,EAAuDI,SAAvD,EAAoFC,gBAApF,EAA8GC,mBAA9G,KAA4JmX,qBAAA,CAAsBziB,KAAtB,CAA4BuI,QAA5B,CAAqCga,gBAArC,EAAuDvX,OAAvD,EAAgE,EAAhE,EAAoEI,SAApE,EAA+EhM,SAA/E,EAA0FA,SAA1F,EAAqGiM,gBAArG,EAAuHC,mBAAvH,CAAhL,CADG;AAAA,YAEHuW,WAAA,GAAc,CAAC5O,iBAAA,CAAkBwP,qBAAA,CAAsBziB,KAAtB,CAA4BuB,UAA9C,CAAf,CAFG;AAAA,SALqB;AAAA,KAvC2C;AAAA,IAkD3E8gB,UAAA,GAAeA,UAAf,CAlD2E;AAAA,IAmD3E,MAAMT,YAAA,GAAec,cAAA,CAAeV,YAAf,CAArB,CAnD2E;AAAA,IAqD3E,OAAO;AAAA,QACHnV,MAAA,EAAQwV,UADL;AAAA,QAEHM,aAAA,EAAeH,iBAAA,GAAoBA,iBAApB,GAAwCpjB,SAFpD;AAAA,QAGHwiB,YAHG;AAAA,QAIHC,WAAA,EAAa,CAAC,CAACA,WAJZ;AAAA,KAAP,CArD2E;AAAA,CArE/E;AAkIA,SAASI,mBAAT,CAA6BpV,MAA7B,EAA+C;AAAA,IAC3C,IAAI,CAAC+V,eAAA,CAAgB/V,MAAhB,CAAL,EAA8B;AAAA,QAC1B,OAAOA,MAAP,CAD0B;AAAA,KADa;AAAA;AAM3C,IAAA,IAAI/J,MAAA,GAASye,YAAA,CAAa1U,MAAb,CAAb,CAN2C;AAAA;AAS3C,IAAAgW,oBAAA,CAAqB/f,MAArB,CAT2C,CAAA;AAAA;AAY3C,IAAAA,MAAA,GAASggB,iCAAA,CAAkChgB,MAAlC,CAAT,CAZ2C;AAAA,IAc3C,OAAOA,MAAP,CAd2C;AAAA,CAlI/C;AAmJA,SAASggB,iCAAT,CAA2CvhB,UAA3C,EAAiE;AAAA,IAC7D,IAAI,CAACgE,KAAA,CAAMC,OAAN,CAAcjE,UAAd,CAAL,EAAgC;AAAA,QAC5B,OAAOA,UAAP,CAD4B;AAAA,KAD6B;AAAA,IAK7D,MAAMwhB,SAAA,GAAYC,mBAAA,CAAoBzhB,UAApB,CAAlB,CAL6D;AAAA,IAM7D,IAAIwhB,SAAA,KAAc,IAAlB,EAAwB;AAAA,QACpB,OAAOA,SAAP,CADoB;AAAA,KAAxB,MAEO;AAAA,QACH,OAAOA,SAAA,CAAUriB,GAAV,CAAeuiB,aAAD,IAAmBH,iCAAA,CAAkCG,aAAlC,CAAjC,CAAP,CADG;AAAA,KARsD;AAAA,CAnJjE;AAyKA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAASJ,oBAAT,CAA8BhW,MAA9B,EAA2C;AAAA,IACvC,IAAIqW,sBAAA,GAAyB,KAA7B,CADuC;AAAA,IAEvC,MAAM7H,QAAA,GAAW,EAAjB,CAFuC;AAAA,IAIvC,IAAIxO,MAAA,CAAO,CAAP,CAAA,KAAc,MAAlB,EAA0B;AAAA,QACtB,KAAK,IAAInQ,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAImQ,MAAA,CAAO5P,MAAP,GAAgB,CAApC,EAAuCP,CAAA,IAAK,CAA5C,EAA+C;AAAA,YAC3CwmB,sBAAA,GAAyBA,sBAAA,IAA0BN,eAAA,CAAgB/V,MAAA,CAAOnQ,CAAP,CAAhB,CAAnD,CAD2C;AAAA,YAE3C2e,QAAA,CAAStZ,IAAT,CAAc8K,MAAA,CAAOnQ,CAAA,GAAI,CAAX,CAAd,CAF2C,CAAA;AAAA,SADzB;AAAA,QAMtB2e,QAAA,CAAStZ,IAAT,CAAc8K,MAAA,CAAOA,MAAA,CAAO5P,MAAP,GAAgB,CAAvB,CAAd,CANsB,CAAA;AAAA,KAA1B,MAOO,IAAI4P,MAAA,CAAO,CAAP,CAAA,KAAc,OAAlB,EAA2B;AAAA,QAC9BqW,sBAAA,GAAyBA,sBAAA,IAA0BN,eAAA,CAAgB/V,MAAA,CAAO,CAAP,CAAhB,CAAnD,CAD8B;AAAA,QAG9B,KAAK,IAAInQ,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAImQ,MAAA,CAAO5P,MAAP,GAAgB,CAApC,EAAuCP,CAAA,IAAK,CAA5C,EAA+C;AAAA,YAC3C2e,QAAA,CAAStZ,IAAT,CAAc8K,MAAA,CAAOnQ,CAAA,GAAI,CAAX,CAAd,CAD2C,CAAA;AAAA,SAHjB;AAAA,QAM9B2e,QAAA,CAAStZ,IAAT,CAAc8K,MAAA,CAAOA,MAAA,CAAO5P,MAAP,GAAgB,CAAvB,CAAd,CAN8B,CAAA;AAAA,KAA3B,MAOA,IAAI4P,MAAA,CAAO,CAAP,CAAA,KAAc,MAAlB,EAA0B;AAAA,QAC7BqW,sBAAA,GAAyBA,sBAAA,IAA0BN,eAAA,CAAgB/V,MAAA,CAAO,CAAP,CAAhB,CAAnD,CAD6B;AAAA,QAG7B,KAAK,IAAInQ,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAImQ,MAAA,CAAO5P,MAAP,GAAgB,CAApC,EAAuCP,CAAA,IAAK,CAA5C,EAA+C;AAAA,YAC3C2e,QAAA,CAAStZ,IAAT,CAAc8K,MAAA,CAAOnQ,CAAA,GAAI,CAAX,CAAd,CAD2C,CAAA;AAAA,SAHlB;AAAA,KAlBM;AAAA,IA0BvC,IAAIwmB,sBAAJ,EAA4B;AAAA,QACxBrW,MAAA,CAAO5P,MAAP,GAAgB,CAAhB,CADwB;AAAA,QAExB4P,MAAA,CAAO9K,IAAP,CAAY,KAAZ,EAAmB,GAAGsZ,QAAtB,CAFwB,CAAA;AAAA,KA1BW;AAAA;AAgCvC,IAAA,KAAK,IAAI3e,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAImQ,MAAA,CAAO5P,MAA3B,EAAmCP,CAAA,EAAnC,EAAwC;AAAA,QACpCmmB,oBAAA,CAAqBhW,MAAA,CAAOnQ,CAAP,CAArB,CADoC,CAAA;AAAA,KAhCD;AAAA,CAzK3C;AA8MA,SAASkmB,eAAT,CAAyB/V,MAAzB,EAA+C;AAAA;AAE3C,IAAA,IAAI,CAACtH,KAAA,CAAMC,OAAN,CAAcqH,MAAd,CAAL,EAA4B;AAAA,QACxB,OAAO,KAAP,CADwB;AAAA,KAFe;AAAA,IAK3C,IAAIsW,uBAAA,CAAwBtW,MAAA,CAAO,CAAP,CAAxB,CAAJ,EAAwC;AAAA,QACpC,OAAO,IAAP,CADoC;AAAA,KALG;AAAA,IAS3C,KAAK,IAAInQ,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAImQ,MAAA,CAAO5P,MAA3B,EAAmCP,CAAA,EAAnC,EAAwC;AAAA,QACpC,MAAMkO,KAAA,GAAQiC,MAAA,CAAOnQ,CAAP,CAAd,CADoC;AAAA,QAEpC,IAAIkmB,eAAA,CAAgBhY,KAAhB,CAAJ,EAA4B;AAAA,YACxB,OAAO,IAAP,CADwB;AAAA,SAFQ;AAAA,KATG;AAAA,IAgB3C,OAAO,KAAP,CAhB2C;AAAA,CA9M/C;AAiOA,SAASuY,uBAAT,CAAiC5hB,UAAjC,EAA8D;AAAA,IAC1D,OAAOA,UAAA,KAAe,OAAf,IACHA,UAAA,KAAe,sBADnB,CAD0D;AAAA,CAjO9D;AAsOA,MAAM6hB,2BAAA,GAA8B,IAAIC,GAAJ,CAAQ;AAAA,IACxC,IADwC;AAAA,IAExC,IAFwC;AAAA,IAGxC,IAHwC;AAAA,IAIxC,GAJwC;AAAA,IAKxC,IALwC;AAAA,IAMxC,GANwC;AAAA,IAOxC,IAPwC;AAAA,IAQxC,YARwC;AAAA,CAAR,CAApC,CAtOA;AAiPA,SAASL,mBAAT,CAA6BzhB,UAA7B,EAAmD;AAAA,IAC/C,IAAI6hB,2BAAA,CAA4Bvf,GAA5B,CAAgCtC,UAAA,CAAW,CAAX,CAAhC,CAAJ,EAAoD;AAAA,QAEhD,KAAK,IAAI7E,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAI6E,UAAA,CAAWtE,MAA/B,EAAuCP,CAAA,EAAvC,EAA4C;AAAA,YACxC,MAAM4mB,KAAA,GAAQ/hB,UAAA,CAAW7E,CAAX,CAAd,CADwC;AAAA,YAExC,IAAIkmB,eAAA,CAAgBU,KAAhB,CAAJ,EAA4B;AAAA,gBACxB,OAAO,IAAP,CADwB;AAAA,aAFY;AAAA,SAFI;AAAA,KADL;AAAA,IAU/C,OAAO/hB,UAAP,CAV+C;AAAA,CAjPnD;AA+PA;AAAA,SAAS0E,OAAT,CAAiBhH,CAAjB,EAAoBD,CAApB,EAAuB;AAAA,IACnB,OAAOC,CAAA,GAAID,CAAJ,GAAQ,CAAC,CAAT,GAAaC,CAAA,GAAID,CAAJ,GAAQ,CAAR,GAAY,CAAhC,CADmB;AAAA,CA/PvB;AAmQA,SAAS0jB,cAAT,CAAwB7V,MAAxB,EAAgC;AAAA,IAC5B,IAAI,CAACtH,KAAA,CAAMC,OAAN,CAAcqH,MAAd,CAAL;AAAA,QAA4B,OAAO,KAAP,CADA;AAAA,IAE5B,IAAIA,MAAA,CAAO,CAAP,MAAc,QAAlB;AAAA,QAA4B,OAAO,IAAP,CAFA;AAAA,IAG5B,KAAK,IAAI4G,KAAA,GAAQ,CAAZ,EAAeA,KAAA,GAAQ5G,MAAA,CAAO5P,MAAnC,EAA2CwW,KAAA,EAA3C,EAAoD;AAAA,QAChD,IAAIiP,cAAA,CAAe7V,MAAA,CAAO4G,KAAP,CAAf,CAAJ;AAAA,YAAmC,OAAO,IAAP,CADa;AAAA,KAHxB;AAAA,IAM5B,OAAO,KAAP,CAN4B;AAAA,CAnQhC;AA4QA,SAASqO,aAAT,CAAuBjV,MAAvB,EAAmD;AAAA,IAC/C,IAAI,CAACA,MAAL;AAAA,QAAa,OAAO,IAAP,CADkC;AAAA,IAE/C,MAAM7O,EAAA,GAAK6O,MAAA,CAAO,CAAP,CAAX,CAF+C;AAAA,IAG/C,IAAIA,MAAA,CAAO5P,MAAP,IAAiB,CAArB;AAAA,QAAwB,OAAQe,EAAA,KAAO,KAAf,CAHuB;AAAA,IAI/C,MAAMulB,SAAA,GACFvlB,EAAA,KAAO,IAAP,GAAcwlB,mBAAA,CAAoB3W,MAAA,CAAO,CAAP,CAApB,EAA+BA,MAAA,CAAO,CAAP,CAA/B,EAA0C,IAA1C,CAAd,GACA7O,EAAA,KAAO,IAAP,GAAcylB,eAAA,CAAgBD,mBAAA,CAAoB3W,MAAA,CAAO,CAAP,CAApB,EAA+BA,MAAA,CAAO,CAAP,CAA/B,EAA0C,IAA1C,CAAhB,CAAd,GACA7O,EAAA,KAAO,GAAP,IACAA,EAAA,KAAO,GADP,IAEAA,EAAA,KAAO,IAFP,IAGAA,EAAA,KAAO,IAHP,GAGcwlB,mBAAA,CAAoB3W,MAAA,CAAO,CAAP,CAApB,EAA+BA,MAAA,CAAO,CAAP,CAA/B,EAA0C7O,EAA1C,CAHd,GAIAA,EAAA,KAAO,KAAP,GAAe0lB,oBAAA,CAAqB7W,MAAA,CAAOhP,KAAP,CAAa,CAAb,CAArB,CAAf,GACAG,EAAA,KAAO,KAAP,GAAe,CAAC,KAAD,CAAA,CAAQ4F,MAAR,CAAeiJ,MAAA,CAAOhP,KAAP,CAAa,CAAb,CAAgB6C,CAAAA,GAAhB,CAAoBohB,aAApB,CAAf,CAAf,GACA9jB,EAAA,KAAO,MAAP,GAAgB,CAAC,KAAD,CAAQ4F,CAAAA,MAAR,CAAeiJ,MAAA,CAAOhP,KAAP,CAAa,CAAb,EAAgB6C,GAAhB,CAAoBohB,aAApB,CAAA,CAAmCphB,GAAnC,CAAuC+iB,eAAvC,CAAf,CAAhB,GACAzlB,EAAA,KAAO,IAAP,GAAc2lB,WAAA,CAAY9W,MAAA,CAAO,CAAP,CAAZ,EAAuBA,MAAA,CAAOhP,KAAP,CAAa,CAAb,CAAvB,CAAd,GACAG,EAAA,KAAO,KAAP,GAAeylB,eAAA,CAAgBE,WAAA,CAAY9W,MAAA,CAAO,CAAP,CAAZ,EAAuBA,MAAA,CAAOhP,KAAP,CAAa,CAAb,CAAvB,CAAhB,CAAf,GACAG,EAAA,KAAO,KAAP,GAAe4lB,YAAA,CAAa/W,MAAA,CAAO,CAAP,CAAb,CAAf,GACA7O,EAAA,KAAO,MAAP,GAAgBylB,eAAA,CAAgBG,YAAA,CAAa/W,MAAA,CAAO,CAAP,CAAb,CAAhB,CAAhB,GACA7O,EAAA,KAAO,QAAP,GAAkB6O,MAAlB,GACA,IAfJ,CAJ+C;AAAA,IAoB/C,OAAO0W,SAAP,CApB+C;AAAA,CA5QnD;AAmSA,SAASC,mBAAT,CAA6BhjB,QAA7B,EAA+CR,KAA/C,EAA2DhC,EAA3D,EAAuE;AAAA,IACnE,QAAQwC,QAAR;AAAA,IACA,KAAK,OAAL;AAAA,QACI,OAAO;AAAA,YAAC,CAAC,YAAD,GAAexC,EAAf,EAAD,CAAA;AAAA,YAAsBgC,KAAtB;AAAA,SAAP,CAFJ;AAAA,IAGA,KAAK,KAAL;AAAA,QACI,OAAO;AAAA,YAAC,CAAC,UAAD,GAAahC,EAAb,EAAD,CAAA;AAAA,YAAoBgC,KAApB;AAAA,SAAP,CAJJ;AAAA,IAKA;AAAA,QACI,OAAO;AAAA,YAAC,CAAC,OAAD,GAAUhC,EAAV,EAAD,CAAA;AAAA,YAAiBwC,QAAjB;AAAA,YAA2BR,KAA3B;AAAA,SAAP,CANJ;AAAA,KADmE;AAAA,CAnSvE;AA8SA,SAAS0jB,oBAAT,CAA8BG,OAA9B,EAA0D;AAAA,IACtD,OAAO,CAAC,KAAD,CAAA,CAAQjgB,MAAR,CAAeigB,OAAA,CAAQnjB,GAAR,CAAYohB,aAAZ,CAAf,CAAP,CADsD;AAAA,CA9S1D;AAkTA,SAAS6B,WAAT,CAAqBnjB,QAArB,EAAuCc,MAAvC,EAA2D;AAAA,IACvD,IAAIA,MAAA,CAAOrE,MAAP,KAAkB,CAAtB,EAAyB;AAAA,QAAE,OAAO,KAAP,CAAF;AAAA,KAD8B;AAAA,IAEvD,QAAQuD,QAAR;AAAA,IACA,KAAK,OAAL;AAAA,QACI,OAAO;AAAA,YAAC,CAAC,cAAD,CAAD;AAAA,YAAmB;AAAA,gBAAC,SAAD;AAAA,gBAAYc,MAAZ;AAAA,aAAnB;AAAA,SAAP,CAFJ;AAAA,IAGA,KAAK,KAAL;AAAA,QACI,OAAO;AAAA,YAAC,CAAC,YAAD,CAAD;AAAA,YAAiB;AAAA,gBAAC,SAAD;AAAA,gBAAYA,MAAZ;AAAA,aAAjB;AAAA,SAAP,CAJJ;AAAA,IAKA;AAAA,QACI,IAAIA,MAAA,CAAOrE,MAAP,GAAgB,GAAhB,IAAuB,CAACqE,MAAA,CAAO+D,IAAP,CAAY2Y,CAAA,IAAK,OAAOA,CAAP,KAAa,OAAO1c,MAAA,CAAO,CAAP,CAArC,CAA5B,EAA6E;AAAA,YACzE,OAAO;AAAA,gBAAC,iBAAD;AAAA,gBAAoBd,QAApB;AAAA,gBAA8B;AAAA,oBAAC,SAAD;AAAA,oBAAYc,MAAA,CAAOyZ,IAAP,CAAY9U,OAAZ,CAAZ;AAAA,iBAA9B;AAAA,aAAP,CADyE;AAAA,SAA7E,MAEO;AAAA,YACH,OAAO;AAAA,gBAAC,iBAAD;AAAA,gBAAoBzF,QAApB;AAAA,gBAA8B;AAAA,oBAAC,SAAD;AAAA,oBAAYc,MAAZ;AAAA,iBAA9B;AAAA,aAAP,CADG;AAAA,SARX;AAAA,KAFuD;AAAA,CAlT3D;AAkUA,SAASsiB,YAAT,CAAsBpjB,QAAtB,EAAwC;AAAA,IACpC,QAAQA,QAAR;AAAA,IACA,KAAK,OAAL;AAAA,QACI,OAAO,IAAP,CAFJ;AAAA,IAGA,KAAK,KAAL;AAAA,QACI,OAAO,CAAC,CAAC,aAAD,CAAD,CAAP,CAJJ;AAAA,IAKA;AAAA,QACI,OAAO;AAAA,YAAC,CAAC,UAAD,CAAD;AAAA,YAAeA,QAAf;AAAA,SAAP,CANJ;AAAA,KADoC;AAAA,CAlUxC;AA6UA,SAASijB,eAAT,CAAyB5W,MAAzB,EAAwC;AAAA,IACpC,OAAO;AAAA,QAAC,GAAD;AAAA,QAAMA,MAAN;AAAA,KAAP,CADoC;AAAA;;AC5UxC;AAAA,oBAAA;AAAA,IAAA,MAAA;AAAA,IAAA,QAAA;AAAA,IAAA,cAAA;AAAA,IAAA,SAAA;AAAA,IAAA,SAAA;AAAA,IAAA,QAAA;AAAA,IAAA,QAAA;AAAA,CAAA;;ACCA;AAIA,SAASiX,KAAT,CAAeC,KAAf,EAA0CtgB,MAA1C,EAA0F;AAAA,IACtF,MAAMX,MAAA,GAAS,EAAf,CADsF;AAAA,IAGtF,KAAWmR,MAAAA,CAAX,IAAgB8P,KAAhB,EAAuB;AAAA,QACnB,IAAI9P,CAAA,KAAM,KAAV,EAAiB;AAAA,YACbnR,MAAA,CAAOmR,CAAP,CAAA,GAAY8P,KAAA,CAAM9P,CAAN,CAAZ,CADa;AAAA,SADE;AAAA,KAH+D;AAAA,IAStF+P,aAAA,CAAc1a,OAAd,CAAuB2K,CAAD,IAAO;AAAA,QACzB,IAAIA,CAAA,IAAKxQ,MAAT,EAAiB;AAAA,YACbX,MAAA,CAAOmR,CAAP,CAAA,GAAaxQ,MAAD,CAAcwQ,CAAd,CAAZ,CADa;AAAA,SADQ;AAAA,KAA7B,CATsF,CAAA;AAAA,IAetF,OAASnR,MAAT,CAfsF;AAAA,CAN1F;AAqCA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAe,SAASmhB,WAAT,CAAqBC,MAArB,EAAmF;AAAA,IAC9FA,MAAA,GAASA,MAAA,CAAOrmB,KAAP,EAAT,CAD8F;AAAA,IAG9F,MAAM6C,GAAA,GAAMU,MAAA,CAAO+iB,MAAP,CAAc,IAAd,CAAZ,CAH8F;AAAA,IAI9F,KAAK,IAAIznB,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIwnB,MAAA,CAAOjnB,MAA3B,EAAmCP,CAAA,EAAnC,EAAwC;AAAA,QACpCgE,GAAA,CAAIwjB,MAAA,CAAOxnB,CAAP,CAAA,CAAU6O,EAAd,CAAA,GAAoB2Y,MAAA,CAAOxnB,CAAP,CAApB,CADoC;AAAA,KAJsD;AAAA,IAQ9F,KAAK,IAAIA,CAAA,GAAI,CAAR,EAAWA,CAAA,GAAIwnB,MAAA,CAAOjnB,MAA3B,EAAmCP,CAAA,EAAnC,EAAwC;AAAA,QACpC,IAAI,KAASwnB,IAAAA,MAAA,CAAOxnB,CAAP,CAAb,EAAwB;AAAA,YACpBwnB,MAAA,CAAOxnB,CAAP,CAAA,GAAYonB,KAAA,CAAMI,MAAA,CAAOxnB,CAAP,CAAN,EAAiBgE,GAAA,CAAKwjB,MAAA,CAAOxnB,CAAP,CAAD,CAAiB0nB,GAArB,CAAjB,CAAZ,CADoB;AAAA,SADY;AAAA,KARsD;AAAA,IAc9F,OAAOF,MAAP,CAd8F;AAAA;;ACrClG,IAAIG,WAAA,GAAc;AAAA,IAChBC,IAAA,EAAM,GADU;AAAA,IAEhBC,QAAA,EAAU,GAFM;AAAA,IAGhB,eAAe,GAHC;AAAA,IAIhB,eAAe,GAJC;AAAA,IAKhBC,KAAA,EAAO,GALS;AAAA,IAMhBC,IAAA,EAAM,GANU;AAAA,IAOhBC,OAAA,EAAS,GAPO;AAAA,IAQhBC,MAAA,EAAQ,GARQ;AAAA,IAShBC,KAAA,EAAO,GATS;AAAA,IAUhBC,KAAA,EAAO,GAVS;AAAA,IAWhBC,QAAA,EAAU,GAXM;AAAA,IAYhBC,MAAA,EAAQ,GAZQ;AAAA,IAahB,aAAa,GAbG;AAAA,IAchB,aAAa,GAdG;AAAA,IAehBC,IAAA,EAAM,GAfU;AAAA,IAgBhB,cAAc,GAhBE;AAAA,IAiBhB,cAAc,GAjBE;AAAA,IAkBhBC,KAAA,EAAO,GAlBS;AAAA,IAmBhBvlB,KAAA,EAAO,GAnBS;AAAA,IAoBhB,eAAe,GApBC;AAAA,IAqBhBwlB,GAAA,EAAK,GArBW;AAAA,IAsBhBC,MAAA,EAAQ,GAtBQ;AAAA,IAuBhB,eAAe,GAvBC;AAAA,IAwBhB,eAAe,GAxBC;AAAA,CAAlB,CAAA;AA0BA,IAAIC,EAAA,GAAK,GAAT,CA1BA;AA2BA,IAAIC,QAAA,GAAW,oBAAf,CA3BA;AA6BA,IAAIC,SAAA,GAAY,EAAhB,CA7BA;AA+BAnQ,IAAAA,eAAA,GAAiB,UAASoQ,KAAT,EAAgBC,IAAhB,EAAsBC,UAAtB,EAAkC;AAAA,IACjD,IAAIC,OAAA,GAAUJ,SAAA,CAAUC,KAAV,CAAd,CADiD;AAAA,IAEjD,IAAI,CAACG,OAAL,EAAc;AAAA,QACZ,IAAI,CAACngB,KAAA,CAAMC,OAAN,CAAc+f,KAAd,CAAL,EAA2B;AAAA,YACzBA,KAAA,GAAQ,CAACA,KAAD,CAAR,CADyB;AAAA,SADf;AAAA,QAIZ,IAAII,MAAA,GAAS,GAAb,CAJY;AAAA,QAKZ,IAAIlI,KAAA,GAAQ,QAAZ,CALY;AAAA,QAMZ,IAAImI,YAAA,GAAe,EAAnB,CANY;AAAA,QAOZ,IAAIC,UAAJ,EAAgBC,SAAhB,CAPY;AAAA,QAQZ,KAAK,IAAIppB,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAKR,KAAA,CAAMtoB,MAAtB,EAA8BP,CAAA,GAAIqpB,EAAvC,EAA2C,EAAErpB,CAA7C,EAAgD;AAAA,YAC9C,IAAIkN,IAAA,GAAO2b,KAAA,CAAM7oB,CAAN,CAAX,CAD8C;AAAA,YAE9C,IAAIspB,KAAA,GAAQpc,IAAA,CAAKvL,KAAL,CAAW,GAAX,CAAZ,CAF8C;AAAA,YAG9C,IAAI4nB,WAAA,GAAcD,KAAA,CAAMA,KAAA,CAAM/oB,MAAN,GAAe,CAArB,CAAwBW,CAAAA,WAAxB,EAAlB,CAH8C;AAAA,YAI9C,IAAIqoB,WAAA,IAAe,QAAf,IAA2BA,WAAA,IAAe,QAA1C,IAAsDA,WAAA,IAAe,SAAzE,EAAoF;AAAA,gBAClFxI,KAAA,GAAQqI,SAAA,GAAYrI,KAAZ,GAAoBwI,WAA5B,CADkF;AAAA,gBAElFH,SAAA,GAAY,IAAZ,CAFkF;AAAA,gBAGlFE,KAAA,CAAMznB,GAAN,EAHkF,CAAA;AAAA,gBAIlF0nB,WAAA,GAAcD,KAAA,CAAMA,KAAA,CAAM/oB,MAAN,GAAe,CAArB,CAAA,CAAwBW,WAAxB,EAAd,CAJkF;AAAA,aAApF,MAKO,IAAIynB,QAAA,CAASnS,IAAT,CAAc+S,WAAd,CAAJ,EAAgC;AAAA,gBACrCA,WAAA,GAAcA,WAAA,CAAYtoB,OAAZ,CAAoB0nB,QAApB,EAA8B,EAA9B,CAAd,CADqC;AAAA,gBAErC5H,KAAA,GAAQqI,SAAA,GAAYrI,KAAZ,GAAoBuI,KAAA,CAAMA,KAAA,CAAM/oB,MAAN,GAAe,CAArB,EAAwBU,OAAxB,CAAgCsoB,WAAhC,EAA6C,EAA7C,CAA5B,CAFqC;AAAA,gBAGrCH,SAAA,GAAY,IAAZ,CAHqC;AAAA,aATO;AAAA,YAc9C,KAASI,IAAAA,CAAT,IAAc7B,WAAd,EAA2B;AAAA,gBACzB,IAAI8B,YAAA,GAAeH,KAAA,CAAM/oB,MAAN,GAAe,CAAf,GAAmB+oB,KAAA,CAAMA,KAAA,CAAM/oB,MAAN,GAAe,CAArB,EAAwBW,WAAxB,EAAnB,GAA2D,EAA9E,CADyB;AAAA,gBAEzB,IAAIqoB,WAAA,IAAeC,CAAf,IAAoBD,WAAA,IAAeC,CAAA,CAAEvoB,OAAF,CAAU,GAAV,EAAe,EAAf,CAAnC,IAAyDwoB,YAAA,GAAe,GAAf,GAAqBF,WAArB,IAAoCC,CAAjG,EAAoG;AAAA,oBAClGP,MAAA,GAASE,UAAA,GAAaF,MAAb,GAAsBtB,WAAA,CAAY6B,CAAZ,CAA/B,CADkG;AAAA,oBAElGF,KAAA,CAAMznB,GAAN,EAFkG,CAAA;AAAA,oBAGlG,IAAI4nB,YAAA,IAAgBD,CAAA,CAAEE,UAAF,CAAaD,YAAb,CAApB,EAAgD;AAAA,wBAC9CH,KAAA,CAAMznB,GAAN,EAD8C,CAAA;AAAA,qBAHkD;AAAA,oBAMlG,MANkG;AAAA,iBAF3E;AAAA,aAdmB;AAAA,YAyB9C,IAAI,CAACsnB,UAAD,IAAe,OAAOI,WAAP,IAAsB,QAAzC,EAAmD;AAAA,gBACjDN,MAAA,GAASM,WAAT,CADiD;AAAA,gBAEjDJ,UAAA,GAAa,IAAb,CAFiD;AAAA,aAzBL;AAAA,YA6B9C,IAAIQ,UAAA,GAAaL,KAAA,CAAM5e,IAAN,CAAWge,EAAX,CAAA,CACdznB,OADc,CACN,sBADM,EACkB,WADlB,CAAjB,CA7B8C;AAAA,YA+B9C,IAAI0oB,UAAA,CAAWpoB,OAAX,CAAmBmnB,EAAnB,CAAA,KAA2B,CAAC,CAAhC,EAAmC;AAAA,gBACjCiB,UAAA,GAAa,GAAA,GAAMA,UAAN,GAAmB,GAAhC,CADiC;AAAA,aA/BW;AAAA,YAkC9CT,YAAA,CAAa7jB,IAAb,CAAkBskB,UAAlB,CAlC8C,CAAA;AAAA,SARpC;AAAA;AA6CZ,QAAAX,OAAA,GAAUJ,SAAA,CAAUC,KAAV,CAAmB,GAAA;AAAA,YAAC9H,KAAD;AAAA,YAAQkI,MAAR;AAAA,YAAgBC,YAAhB;AAAA,SAA7B,CA7CY;AAAA,KAFmC;AAAA,IAiDjD,OAAOF,OAAA,CAAQ,CAAR,IAAaN,EAAb,GAAkBM,OAAA,CAAQ,CAAR,CAAlB,GAA+BN,EAA/B,GAAoCI,IAApC,GAA2C,IAA3C,IAAmDC,UAAA,GAAa,GAAA,GAAMA,UAAnB,GAAgC,EAAhC,CAAnD,GAAyFL,EAAzF,GAA8FM,OAAA,CAAQ,CAAR,CAArG,CAjDiD;AAAA,CAAnD,CAAA;;;;AC/BA,MAAMY,aAAA,GAAgB,wBAAtB,CAAA;AAQA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASC,aAAT,CAAuBC,GAAvB,EAA4B;AAAA,IACjC,MAAMJ,UAAA,GAAa,WAAnB,CADiC;AAAA,IAEjC,IAAII,GAAA,CAAIvoB,OAAJ,CAAYmoB,UAAZ,CAAA,KAA4B,CAAhC,EAAmC;AAAA,QACjC,OAAO,EAAP,CADiC;AAAA,KAFF;AAAA,IAKjC,OAAOI,GAAA,CAAI3oB,KAAJ,CAAUuoB,UAAA,CAAWnpB,MAArB,CAAP,CALiC;AAAA,CARnC;AAwBA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASwpB,kBAAT,CAA4BD,GAA5B,EAAiCE,KAAjC,EAAwCC,QAAxC,EAAkD;AAAA,IACvD,MAAMC,UAAA,GAAaL,aAAA,CAAcC,GAAd,CAAnB,CADuD;AAAA,IAEvD,IAAI,CAACI,UAAL,EAAiB;AAAA,QACf,OAAOC,SAAA,CAAU,IAAIC,GAAJ,CAAQN,GAAR,EAAaG,QAAb,CAAA,CAAuBI,IAAjC,CAAP,CADe;AAAA,KAFsC;AAAA,IAKvD,MAAMX,UAAA,GAAa,UAAnB,CALuD;AAAA,IAMvD,IAAIQ,UAAA,CAAW3oB,OAAX,CAAmBmoB,UAAnB,CAAA,KAAmC,CAAvC,EAA0C;AAAA,QACxC,MAAM,IAAI1jB,KAAJ,CAAU,CAAC,wBAAD,GAA2B8jB,GAA3B,EAAV,CAAA,CAAN,CADwC;AAAA,KANa;AAAA,IASvD,MAAMQ,MAAA,GAASJ,UAAA,CAAW/oB,KAAX,CAAiBuoB,UAAA,CAAWnpB,MAA5B,CAAf,CATuD;AAAA,IAWvD,OAAO,CAAA,GAAGqpB,aAAH,EAAiB,WAAjB,GAA8BU,MAA9B,EAAqC,qBAArC,GAA4DN,KAA5D,EAAA,CAAP,CAXuD;AAAA,CAxBzD;AA6CA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASO,iBAAT,CAA2BT,GAA3B,EAAgCE,KAAhC,EAAuC;AAAA,IAC5C,MAAME,UAAA,GAAaL,aAAA,CAAcC,GAAd,CAAnB,CAD4C;AAAA,IAE5C,IAAI,CAACI,UAAL,EAAiB;AAAA,QACf,OAAOC,SAAA,CAAU,IAAIC,GAAJ,CAAQN,GAAR,EAAaU,QAAA,CAASH,IAAtB,CAA4BA,CAAAA,IAAtC,CAAP,CADe;AAAA,KAF2B;AAAA,IAK5C,MAAMX,UAAA,GAAa,SAAnB,CAL4C;AAAA,IAM5C,IAAIQ,UAAA,CAAW3oB,OAAX,CAAmBmoB,UAAnB,CAAA,KAAmC,CAAvC,EAA0C;AAAA,QACxC,MAAM,IAAI1jB,KAAJ,CAAU,CAAC,sBAAD,GAAyB8jB,GAAzB,EAAV,CAAA,CAAN,CADwC;AAAA,KANE;AAAA,IAS5C,MAAM/I,KAAA,GAAQmJ,UAAA,CAAW/oB,KAAX,CAAiBuoB,UAAA,CAAWnpB,MAA5B,CAAd,CAT4C;AAAA,IAW5C,OAAO,CAAA,GAAGqpB,aAAH,EAAiB,WAAjB,GAA8B7I,KAA9B,EAAoC,eAApC,GAAqDiJ,KAArD,EAAA,CAAP,CAX4C;AAAA,CA7C9C;AA2DA,MAAMS,gBAAA,GAAmB;AAAA,IAAC,GAAD;AAAA,IAAM,GAAN;AAAA,IAAW,GAAX;AAAA,IAAgB,GAAhB;AAAA,CAAzB,CA3DA;AAsEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASC,kBAAT,CAA4BZ,GAA5B,EAAiCE,KAAjC,EAAwCW,UAAxC,EAAoDV,QAApD,EAA8D;AAAA,IACnE,MAAMW,SAAA,GAAY,IAAIR,GAAJ,CAAQN,GAAR,EAAaG,QAAb,CAAlB,CADmE;AAAA,IAEnE,MAAMC,UAAA,GAAaL,aAAA,CAAcC,GAAd,CAAnB,CAFmE;AAAA,IAGnE,IAAI,CAACI,UAAL,EAAiB;AAAA,QACf,IAAI,CAACF,KAAL,EAAY;AAAA,YACV,OAAO,CAACG,SAAA,CAAUS,SAAA,CAAUP,IAApB,CAAD,CAAP,CADU;AAAA,SADG;AAAA,QAIf,IAAI,CAACO,SAAA,CAAUC,YAAV,CAAuB1jB,GAAvB,CAA2BwjB,UAA3B,CAAL,EAA6C;AAAA,YAC3CC,SAAA,CAAUC,YAAV,CAAuBC,GAAvB,CAA2BH,UAA3B,EAAuCX,KAAvC,CAD2C,CAAA;AAAA,SAJ9B;AAAA,QAOf,OAAO,CAACG,SAAA,CAAUS,SAAA,CAAUP,IAApB,CAAD,CAAP,CAPe;AAAA,KAHkD;AAAA,IAanE,IAAIH,UAAA,KAAe,kBAAnB,EAAuC;AAAA,QACrC,MAAMa,UAAA,GAAaC,MAAA,CAAOC,gBAAP,IAA2B,GAA3B,GAAiC,KAAjC,GAAyC,EAA5D,CADqC;AAAA,QAErC,OAAO,CACL,CAAC,0BAAD,GAA6Bf,UAA7B,EAAwC,YAAxC,GAAsDa,UAAtD,EAAiE,mBAAjE,GAAsFf,KAAtF,EAAA,CADK,CAAP,CAFqC;AAAA,KAb4B;AAAA,IAmBnE,OAAOS,gBAAA,CAAiBzmB,GAAjB,CACJknB,GAAD,IACE,CAAC,QAAD,GAAWA,GAAX,EAAe,qBAAf,GAAsChB,UAAtC,EAAiD,qCAAjD,GAAwFF,KAAxF,EAFG,CAAA,CAAP,CAnBmE;AAAA;;ACvDrE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAAMmB,sBAAA,GAAyB,EAA/B,CAfA;AAgBA,MAAMC,oBAAA,GAAuB,EAA7B,CAhBA;AAkBA,IAAIC,OAAA,GAAU,CAAd,CAlBA;AAmBO,SAASC,UAAT,CAAoBC,OAApB,EAA6B;AAAA,IAClC,IAAI,CAACA,OAAA,CAAQ1c,EAAb,EAAiB;AAAA,QACf0c,OAAA,CAAQ1c,EAAR,GAAawc,OAAA,EAAb,CADe;AAAA,KADiB;AAAA,IAIlC,OAAOE,OAAA,CAAQ1c,EAAf,CAJkC;AAAA,CAnBpC;AA0BO,SAAS2c,mBAAT,CAA6BD,OAA7B,EAAsCE,OAAtC,EAA+C;AAAA,IACpD,OAAOH,UAAA,CAAWC,OAAX,CAAA,GAAsB,GAAtB,GAA4BG,MAAA,CAAOD,OAAP,CAAnC,CADoD;AAAA,CA1BtD;AAkCA;AAAA;AAAA;AAAA;AAAO,SAASE,gBAAT,CAA0BJ,OAA1B,EAAmC;AAAA,IACxC,IAAIK,aAAA,GAAgBT,sBAAA,CAAuBI,OAAA,CAAQ1c,EAA/B,CAApB,CADwC;AAAA,IAExC,IAAI,CAAC+c,aAAL,EAAoB;AAAA,QAClBA,aAAA,GAAgB,EAAhB,CADkB;AAAA,QAElBT,sBAAA,CAAuBG,UAAA,CAAWC,OAAX,CAAvB,CAAA,GAA8CK,aAA9C,CAFkB;AAAA,KAFoB;AAAA,IAMxC,OAAOA,aAAP,CANwC;AAAA,CAlC1C;AA2CO,SAASC,kBAAT,GAA8B;AAAA,IACnC,KAAWjlB,MAAAA,GAAX,IAAkBukB,sBAAlB,EAA0C;AAAA,QACxC,OAAOA,sBAAA,CAAuBvkB,GAAvB,CAAP,CADwC;AAAA,KADP;AAAA,CA3CrC;AAqDA;AAAA;AAAA;AAAA;AAAO,SAASklB,cAAT,CAAwBP,OAAxB,EAAiC;AAAA,IACtC,IAAIQ,WAAA,GAAcX,oBAAA,CAAqBG,OAAA,CAAQ1c,EAA7B,CAAlB,CADsC;AAAA,IAEtC,IAAI,CAACkd,WAAL,EAAkB;AAAA,QAChBA,WAAA,GAAc,EAAd,CADgB;AAAA,QAEhBX,oBAAA,CAAqBE,UAAA,CAAWC,OAAX,CAArB,CAAA,GAA4CQ,WAA5C,CAFgB;AAAA,KAFoB;AAAA,IAMtC,OAAOA,WAAP,CANsC;AAAA,CArDxC;AA8DO,SAASvR,OAAT,CAAiBwR,OAAjB,EAA0B;AAAA,IAC/B,OAAQA,OAAA,GAAU/rB,IAAA,CAAK2R,EAAhB,GAAsB,GAA7B,CAD+B;AAAA,CA9DjC;AAkEO,MAAMqa,kBAAA,IAAsB,YAAY;AAAA,IAC7C,MAAMC,WAAA,GAAc,EAApB,CAD6C;AAAA,IAE7C,KAAK,IAAIC,GAAA,GAAM,iBAAV,EAA6BD,WAAA,CAAY3rB,MAAZ,IAAsB,EAAxD,EAA4D4rB,GAAA,IAAO,CAAnE,EAAsE;AAAA,QACpED,WAAA,CAAY7mB,IAAZ,CAAiB8mB,GAAjB,CADoE,CAAA;AAAA,KAFzB;AAAA,IAK7C,OAAOD,WAAP,CAL6C;AAAA,CAAb,GAA3B,CAlEP;AA+EA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASE,YAAT,CAAsBC,KAAtB,EAA6BC,MAA7B,EAAqC;AAAA,IAC1C,IAAI,OAAOC,iBAAP,KAA6B,WAA7B,IAA4CC,IAAA,YAAgBD,iBAA5D,IAAiF,OAAOE,eAAP,KAA2B,WAAhH,EAA6H;AAAA;AAC3H,QAAA,OAAyB,IAAIA,eAAJ,CAAoBJ,KAApB,EAA2BC,MAA3B,CAAzB,CAD2H;AAAA,KADnF;AAAA,IAI1C,MAAMI,MAAA,GAASC,QAAA,CAASC,aAAT,CAAuB,QAAvB,CAAf,CAJ0C;AAAA,IAK1CF,MAAA,CAAOL,KAAP,GAAeA,KAAf,CAL0C;AAAA,IAM1CK,MAAA,CAAOJ,MAAP,GAAgBA,MAAhB,CAN0C;AAAA,IAO1C,OAAOI,MAAP,CAP0C;AAAA,CA/E5C;AAyFO,SAASG,oBAAT,CAA8BC,UAA9B,EAA0CZ,WAA1C,EAAuD;AAAA,IAC5D,IAAIlsB,CAAA,GAAI,CAAR,CAD4D;AAAA,IAE5D,MAAMqpB,EAAA,GAAK6C,WAAA,CAAY3rB,MAAvB,CAF4D;AAAA,IAG5D,OAAOP,CAAA,GAAIqpB,EAAX,EAAe,EAAErpB,CAAjB,EAAoB;AAAA,QAClB,MAAM+sB,SAAA,GAAYb,WAAA,CAAYlsB,CAAZ,CAAlB,CADkB;AAAA,QAElB,IAAI+sB,SAAA,GAAYD,UAAZ,IAA0B9sB,CAAA,GAAI,CAAJ,GAAQqpB,EAAtC,EAA0C;AAAA,YACxC,MAAM2D,UAAA,GAAad,WAAA,CAAYlsB,CAAZ,CAAiBksB,GAAAA,WAAA,CAAYlsB,CAAA,GAAI,CAAhB,CAApC,CADwC;AAAA,YAExC,OAAOA,CAAA,GAAIC,IAAA,CAAK4R,GAAL,CAASqa,WAAA,CAAYlsB,CAAZ,CAAiB8sB,GAAAA,UAA1B,IAAwC7sB,IAAA,CAAK4R,GAAL,CAASmb,UAAT,CAAnD,CAFwC;AAAA,SAFxB;AAAA,KAHwC;AAAA,IAU5D,OAAO3D,EAAA,GAAK,CAAZ,CAV4D;AAAA,CAzF9D;AAsGO,SAAS4D,oBAAT,CAA8B7nB,IAA9B,EAAoC8mB,WAApC,EAAiD;AAAA,IACtD,MAAMnmB,IAAA,GAAO9F,IAAA,CAAKuM,KAAL,CAAWpH,IAAX,CAAb,CADsD;AAAA,IAEtD,MAAM8nB,MAAA,GAASjtB,IAAA,CAAKoS,GAAL,CAAS,CAAT,EAAYjN,IAAA,GAAOW,IAAnB,CAAf,CAFsD;AAAA,IAGtD,OAAOmmB,WAAA,CAAYnmB,IAAZ,CAAA,GAAoBmnB,MAA3B,CAHsD;AAAA,CAtGxD;AA4GA,MAAMC,eAAA,GAAkB,EAAxB,CA5GA;AAsHA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASC,aAAT,CAAuBC,YAAvB,EAAqCvD,GAArC,EAA0Cjf,OAAA,GAAU,EAApD,EAAwDyiB,QAAxD,EAAkE;AAAA,IACvE,IAAIxD,GAAA,IAAOqD,eAAX,EAA4B;AAAA,QAC1B,IAAIG,QAAJ,EAAc;AAAA,YACZA,QAAA,CAASC,OAAT,GAAmBJ,eAAA,CAAgBrD,GAAhB,CAAA,CAAqB,CAArB,CAAnB,CADY;AAAA,SADY;AAAA,QAI1B,OAAOqD,eAAA,CAAgBrD,GAAhB,CAAqB,CAAA,CAArB,CAAP,CAJ0B;AAAA,KAD2C;AAAA,IAOvE,MAAM0D,kBAAA,GAAqB3iB,OAAA,CAAQ4iB,gBAAR,GACvB5iB,OAAA,CAAQ4iB,gBAAR,CAAyB3D,GAAzB,EAA8BuD,YAA9B,KAA+CvD,GADxB,GAEvBA,GAFJ,CAPuE;AAAA,IAUvE,MAAM4D,cAAA,GAAiBC,SAAA,CAAU,MAAMH,kBAAhB,CAAoCI,CAAAA,IAApC,CACpBJ,kBAAD,IAAwB;AAAA,QACtB,IAAI,EAAEA,kBAAA,YAA8BK,OAA9B,CAAN,EAA8C;AAAA,YAC5CL,kBAAA,GAAqB,IAAIK,OAAJ,CAAYL,kBAAZ,CAArB,CAD4C;AAAA,SADxB;AAAA,QAItB,IAAI,CAACA,kBAAA,CAAmBM,OAAnB,CAA2BvpB,GAA3B,CAA+B,QAA/B,CAAL,EAA+C;AAAA,YAC7CipB,kBAAA,CAAmBM,OAAnB,CAA2BhD,GAA3B,CAA+B,QAA/B,EAAyC,kBAAzC,CAD6C,CAAA;AAAA,SAJzB;AAAA,QAOtB,IAAIwC,QAAJ,EAAc;AAAA,YACZA,QAAA,CAASC,OAAT,GAAmBC,kBAAnB,CADY;AAAA,SAPQ;AAAA,QAUtB,OAAOO,KAAA,CAAMP,kBAAN,EACJI,IADI,CACC,UAAUI,QAAV,EAAoB;AAAA,YACxB,OAAOb,eAAA,CAAgBrD,GAAhB,CAAP,CADwB;AAAA,YAExB,OAAOkE,QAAA,CAASC,EAAT,GACHD,QAAA,CAASE,IAAT,EADG,GAEHC,OAAA,CAAQC,MAAR,CAAe,IAAIpoB,KAAJ,CAAU,wBAA2B8jB,GAAAA,GAArC,CAAf,CAFJ,CAFwB;AAAA,SADrB,CAOJuE,CAAAA,KAPI,CAOE,UAAU1iB,KAAV,EAAiB;AAAA,YACtB,OAAOwhB,eAAA,CAAgBrD,GAAhB,CAAP,CADsB;AAAA,YAEtB,OAAOqE,OAAA,CAAQC,MAAR,CAAe,IAAIpoB,KAAJ,CAAU,wBAA2B8jB,GAAAA,GAArC,CAAf,CAAP,CAFsB;AAAA,SAPnB,CAAP,CAVsB;AAAA,KADH,CAAvB,CAVuE;AAAA,IAkCvEqD,eAAA,CAAgBrD,GAAhB,CAAuB,GAAA;AAAA,QAAC0D,kBAAD;AAAA,QAAqBE,cAArB;AAAA,KAAvB,CAlCuE;AAAA,IAmCvE,OAAOA,cAAP,CAnCuE;AAAA,CAtHzE;AA4JO,SAASY,UAAT,CAAoBC,YAApB,EAAkC1jB,OAAlC,EAA2C;AAAA,IAChD,IAAI,OAAO0jB,YAAP,KAAwB,QAA5B,EAAsC;AAAA,QACpC,IAAIA,YAAA,CAAaC,IAAb,GAAoB9E,UAApB,CAA+B,GAA/B,CAAJ,EAAyC;AAAA,YACvC,IAAI;AAAA,gBACF,MAAM6B,OAAA,GAAUjgB,IAAA,CAAK9I,KAAL,CAAW+rB,YAAX,CAAhB,CADE;AAAA,gBAEF,OAAOJ,OAAA,CAAQM,OAAR,CAAgBlD,OAAhB,CAAP,CAFE;AAAA,aAAJ,CAGE,OAAO5f,KAAP,EAAc;AAAA,gBACd,OAAOwiB,OAAA,CAAQC,MAAR,CAAeziB,KAAf,CAAP,CADc;AAAA,aAJuB;AAAA,SAAzC,MAOO;AAAA,YACL4iB,YAAA,GAAehE,iBAAA,CAAkBgE,YAAlB,EAAgC1jB,OAAA,CAAQ6jB,WAAxC,CAAf,CADK;AAAA,YAEL,OAAOtB,aAAA,CAAc,OAAd,EAAuBmB,YAAvB,EAAqC1jB,OAArC,CAAP,CAFK;AAAA,SAR6B;AAAA,KAAtC,MAYO;AAAA,QACL,OAAOsjB,OAAA,CAAQM,OAAR,CAAgBF,YAAhB,CAAP,CADK;AAAA,KAbyC;AAAA,CA5JlD;AA8KA,MAAMI,aAAA,GAAgB,EAAtB,CA9KA;AAqLA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASC,WAAT,CAAqBC,QAArB,EAA+B5E,QAA/B,EAAyCpf,OAAA,GAAU,EAAnD,EAAuD;AAAA,IAC5D,MAAMikB,QAAA,GAAW;AAAA,QAAC7E,QAAD;AAAA,QAAW3e,IAAA,CAAKC,SAAL,CAAesjB,QAAf,CAAX;AAAA,KAAqCjsB,CAAAA,QAArC,EAAjB,CAD4D;AAAA,IAE5D,IAAImsB,OAAA,GAAUJ,aAAA,CAAcG,QAAd,CAAd,CAF4D;AAAA,IAG5D,IAAI,CAACC,OAAD,IAAYlkB,OAAA,CAAQ4iB,gBAAxB,EAA0C;AAAA,QACxC,IAAIuB,gBAAJ,CADwC;AAAA,QAExC,IAAInkB,OAAA,CAAQ4iB,gBAAZ,EAA8B;AAAA,YAC5BuB,gBAAA,GAAmB,CAACC,IAAD,EAAOC,GAAP,KAAe;AAAA,gBAChC,MAAM1B,kBAAA,GAAqB3iB,OAAA,CAAQ4iB,gBAAR,GACvB5iB,OAAA,CAAQ4iB,gBAAR,CAAyByB,GAAzB,EAA8B,OAA9B,KAA0CA,GADnB,GAEvBA,GAFJ,CADgC;AAAA,gBAIhC,IAAID,IAAA,YAAgBE,UAApB,EAAgC;AAAA,oBAC9BF,IAAA,CAAKG,SAAL,CAAe,CAACC,MAAD,EAASvC,UAAT,EAAqBwC,UAArB,KAAoC;AAAA,wBACjD3B,SAAA,CAAU,MAAMH,kBAAhB,EAAoCI,IAApC,CAA0CJ,kBAAD,IAAwB;AAAA,4BAC/DO,KAAA,CAAMP,kBAAN,CACGI,CAAAA,IADH,CACSI,QAAD,IAAcA,QAAA,CAASuB,WAAT,EADtB,CAAA,CAEG3B,IAFH,CAES4B,IAAD,IAAU;AAAA,gCACd,MAAMtO,MAAA,GAAS+N,IAAA,CAAKQ,SAAL,EAAf,CADc;AAAA,gCAEd,MAAMnZ,QAAA,GAAW4K,MAAA,CAAOwO,YAAP,CAAoBF,IAApB,EAA0B;AAAA,oCACzCH,MAAA,EAAQA,MADiC;AAAA,oCAEzCM,iBAAA,EAAmBL,UAFsB;AAAA,iCAA1B,CAAjB,CAFc;AAAA;AAOd,gCAAAL,IAAA,CAAKW,WAAL,CAAiBtZ,QAAjB,CAPc,CAAA;AAAA,6BAFlB,CAWG+X,CAAAA,KAXH,CAWUpsB,CAAD,IAAOgtB,IAAA,CAAKY,QAAL,CAAcC,SAAA,CAAUC,KAAxB,CAXhB,CAD+D,CAAA;AAAA,yBAAjE,CADiD,CAAA;AAAA,qBAAnD,CAD8B,CAAA;AAAA,iBAAhC,MAiBO;AAAA,oBACL,MAAMC,GAAA,GAAMf,IAAA,CAAKgB,QAAL,EAAZ,CADK;AAAA,oBAELtC,SAAA,CAAU,MAAMH,kBAAhB,EAAoCI,IAApC,CAA0CJ,kBAAD,IAAwB;AAAA,wBAC/D,IAAIA,kBAAA,YAA8BK,OAAlC,EAA2C;AAAA,4BACzCE,KAAA,CAAMP,kBAAN,CACGI,CAAAA,IADH,CACSI,QAAD,IAAcA,QAAA,CAASkC,IAAT,EADtB,CAAA,CAEGtC,IAFH,CAESsC,IAAD,IAAU;AAAA,gCACd,MAAMpG,GAAA,GAAMM,GAAA,CAAI+F,eAAJ,CAAoBD,IAApB,CAAZ,CADc;AAAA,gCAEdF,GAAA,CAAII,gBAAJ,CAAqB,MAArB,EAA6B,MAAMhG,GAAA,CAAIiG,eAAJ,CAAoBvG,GAApB,CAAnC,CAFc,CAAA;AAAA,gCAGdkG,GAAA,CAAII,gBAAJ,CAAqB,OAArB,EAA8B,MAAMhG,GAAA,CAAIiG,eAAJ,CAAoBvG,GAApB,CAApC,CAHc,CAAA;AAAA,gCAIdkG,GAAA,CAAId,GAAJ,GAAUpF,GAAV,CAJc;AAAA,6BAFlB,CAQGuE,CAAAA,KARH,CAQUpsB,CAAD,IAAOgtB,IAAA,CAAKY,QAAL,CAAcC,SAAA,CAAUC,KAAxB,CARhB,CADyC,CAAA;AAAA,yBAA3C,MAUO;AAAA,4BACLC,GAAA,CAAId,GAAJ,GAAU1B,kBAAV,CADK;AAAA,yBAXwD;AAAA,qBAAjE,CAFK,CAAA;AAAA,iBArByB;AAAA,aAAlC,CAD4B;AAAA,SAFU;AAAA,QA4CxC,MAAM1D,GAAA,GAAM+E,QAAA,CAAS/E,GAArB,CA5CwC;AAAA,QA6CxC,IAAIA,GAAA,IAAO,CAAC+E,QAAA,CAASyB,KAArB,EAA4B;AAAA,YAC1B,MAAMC,mBAAA,GAAsB7F,kBAAA,CAC1BZ,GAD0B,EAE1Bjf,OAAA,CAAQ6jB,WAFkB,EAG1B7jB,OAAA,CAAQ2lB,gBAAR,IAA4B,cAHF,EAI1BvG,QAAA,IAAYO,QAAA,CAASH,IAJK,CAA5B,CAD0B;AAAA,YAO1B,IAAIP,GAAA,CAAIJ,UAAJ,CAAe,WAAf,CAAJ,EAAiC;AAAA,gBAC/BqF,OAAA,GAAUZ,OAAA,CAAQM,OAAR,CAAgB;AAAA,oBACxBgC,QAAA,EAAU/rB,MAAA,CAAOgsB,MAAP,CAAc,EAAd,EAAkB7B,QAAlB,EAA4B;AAAA,wBACpC/E,GAAA,EAAKpnB,SAD+B;AAAA,wBAEpC4tB,KAAA,EAAOC,mBAF6B;AAAA,qBAA5B,CADc;AAAA,oBAKxBvB,gBALwB;AAAA,iBAAhB,CAAV,CAD+B;AAAA,aAAjC,MAQO;AAAA,gBACL,MAAM1B,QAAA,GAAW,EAAjB,CADK;AAAA,gBAELyB,OAAA,GAAU3B,aAAA,CACR,QADQ,EAERmD,mBAAA,CAAoB,CAApB,CAFQ,EAGR1lB,OAHQ,EAIRyiB,QAJQ,CAAA,CAKRM,IALQ,CAKH,UAAU6C,QAAV,EAAoB;AAAA,oBACzBA,QAAA,CAASH,KAAT,GAAiBG,QAAA,CAASH,KAAT,CAAetsB,GAAf,CAAmB,UAAU2sB,OAAV,EAAmB;AAAA,wBACrD,IAAIF,QAAA,CAASG,MAAT,KAAoB,KAAxB,EAA+B;AAAA,4BAC7BD,OAAA,GAAUA,OAAA,CAAQ1vB,OAAR,CAAgB,KAAhB,EAAuB,MAAvB,CAAV,CAD6B;AAAA,yBADsB;AAAA,wBAIrD,OAAOypB,kBAAA,CACLiG,OADK,EAEL9lB,OAAA,CAAQ6jB,WAFH,EAGL7jB,OAAA,CAAQ2lB,gBAAR,IAA4B,cAHvB,EAILlD,QAAA,CAASC,OAAT,CAAiBzD,GAJZ,CAAA,CAKL,CALK,CAAP,CAJqD;AAAA,qBAAtC,CAAjB,CADyB;AAAA,oBAYzB,OAAOqE,OAAA,CAAQM,OAAR,CAAgB;AAAA,wBAACgC,QAAD;AAAA,wBAAWzB,gBAAX;AAAA,qBAAhB,CAAP,CAZyB;AAAA,iBALjB,CAAV,CAFK;AAAA,aAfmB;AAAA,SAA5B,MAqCO;AAAA,YACLH,QAAA,GAAWnqB,MAAA,CAAOgsB,MAAP,CAAc,EAAd,EAAkB7B,QAAlB,EAA4B;AAAA,gBACrCyB,KAAA,EAAOzB,QAAA,CAASyB,KAAT,CAAetsB,GAAf,CAAmB,UAAU2sB,OAAV,EAAmB;AAAA,oBAC3C,IAAI9B,QAAA,CAAS+B,MAAT,KAAoB,KAAxB,EAA+B;AAAA,wBAC7BD,OAAA,GAAUA,OAAA,CAAQ1vB,OAAR,CAAgB,KAAhB,EAAuB,MAAvB,CAAV,CAD6B;AAAA,qBADY;AAAA,oBAI3C,OAAOypB,kBAAA,CACLiG,OADK,EAEL9lB,OAAA,CAAQ6jB,WAFH,EAGL7jB,OAAA,CAAQ2lB,gBAAR,IAA4B,cAHvB,EAILvG,QAAA,IAAYO,QAAA,CAASH,IAJhB,CAAA,CAKL,CALK,CAAP,CAJ2C;AAAA,iBAAtC,CAD8B;AAAA,aAA5B,CAAX,CADK;AAAA,YAcL0E,OAAA,GAAUZ,OAAA,CAAQM,OAAR,CAAgB;AAAA,gBACxBgC,QAAA,EAAU/rB,MAAA,CAAOgsB,MAAP,CAAc,EAAd,EAAkB7B,QAAlB,CADc;AAAA,gBAExBG,gBAFwB;AAAA,aAAhB,CAAV,CAdK;AAAA,SAlFiC;AAAA,QAqGxCL,aAAA,CAAcG,QAAd,CAAA,GAA0BC,OAA1B,CArGwC;AAAA,KAHkB;AAAA,IA0G5D,OAAOA,OAAP,CA1G4D;AAAA,CArL9D;AAySA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAAS8B,YAAT,CACLC,WADK,EAELC,eAFK,EAGLC,SAHK,EAILC,SAJK,EAKL;AAAA,IACA,MAAMC,OAAA,GAAU;AAAA,QACd,CAAA,GAAIF,SAAJ,GAAgBD,eAAA,CAAgBI,UAAhC,GAA6CJ,eAAA,CAAgB1E,KAD/C;AAAA,QAEd,CAAA,GAAI2E,SAAJ,GAAgBD,eAAA,CAAgBI,UAAhC,GAA6CJ,eAAA,CAAgBzE,MAF/C;AAAA,KAAhB,CADA;AAAA,IAKA,MAAM8E,WAAA,GAAchF,YAAA,CAAa8E,OAAA,CAAQ,CAAR,CAAb,EAAyBA,OAAA,CAAQ,CAAR,CAAzB,CAApB,CALA;AAAA,IAMA,MAAMG,YAAA,GAAeD,WAAA,CAAYE,UAAZ,CAAuB,IAAvB,CAArB,CANA;AAAA,IAOAD,YAAA,CAAaE,SAAb,CACET,WADF,EAEEC,eAAA,CAAgB3hB,CAFlB,EAGE2hB,eAAA,CAAgB1hB,CAHlB,EAIE0hB,eAAA,CAAgB1E,KAJlB,EAKE0E,eAAA,CAAgBzE,MALlB,EAME0E,SAAA,GAAYD,eAAA,CAAgBI,UAN9B,EAOEH,SAAA,GAAYD,eAAA,CAAgBI,UAP9B,EAQEJ,eAAA,CAAgB1E,KARlB,EASE0E,eAAA,CAAgBzE,MATlB,CAPA,CAAA;AAAA,IAkBA,MAAMkF,SAAA,GAAYH,YAAA,CAAaI,YAAb,CAA0B,CAA1B,EAA6B,CAA7B,EAAgCP,OAAA,CAAQ,CAAR,CAAhC,EAA4CA,OAAA,CAAQ,CAAR,CAA5C,CAAlB,CAlBA;AAAA,IAmBAG,YAAA,CAAaK,wBAAb,GAAwC,kBAAxC,CAnBA;AAAA,IAoBAL,YAAA,CAAaM,SAAb,GAAyB,CAAC,KAAD,GAAQV,SAAA,CAAU7uB,CAAV,GAAc,GAAtB,EAA0B,CAA1B,GAA6B6uB,SAAA,CAAU5uB,CAAV,GAAc,GAA3C,EAA+C,CAA/C,GACvB4uB,SAAA,CAAU3uB,CAAV,GAAc,GADS,EAExB,CAFwB,GAErB2uB,SAAA,CAAU1uB,CAFW,EAET,CAFS,CAAzB,CApBA;AAAA,IAuBA,MAAMitB,IAAA,GAAOgC,SAAA,CAAUhC,IAAvB,CAvBA;AAAA,IAwBA,KAAK,IAAIxvB,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAKmI,SAAA,CAAUnF,KAA1B,EAAiCrsB,CAAA,GAAIqpB,EAA1C,EAA8C,EAAErpB,CAAhD,EAAmD;AAAA,QACjD,KAAK,IAAIoT,CAAA,GAAI,CAAR,EAAWwe,EAAA,GAAKJ,SAAA,CAAUlF,MAA1B,EAAkClZ,CAAA,GAAIwe,EAA3C,EAA+C,EAAExe,CAAjD,EAAoD;AAAA,YAClD,MAAM2D,KAAA,GAAS,CAAA3D,CAAA,GAAIiW,EAAJ,GAASrpB,CAAT,IAAc,CAA7B,CADkD;AAAA,YAElD,MAAM4B,KAAA,GAAQ4tB,IAAA,CAAKzY,KAAA,GAAQ,CAAb,CAAd,CAFkD;AAAA,YAGlD,IAAInV,KAAA,GAAQ,CAAZ,EAAe;AAAA,gBACbyvB,YAAA,CAAaQ,GAAb,CACE7xB,CADF,EAEEoT,CAFF,EAGE4d,SAAA,GAAYD,eAAA,CAAgBI,UAH9B,EAIE,CAJF,EAKE,IAAIlxB,IAAA,CAAK2R,EALX,CADa,CAAA;AAAA,aAHmC;AAAA,SADH;AAAA,KAxBnD;AAAA,IAuCAyf,YAAA,CAAaS,IAAb,EAvCA,CAAA;AAAA,IAwCA,OAAOV,WAAP,CAxCA;AAAA,CA9SF;AAyVA,SAASW,UAAT,CAAoBzgB,GAApB,EAAyBC,GAAzB,EAA8BjO,KAA9B,EAAqC;AAAA,IACnC,MAAM8L,CAAA,GAAInP,IAAA,CAAKsR,GAAL,CAAS,CAAT,EAAYtR,IAAA,CAAKqR,GAAL,CAAS,CAAT,EAAa,CAAAhO,KAAA,GAAQgO,GAAR,KAAgBC,GAAA,GAAMD,GAAN,CAA7B,CAAZ,CAAV,CADmC;AAAA,IAEnC,OAAOlC,CAAA,GAAIA,CAAJ,IAAa,CAAA,GAAA,CAAA,GAAIA,CAAR,CAAhB,CAFmC;AAAA,CAzVrC;AAoWA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAAS4iB,OAAT,CAAiBloB,KAAjB,EAAwBmoB,IAAxB,EAA8BhY,KAA9B,EAAqC;AAAA,IAC1C,MAAMmX,WAAA,GAAchF,YAAA,CAAa6F,IAAA,CAAK5F,KAAlB,EAAyB4F,IAAA,CAAK3F,MAA9B,CAApB,CAD0C;AAAA,IAE1C,MAAM+E,YAAA,GAAeD,WAAA,CAAYE,UAAZ,CAAuB,IAAvB,CAArB,CAF0C;AAAA,IAG1CD,YAAA,CAAaE,SAAb,CACEznB,KADF,EAEEmoB,IAAA,CAAK7iB,CAFP,EAGE6iB,IAAA,CAAK5iB,CAHP,EAIE4iB,IAAA,CAAK5F,KAJP,EAKE4F,IAAA,CAAK3F,MALP,EAME,CANF,EAOE,CAPF,EAQE2F,IAAA,CAAK5F,KARP,EASE4F,IAAA,CAAK3F,MATP,CAH0C,CAAA;AAAA,IAc1C,MAAMkF,SAAA,GAAYH,YAAA,CAAaI,YAAb,CAA0B,CAA1B,EAA6B,CAA7B,EAAgCQ,IAAA,CAAK5F,KAArC,EAA4C4F,IAAA,CAAK3F,MAAjD,CAAlB,CAd0C;AAAA,IAe1C,MAAMkD,IAAA,GAAOgC,SAAA,CAAUhC,IAAvB,CAf0C;AAAA,IAgB1C,KAAK,IAAIxvB,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAKmI,SAAA,CAAUnF,KAA1B,EAAiCrsB,CAAA,GAAIqpB,EAA1C,EAA8C,EAAErpB,CAAhD,EAAmD;AAAA,QACjD,KAAK,IAAIoT,CAAA,GAAI,CAAR,EAAWwe,EAAA,GAAKJ,SAAA,CAAUlF,MAA1B,EAAkClZ,CAAA,GAAIwe,EAA3C,EAA+C,EAAExe,CAAjD,EAAoD;AAAA,YAClD,MAAM2D,KAAA,GAAS,CAAA3D,CAAA,GAAIiW,EAAJ,GAASrpB,CAAT,IAAc,CAA7B,CADkD;AAAA,YAElD,MAAM2P,IAAA,GAAO6f,IAAA,CAAKzY,KAAA,GAAQ,CAAb,CAAkB,GAAA,GAA/B,CAFkD;AAAA,YAIlD,MAAMmb,MAAA,GAAS,IAAf,CAJkD;AAAA,YAKlD,MAAMC,KAAA,GAAQ,GAAd,CALkD;AAAA,YAOlD,MAAMvwB,KAAA,GAAQmwB,UAAA,CAAWG,MAAA,GAASC,KAApB,EAA2BD,MAAA,GAASC,KAApC,EAA2CxiB,IAA3C,CAAd,CAPkD;AAAA,YAQlD,IAAI/N,KAAA,GAAQ,CAAZ,EAAe;AAAA,gBACb4tB,IAAA,CAAKzY,KAAA,GAAQ,CAAb,IAAkB9W,IAAA,CAAKC,KAAL,CAAW,MAAM+Z,KAAA,CAAM7X,CAAZ,GAAgBR,KAA3B,CAAlB,CADa;AAAA,gBAEb4tB,IAAA,CAAKzY,KAAA,GAAQ,CAAb,IAAkB9W,IAAA,CAAKC,KAAL,CAAW,MAAM+Z,KAAA,CAAM5X,CAAZ,GAAgBT,KAA3B,CAAlB,CAFa;AAAA,gBAGb4tB,IAAA,CAAKzY,KAAA,GAAQ,CAAb,IAAkB9W,IAAA,CAAKC,KAAL,CAAW,MAAM+Z,KAAA,CAAM3X,CAAZ,GAAgBV,KAA3B,CAAlB,CAHa;AAAA,gBAIb4tB,IAAA,CAAKzY,KAAA,GAAQ,CAAb,CAAA,GAAkB9W,IAAA,CAAKC,KAAL,CAAW,GAAM0B,GAAAA,KAAjB,CAAlB,CAJa;AAAA,aAAf,MAKO;AAAA,gBACL4tB,IAAA,CAAKzY,KAAA,GAAQ,CAAb,CAAA,GAAkB,CAAlB,CADK;AAAA,aAb2C;AAAA,SADH;AAAA,KAhBT;AAAA,IAmC1Csa,YAAA,CAAae,YAAb,CAA0BZ,SAA1B,EAAqC,CAArC,EAAwC,CAAxC,CAnC0C,CAAA;AAAA,IAoC1C,OAAOJ,WAAP,CApC0C;AAAA,CAAA;AAAA;AAAA;AAAA;;AChW5C,MAAMiB,aAAA,GAAgBxpB,KAAA,CAAM,GAAN,EAAW6B,IAAX,CAAgB,QAAhB,CAAtB,CAJA;AAKO,SAAS4nB,kBAAT,CAA4BzoB,IAA5B,EAAkC0oB,aAAlC,EAAiD;AAAA,IACtD,IAAIA,aAAA,IAAiB,IAArB,EAA2B;AAAA,QACzB,IAAIC,qBAAA,GAAwB,EAA5B,CADyB;AAAA,QAEzB,MAAMC,KAAA,GAAQ5oB,IAAA,CAAKlI,KAAL,CAAW,IAAX,CAAd,CAFyB;AAAA,QAGzB,MAAM+wB,eAAA,GAAkBL,aAAA,CAAclxB,KAAd,CACtB,CADsB,EAEtBlB,IAAA,CAAKC,KAAL,CAAWqyB,aAAA,GAAgB,GAA3B,CAFsB,CAAxB,CAHyB;AAAA,QAOzB,KAAK,IAAIxwB,CAAA,GAAI,CAAR,EAAW4wB,EAAA,GAAKF,KAAA,CAAMlyB,MAAtB,EAA8BwB,CAAA,GAAI4wB,EAAvC,EAA2C,EAAE5wB,CAA7C,EAAgD;AAAA,YAC9C,IAAIA,CAAA,GAAI,CAAR,EAAW;AAAA,gBACTywB,qBAAA,IAAyB,IAAzB,CADS;AAAA,aADmC;AAAA,YAI9CA,qBAAA,IAAyBC,KAAA,CAAM1wB,CAAN,CAASJ,CAAAA,KAAT,CAAe,EAAf,CAAmB+I,CAAAA,IAAnB,CAAwBgoB,eAAxB,CAAzB,CAJ8C;AAAA,SAPvB;AAAA,QAazB,OAAOF,qBAAP,CAbyB;AAAA,KAD2B;AAAA,IAgBtD,OAAO3oB,IAAP,CAhBsD;AAAA,CALxD;AAwBA,IAAI+oB,cAAJ,CAxBA;AAyBA,SAASC,iBAAT,GAA6B;AAAA,IAC3B,IAAI,CAACD,cAAL,EAAqB;AAAA,QACnBA,cAAA,GAAiBxG,YAAA,CAAa,CAAb,EAAgB,CAAhB,CAAA,CAAmBkF,UAAnB,CAA8B,IAA9B,CAAjB,CADmB;AAAA,KADM;AAAA,IAI3B,OAAOsB,cAAP,CAJ2B;AAAA,CAzB7B;AAgCA,SAASE,WAAT,CAAqBjpB,IAArB,EAA2B0oB,aAA3B,EAA0C;AAAA,IACxC,OACEM,iBAAA,EAAA,CAAoBC,WAApB,CAAgCjpB,IAAhC,EAAsCwiB,KAAtC,GACC,CAAAxiB,IAAA,CAAKtJ,MAAL,GAAc,CAAd,IAAmBgyB,aAFtB,CADwC;AAAA,CAhC1C;AAuCA,MAAMQ,YAAA,GAAe,EAArB,CAvCA;AAwCO,SAASC,QAAT,CAAkBnpB,IAAlB,EAAwBqD,IAAxB,EAA8B+lB,EAA9B,EAAkCV,aAAlC,EAAiD;AAAA,IACtD,IAAI1oB,IAAA,CAAKtI,OAAL,CAAa,IAAb,CAAA,KAAuB,CAAC,CAA5B,EAA+B;AAAA,QAC7B,MAAM2xB,SAAA,GAAYrpB,IAAA,CAAKlI,KAAL,CAAW,IAAX,CAAlB,CAD6B;AAAA,QAE7B,MAAM8wB,KAAA,GAAQ,EAAd,CAF6B;AAAA,QAG7B,KAAK,IAAIzyB,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAK6J,SAAA,CAAU3yB,MAA1B,EAAkCP,CAAA,GAAIqpB,EAA3C,EAA+C,EAAErpB,CAAjD,EAAoD;AAAA,YAClDyyB,KAAA,CAAMptB,IAAN,CAAW2tB,QAAA,CAASE,SAAA,CAAUlzB,CAAV,CAAT,EAAuBkN,IAAvB,EAA6B+lB,EAA7B,EAAiCV,aAAjC,CAAX,CADkD,CAAA;AAAA,SAHvB;AAAA,QAM7B,OAAOE,KAAA,CAAM/nB,IAAN,CAAW,IAAX,CAAP,CAN6B;AAAA,KADuB;AAAA,IAStD,MAAM9D,GAAA,GAAMqsB,EAAA,GAAK,GAAL,GAAW/lB,IAAX,GAAkB,GAAlB,GAAwBrD,IAAxB,GAA+B,GAA/B,GAAqC0oB,aAAjD,CATsD;AAAA,IAUtD,IAAIY,WAAA,GAAcJ,YAAA,CAAansB,GAAb,CAAlB,CAVsD;AAAA,IAWtD,IAAI,CAACusB,WAAL,EAAkB;AAAA,QAChB,MAAMC,KAAA,GAAQvpB,IAAA,CAAKlI,KAAL,CAAW,GAAX,CAAd,CADgB;AAAA,QAEhB,IAAIyxB,KAAA,CAAM7yB,MAAN,GAAe,CAAnB,EAAsB;AAAA,YACpB,MAAMmM,GAAA,GAAMmmB,iBAAA,EAAZ,CADoB;AAAA,YAEpBnmB,GAAA,CAAIQ,IAAJ,GAAWA,IAAX,CAFoB;AAAA,YAGpB,MAAMmmB,KAAA,GAAQ3mB,GAAA,CAAIomB,WAAJ,CAAgB,GAAhB,CAAqBzG,CAAAA,KAAnC,CAHoB;AAAA,YAIpB,MAAMiH,QAAA,GAAWD,KAAA,GAAQJ,EAAzB,CAJoB;AAAA,YAKpB,IAAIxe,IAAA,GAAO,EAAX,CALoB;AAAA,YAMpB,MAAMge,KAAA,GAAQ,EAAd,CANoB;AAAA;AAQpB,YAAA,KAAK,IAAIzyB,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAK+J,KAAA,CAAM7yB,MAAtB,EAA8BP,CAAA,GAAIqpB,EAAvC,EAA2C,EAAErpB,CAA7C,EAAgD;AAAA,gBAC9C,MAAMuzB,IAAA,GAAOH,KAAA,CAAMpzB,CAAN,CAAb,CAD8C;AAAA,gBAE9C,MAAMwzB,QAAA,GAAW/e,IAAA,IAAQA,IAAA,GAAO,GAAP,GAAa,EAAb,CAAR,GAA2B8e,IAA5C,CAF8C;AAAA,gBAG9C,IAAIT,WAAA,CAAYU,QAAZ,EAAsBjB,aAAtB,CAAA,IAAwCe,QAA5C,EAAsD;AAAA,oBACpD7e,IAAA,GAAO+e,QAAP,CADoD;AAAA,iBAAtD,MAEO;AAAA,oBACL,IAAI/e,IAAJ,EAAU;AAAA,wBACRge,KAAA,CAAMptB,IAAN,CAAWoP,IAAX,CADQ,CAAA;AAAA,qBADL;AAAA,oBAILA,IAAA,GAAO8e,IAAP,CAJK;AAAA,iBALuC;AAAA,aAR5B;AAAA,YAoBpB,IAAI9e,IAAJ,EAAU;AAAA,gBACRge,KAAA,CAAMptB,IAAN,CAAWoP,IAAX,CADQ,CAAA;AAAA,aApBU;AAAA;AAwBpB,YAAK,KAAA,IAAIzU,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAKoJ,KAAA,CAAMlyB,MAAtB,EAA8BP,CAAA,GAAIqpB,EAAJ,IAAUA,EAAA,GAAK,CAAlD,EAAqD,EAAErpB,CAAvD,EAA0D;AAAA,gBACxD,MAAMyU,IAAA,GAAOge,KAAA,CAAMzyB,CAAN,CAAb,CADwD;AAAA,gBAExD,IAAI8yB,WAAA,CAAYre,IAAZ,EAAkB8d,aAAlB,CAAmCe,GAAAA,QAAA,GAAW,IAAlD,EAAwD;AAAA,oBACtD,MAAMG,SAAA,GACJzzB,CAAA,GAAI,CAAJ,GAAQ8yB,WAAA,CAAYL,KAAA,CAAMzyB,CAAA,GAAI,CAAV,CAAZ,EAA0BuyB,aAA1B,CAAR,GAAmDnd,QADrD,CADsD;AAAA,oBAGtD,MAAMse,SAAA,GACJ1zB,CAAA,GAAIqpB,EAAA,GAAK,CAAT,GAAayJ,WAAA,CAAYL,KAAA,CAAMzyB,CAAA,GAAI,CAAV,CAAZ,EAA0BuyB,aAA1B,CAAb,GAAwDnd,QAD1D,CAHsD;AAAA,oBAKtDqd,KAAA,CAAM3tB,MAAN,CAAa9E,CAAb,EAAgB,CAAhB,CALsD,CAAA;AAAA,oBAMtDqpB,EAAA,IAAM,CAAN,CANsD;AAAA,oBAOtD,IAAIoK,SAAA,GAAYC,SAAhB,EAA2B;AAAA,wBACzBjB,KAAA,CAAMzyB,CAAA,GAAI,CAAV,CAAgB,IAAA,GAAA,GAAMyU,IAAtB,CADyB;AAAA,wBAEzBzU,CAAA,IAAK,CAAL,CAFyB;AAAA,qBAA3B,MAGO;AAAA,wBACLyyB,KAAA,CAAMzyB,CAAN,CAAA,GAAWyU,IAAA,GAAO,GAAP,GAAage,KAAA,CAAMzyB,CAAN,CAAxB,CADK;AAAA,qBAV+C;AAAA,iBAFA;AAAA,aAxBtC;AAAA;AA0CpB,YAAK,KAAA,IAAIA,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAKoJ,KAAA,CAAMlyB,MAAN,GAAe,CAA/B,EAAkCP,CAAA,GAAIqpB,EAA3C,EAA+C,EAAErpB,CAAjD,EAAoD;AAAA,gBAClD,MAAMyU,IAAA,GAAOge,KAAA,CAAMzyB,CAAN,CAAb,CADkD;AAAA,gBAElD,MAAM2zB,IAAA,GAAOlB,KAAA,CAAMzyB,CAAA,GAAI,CAAV,CAAb,CAFkD;AAAA,gBAGlD,IACE8yB,WAAA,CAAYre,IAAZ,EAAkB8d,aAAlB,CAAA,GAAmCe,QAAA,GAAW,GAA9C,IACAR,WAAA,CAAYa,IAAZ,EAAkBpB,aAAlB,IAAmCe,QAAA,GAAW,GAFhD,EAGE;AAAA,oBACA,MAAMM,SAAA,GAAYnf,IAAA,CAAK9S,KAAL,CAAW,GAAX,CAAlB,CADA;AAAA,oBAEA,MAAMkyB,QAAA,GAAWD,SAAA,CAAU/xB,GAAV,EAAjB,CAFA;AAAA,oBAGA,IAAIixB,WAAA,CAAYe,QAAZ,EAAsBtB,aAAtB,CAAuCe,GAAAA,QAAA,GAAW,GAAtD,EAA2D;AAAA,wBACzDb,KAAA,CAAMzyB,CAAN,CAAW4zB,GAAAA,SAAA,CAAUlpB,IAAV,CAAe,GAAf,CAAX,CADyD;AAAA,wBAEzD+nB,KAAA,CAAMzyB,CAAA,GAAI,CAAV,CAAe6zB,GAAAA,QAAA,GAAW,GAAX,GAAiBF,IAAhC,CAFyD;AAAA,qBAH3D;AAAA,oBAOAtK,EAAA,IAAM,CAAN,CAPA;AAAA,iBANgD;AAAA,aA1ChC;AAAA,YA0DpB8J,WAAA,GAAcV,KAAA,CAAM/nB,IAAN,CAAW,IAAX,CAAd,CA1DoB;AAAA,SAAtB,MA2DO;AAAA,YACLyoB,WAAA,GAActpB,IAAd,CADK;AAAA,SA7DS;AAAA,QAgEhBspB,WAAA,GAAcb,kBAAA,CAAmBa,WAAnB,EAAgCZ,aAAhC,CAAd,CAhEgB;AAAA,QAiEhBQ,YAAA,CAAansB,GAAb,CAAA,GAAoBusB,WAApB,CAjEgB;AAAA,KAXoC;AAAA,IA8EtD,OAAOA,WAAP,CA9EsD;AAAA,CAxCxD;AAyHA,MAAMW,eAAA,GAAkB,wBAAxB,CAzHA;AA0HA,MAAMC,gBAAA,GAAmB,QAAzB,CA1HA;AA2HA,IAAIC,kBAAJ,CA3HA;AA4HA,SAASC,aAAT,CAAuBC,MAAvB,EAA+B;AAAA,IAC7B,IAAI,CAACF,kBAAL,EAAyB;AAAA,QACvBA,kBAAA,GAAqB,EAArB,CADuB;AAAA,QAEvB,MAAMG,WAAA,GAAcxH,QAAA,CAASwH,WAA7B,CAFuB;AAAA,QAGvB,KAAK,IAAIn0B,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAK8K,WAAA,CAAY5zB,MAA5B,EAAoCP,CAAA,GAAIqpB,EAA7C,EAAiD,EAAErpB,CAAnD,EAAsD;AAAA,YACpD,MAAMo0B,UAAA,GAA2CD,WAAA,CAAYn0B,CAAZ,CAAjD,CADoD;AAAA,YAEpD,IAAI;AAAA,gBACF,MAAMq0B,QAAA,GAAWD,UAAA,CAAWE,KAAX,IAAoBF,UAAA,CAAWC,QAAhD,CADE;AAAA,gBAEF,IAAIA,QAAJ,EAAc;AAAA,oBACZ,KAAK,IAAIjhB,CAAA,GAAI,CAAR,EAAWwe,EAAA,GAAKyC,QAAA,CAAS9zB,MAAzB,EAAiC6S,CAAA,GAAIwe,EAA1C,EAA8C,EAAExe,CAAhD,EAAmD;AAAA,wBACjD,MAAMmhB,OAAA,GAAUF,QAAA,CAASjhB,CAAT,CAAhB,CADiD;AAAA,wBAEjD,IAAImhB,OAAA,CAAQ9vB,IAAR,IAAgB,CAApB,EAAuB;AAAA,4BACrB,MAAM8B,KAAA,GAAQguB,OAAA,CAAQC,OAAR,CAAgBjuB,KAAhB,CAAsButB,eAAtB,CAAd,CADqB;AAAA,4BAErBE,kBAAA,CAAmBztB,KAAA,CAAM,CAAN,CAAStF,CAAAA,OAAT,CAAiB8yB,gBAAjB,EAAmC,EAAnC,CAAnB,CAAA,GAA6D,IAA7D,CAFqB;AAAA,yBAF0B;AAAA,qBADvC;AAAA,iBAFZ;AAAA,aAAJ,CAWE,OAAO9xB,CAAP,EAAU;AAAA,aAbwC;AAAA,SAH/B;AAAA,KADI;AAAA,IAsB7B,OAAOiyB,MAAA,IAAUF,kBAAjB,CAtB6B;AAAA,CA5H/B;AAqJA,MAAMS,qBAAA,GAAwB,EAA9B,CArJA;AA6JA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASC,QAAT,CACL7L,KADK,EAEL8L,WAAA,GAAc,qFAFT,EAGL;AAAA,IACA,MAAMC,QAAA,GAAW/L,KAAA,CAAMjmB,QAAN,EAAjB,CADA;AAAA,IAEA,IAAIgyB,QAAA,IAAYH,qBAAhB,EAAuC;AAAA,QACrC,OAAOA,qBAAA,CAAsBG,QAAtB,CAAP,CADqC;AAAA,KAFvC;AAAA,IAKA,MAAMC,gBAAA,GAAmB,EAAzB,CALA;AAAA,IAMA,KAAK,IAAI70B,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAKR,KAAA,CAAMtoB,MAAtB,EAA8BP,CAAA,GAAIqpB,EAAvC,EAA2C,EAAErpB,CAA7C,EAAgD;AAAA,QAC9C6oB,KAAA,CAAM7oB,CAAN,CAAA,GAAW6oB,KAAA,CAAM7oB,CAAN,CAASiB,CAAAA,OAAT,CAAiB,kBAAjB,EAAqC,OAArC,CAAX,CAD8C;AAAA,QAE9C,MAAMiM,IAAA,GAAO2b,KAAA,CAAM7oB,CAAN,CAAb,CAF8C;AAAA,QAG9C,MAAM80B,OAAA,GAAUC,MAAA,CAAO7nB,IAAP,EAAa,CAAb,CAAhB,CAH8C;AAAA,QAI9C8nB,YAAA,CAAaF,OAAb,CAJ8C,CAAA;AAAA,QAK9C,MAAMxL,KAAA,GAAQwL,OAAA,CAAQnzB,KAAR,CAAc,GAAd,CAAd,CAL8C;AAAA,QAM9CkzB,gBAAA,CAAiBxvB,IAAjB,CAAsB;AAAA,YACpBikB,KAAA,CAAMnoB,KAAN,CAAY,CAAZ,CAAeuJ,CAAAA,IAAf,CAAoB,GAApB,EAAyBzJ,OAAzB,CAAiC,IAAjC,EAAuC,EAAvC,CADoB;AAAA,YAEpBqoB,KAAA,CAAM,CAAN,CAFoB;AAAA,YAGpBA,KAAA,CAAM,CAAN,CAHoB;AAAA,SAAtB,CAN8C,CAAA;AAAA,KANhD;AAAA,IAkBA,KAAK,IAAItpB,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAKwL,gBAAA,CAAiBt0B,MAAjC,EAAyCP,CAAA,GAAIqpB,EAAlD,EAAsD,EAAErpB,CAAxD,EAA2D;AAAA,QACzD,MAAMi1B,eAAA,GAAkBJ,gBAAA,CAAiB70B,CAAjB,CAAxB,CADyD;AAAA,QAEzD,MAAMk0B,MAAA,GAASe,eAAA,CAAgB,CAAhB,CAAf,CAFyD;AAAA,QAGzD,IAAI,CAAChB,aAAA,CAAcC,MAAd,CAAL,EAA4B;AAAA,YAC1B,IACEgB,YAAA,CAAa3wB,GAAb,CACE,IAAG0wB,eAAA,CAAgB,CAAhB,CAAH,EAAsB,EAAtB,GAA0BA,eAAA,CAAgB,CAAhB,CAA1B,EAA6C,GAA7C,GAAkDf,MAAlD,EAAA,CADF,CAEM,KAAA,GAHR,EAIE;AAAA,gBACA,MAAMiB,OAAA,GAAUR,WAAA,CACb1zB,OADa,CACL,eADK,EACYizB,MAAA,CAAOjzB,OAAP,CAAe,IAAf,EAAqB,GAArB,CAAA,CAA0BC,WAA1B,EADZ,CAEbD,CAAAA,OAFa,CAEL,eAFK,EAEYizB,MAAA,CAAOjzB,OAAP,CAAe,IAAf,EAAqB,GAArB,CAFZ,CAAA,CAGbA,OAHa,CAGL,cAHK,EAGWg0B,eAAA,CAAgB,CAAhB,CAHX,CAAA,CAIbh0B,OAJa,CAKZ,cALY,EAMZg0B,eAAA,CAAgB,CAAhB,CAAA,CAAmBh0B,OAAnB,CAA2B,QAA3B,EAAqC,EAArC,CAAyCA,CAAAA,OAAzC,CAAiD,MAAjD,EAAyD,KAAzD,CANY,CAQbA,CAAAA,OARa,CAQL,aARK,EAQUg0B,eAAA,CAAgB,CAAhB,CARV,CAAhB,CADA;AAAA,gBAUA,IAAI,CAACtI,QAAA,CAASyI,aAAT,CAAuB,aAAA,GAAgBD,OAAhB,GAA0B,IAAjD,CAAL,EAA6D;AAAA,oBAC3D,MAAME,MAAA,GAAS1I,QAAA,CAASC,aAAT,CAAuB,MAAvB,CAAf,CAD2D;AAAA,oBAE3DyI,MAAA,CAAOhL,IAAP,GAAc8K,OAAd,CAF2D;AAAA,oBAG3DE,MAAA,CAAOC,GAAP,GAAa,YAAb,CAH2D;AAAA,oBAI3D3I,QAAA,CAAS4I,IAAT,CAAcC,WAAd,CAA0BH,MAA1B,CAJ2D,CAAA;AAAA,iBAV7D;AAAA,aALwB;AAAA,SAH6B;AAAA,KAlB3D;AAAA,IA6CAZ,qBAAA,CAAsBG,QAAtB,CAAA,GAAkC/L,KAAlC,CA7CA;AAAA,IA8CA,OAAOA,KAAP,CA9CA;AAAA;;AC1JF;AAAA;AAAA;AAAA;AAAA;AAyCA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAAM3c,KAAA,GAAQ;AAAA,IACZ,SAAS,CADG;AAAA,IAEZ,cAAc,CAFF;AAAA,IAGZ,cAAc,CAHF;AAAA,IAIZ,mBAAmB,CAJP;AAAA,IAKZ,WAAW,CALC;AAAA,IAMZ,gBAAgB,CANJ;AAAA,CAAd,CA/CA;AAuDA,MAAMupB,MAAA,GAAS;AAAA,IACb,QAAU,EAAA;AAAA,QAAC,GAAD;AAAA,QAAM,GAAN;AAAA,KADG;AAAA,IAEb,MAAQ,EAAA;AAAA,QAAC,CAAD;AAAA,QAAI,GAAJ;AAAA,KAFK;AAAA,IAGb,OAAS,EAAA;AAAA,QAAC,CAAD;AAAA,QAAI,GAAJ;AAAA,KAHI;AAAA,IAIb,KAAO,EAAA;AAAA,QAAC,GAAD;AAAA,QAAM,CAAN;AAAA,KAJM;AAAA,IAKb,QAAU,EAAA;AAAA,QAAC,GAAD;AAAA,QAAM,CAAN;AAAA,KALG;AAAA,IAMb,UAAY,EAAA;AAAA,QAAC,CAAD;AAAA,QAAI,CAAJ;AAAA,KANC;AAAA,IAOb,WAAa,EAAA;AAAA,QAAC,CAAD;AAAA,QAAI,CAAJ;AAAA,KAPA;AAAA,IAQb,aAAe,EAAA;AAAA,QAAC,CAAD;AAAA,QAAI,CAAJ;AAAA,KARF;AAAA,IASb,cAAgB,EAAA;AAAA,QAAC,CAAD;AAAA,QAAI,CAAJ;AAAA,KATH;AAAA,CAAf,CAvDA;AAmEA,MAAMC,cAAA,GAAiB,UAAUC,aAAV,EAAyBlyB,YAAzB,EAAuC;AAAA,IAC5D,MAAMmyB,kBAAA,GAAqBzR,wBAAA,CACzBwR,aADyB,EAEzBlyB,YAFyB,CAA3B,CAD4D;AAAA,IAK5D,IAAImyB,kBAAA,CAAmBxvB,MAAnB,KAA8B,OAAlC,EAA2C;AAAA,QACzC,MAAM,IAAIJ,KAAJ,CACJ4vB,kBAAA,CAAmBtyB,KAAnB,CACGU,GADH,CACQ4hB,GAAD,IAAS,CAAGA,GAAAA,GAAA,CAAIhf,GAAP,EAAW,EAAX,GAAegf,GAAA,CAAI/e,OAAnB,EADhB,CAAA,CAAA,CAEG6D,IAFH,CAEQ,IAFR,CADI,CAAN,CADyC;AAAA,KALiB;AAAA,IAY5D,OAAOkrB,kBAAA,CAAmBtyB,KAA1B,CAZ4D;AAAA,CAA9D,CAnEA;AAkFA,MAAMuyB,UAAA,GAAW,EAAjB,CAlFA;AAmFA,MAAMC,OAAA,GAAU,EAAC1wB,IAAA,EAAM,CAAP,EAAhB,CAnFA;AAoFA,IAAI2wB,wBAAJ,EAA8BC,aAA9B,CApFA;AAiGA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASC,QAAT,CACL5O,KADK,EAEL6O,aAFK,EAGLpyB,QAHK,EAILsB,IAJK,EAKLkJ,OALK,EAMLsd,aANK,EAOLrd,YAPK,EAQL;AAAA,IACA,MAAM4nB,OAAA,GAAU9O,KAAA,CAAMxY,EAAtB,CADA;AAAA,IAEA,IAAI,CAAC+c,aAAL,EAAoB;AAAA,QAClBA,aAAA,GAAgB,EAAhB,CADkB;AAAA,QAElBpI,OAAA,CAAQC,IAAR,CAAa,yCAAb,CAAA,CAAA;AAFkB,KAFpB;AAAA,IAMA,IAAI,CAACmI,aAAA,CAAcuK,OAAd,CAAL,EAA6B;AAAA,QAC3BvK,aAAA,CAAcuK,OAAd,CAAA,GAAyB,EAAzB,CAD2B;AAAA,KAN7B;AAAA,IASA,MAAMC,SAAA,GAAYxK,aAAA,CAAcuK,OAAd,CAAlB,CATA;AAAA,IAUA,IAAI,CAACC,SAAA,CAAUtyB,QAAV,CAAL,EAA0B;AAAA,QACxB,IAAIR,KAAA,GAAS,CAAA+jB,KAAA,CAAM6O,aAAN,CAAA,IAAwBL,UAAxB,EAAkC/xB,QAAnC,CAAZ,CADwB;AAAA,QAExB,MAAML,YAAA,GAAemf,IAAA,CAAK,IAAGsT,aAAH,EAAiB,CAAjB,GAAoB7O,KAAA,CAAM5iB,IAA1B,GAAL,CAAuCX,CAAAA,QAAvC,CAArB,CAFwB;AAAA,QAGxB,IAAIR,KAAA,KAAUZ,SAAd,EAAyB;AAAA,YACvBY,KAAA,GAAQG,YAAA,CAAae,OAArB,CADuB;AAAA,SAHD;AAAA,QAMxB,IAAI6xB,MAAA,GAAS3S,YAAA,CAAapgB,KAAb,CAAb,CANwB;AAAA,QAOxB,IAAI,CAAC+yB,MAAD,IAAWtT,UAAA,CAAWzf,KAAX,CAAf,EAAkC;AAAA,YAChCA,KAAA,GAAQC,eAAA,CAAgBD,KAAhB,EAAuBG,YAAvB,CAAR,CADgC;AAAA,YAEhC4yB,MAAA,GAAS,IAAT,CAFgC;AAAA,SAPV;AAAA,QAWxB,IAAIA,MAAJ,EAAY;AAAA,YACV,MAAMT,kBAAA,GAAqBF,cAAA,CAAepyB,KAAf,EAAsBG,YAAtB,CAA3B,CADU;AAAA,YAEV2yB,SAAA,CAAUtyB,QAAV,CAAA,GACE8xB,kBAAA,CAAmB/pB,QAAnB,CAA4ByqB,IAA5B,CAAiCV,kBAAjC,CADF,CAFU;AAAA,SAAZ,MAIO;AAAA,YACL,IAAInyB,YAAA,CAAagB,IAAb,IAAqB,OAAzB,EAAkC;AAAA,gBAChCnB,KAAA,GAAQpB,OAAA,CAAMM,KAAN,CAAYc,KAAZ,CAAR,CADgC;AAAA,aAD7B;AAAA,YAIL8yB,SAAA,CAAUtyB,QAAV,CAAA,GAAsB,YAAY;AAAA,gBAChC,OAAOR,KAAP,CADgC;AAAA,aAAlC,CAJK;AAAA,SAfiB;AAAA,KAV1B;AAAA,IAkCAwyB,OAAA,CAAQ1wB,IAAR,GAAeA,IAAf,CAlCA;AAAA,IAmCA,OAAOgxB,SAAA,CAAUtyB,QAAV,CAAA,CAAoBgyB,OAApB,EAA6BxnB,OAA7B,EAAsCC,YAAtC,CAAP,CAnCA;AAAA,CAzGF;AAwJA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAASgoB,gBAAT,CAA0BlP,KAA1B,EAAiCjiB,IAAjC,EAAuCkJ,OAAvC,EAAgDkoB,MAAhD,EAAwD5K,aAAxD,EAAuE;AAAA,IACrE,MAAM6K,YAAA,GAAeR,QAAA,CACnB5O,KADmB,EAEnB,QAFmB,EAGnB,CAAA,GAAGmP,MAAH,EAAU,cAAV,CAHmB,EAInBpxB,IAJmB,EAKnBkJ,OALmB,EAMnBsd,aANmB,CAArB,CADqE;AAAA,IASrE,IAAI,CAAC6K,YAAL,EAAmB;AAAA,QACjB,OAAO,WAAP,CADiB;AAAA,KATkD;AAAA,IAYrE,MAAMC,eAAA,GAAkBT,QAAA,CACtB5O,KADsB,EAEtB,QAFsB,EAGtB,CAAA,GAAGmP,MAAH,EAAU,iBAAV,CAHsB,EAItBpxB,IAJsB,EAKtBkJ,OALsB,EAMtBsd,aANsB,CAAxB,CAZqE;AAAA,IAoBrE,IAAI,CAAC8K,eAAL,EAAsB;AAAA,QACpB,OAAO,UAAP,CADoB;AAAA,KApB+C;AAAA,IAuBrE,OAAO,MAAP,CAvBqE;AAAA,CAxJvE;AA2LA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAASC,cAAT,CAAwBR,OAAxB,EAAiChmB,MAAjC,EAAyC7B,OAAzC,EAAkDlJ,IAAlD,EAAwD2mB,WAAxD,EAAqE;AAAA,IACnE,IAAI,CAACA,WAAL,EAAkB;AAAA,QAChBvI,OAAA,CAAQC,IAAR,CAAa,6CAAb,CAAA,CAAA;AADgB,KADiD;AAAA,IAInE,IAAI,EAAE0S,OAAA,IAAWpK,WAAX,CAAN,EAA+B;AAAA,QAC7BA,WAAA,CAAYoK,OAAZ,CAAA,GAAuBnR,YAAA,CAAa7U,MAAb,CAAqBA,CAAAA,MAA5C,CAD6B;AAAA,KAJoC;AAAA,IAOnE2lB,OAAA,CAAQ1wB,IAAR,GAAeA,IAAf,CAPmE;AAAA,IAQnE,OAAO2mB,WAAA,CAAYoK,OAAZ,EAAqBL,OAArB,EAA8BxnB,OAA9B,CAAP,CARmE;AAAA,CA3LrE;AAsMA,IAAIsoB,wBAAA,GAA2B,KAA/B,CAtMA;AAgNA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASC,iBAAT,CAA2BC,OAA3B,EAAoC;AAAA,IACzC,IAAIA,OAAA,KAAYF,wBAAhB,EAA0C;AAAA,QACxC/K,kBAAA,EADwC,CAAA;AAAA,QAExC+K,wBAAA,GAA2BE,OAA3B,CAFwC;AAAA,KADD;AAAA,CAhN3C;AA6NA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAASC,gBAAT,CAA0B9c,KAA1B,EAAiC+c,OAAjC,EAA0C;AAAA,IACxC,IAAI/c,KAAJ,EAAW;AAAA,QACT,IAAI,CAAC2c,wBAAD,KAA8B3c,KAAA,CAAM1X,CAAN,KAAY,CAAZ,IAAiBy0B,OAAA,KAAY,CAA7B,CAAlC,EAAmE;AAAA,YACjE,OAAOt0B,SAAP,CADiE;AAAA,SAD1D;AAAA,QAIT,MAAMH,CAAA,GAAI0X,KAAA,CAAM1X,CAAhB,CAJS;AAAA,QAKTy0B,OAAA,GAAUA,OAAA,KAAYt0B,SAAZ,GAAwB,CAAxB,GAA4Bs0B,OAAtC,CALS;AAAA,QAMT,OAAOz0B,CAAA,KAAM,CAAN,GACH,aADG,GAEH,OACEtC,GAAAA,IAAA,CAAKC,KAAL,CAAY+Z,KAAA,CAAM7X,CAAN,GAAU,GAAX,GAAkBG,CAA7B,CADF,GAEE,GAFF,GAGEtC,IAAA,CAAKC,KAAL,CAAY+Z,KAAA,CAAM5X,CAAN,GAAU,GAAX,GAAkBE,CAA7B,CAHF,GAIE,GAJF,GAKEtC,IAAA,CAAKC,KAAL,CAAY+Z,KAAA,CAAM3X,CAAN,GAAU,GAAX,GAAkBC,CAA7B,CALF,GAME,GANF,GAOEA,CAAA,GAAIy0B,OAPN,GAQE,GAVN,CANS;AAAA,KAD6B;AAAA,IAmBxC,OAAO/c,KAAP,CAnBwC;AAAA,CA7N1C;AAmPA,MAAMgd,aAAA,GAAgB,cAAtB,CAnPA;AA2PA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAASC,YAAT,CAAsBrtB,IAAtB,EAA4BoF,UAA5B,EAAwC;AAAA,IACtC,OAAOpF,IAAA,CAAK5I,OAAL,CAAag2B,aAAb,EAA4B,UAAU1wB,KAAV,EAAiB;AAAA,QAClD,OAAO0I,UAAA,CAAW1I,KAAA,CAAMpF,KAAN,CAAY,CAAZ,EAAe,CAAC,CAAhB,CAAX,CAAA,IAAkC,EAAzC,CADkD;AAAA,KAA7C,CAAP,CADsC;AAAA,CA3PxC;AAiQA,IAAIg2B,WAAA,GAAc,KAAlB,CAjQA;AAyQA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASC,gBAAT,CAA0BC,MAAA,GAAS,KAAnC,EAA0C;AAAA,IAC/CF,WAAA,GAAcE,MAAd,CAD+C;AAAA,CAzQjD;AA6QO,MAAMC,iBAAA,GAAoB,EAA1B,CA7QP;AAmVA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASC,aAAT,CACL9L,OADK,EAELF,OAFK,EAGLiM,cAHK,EAILtL,WAAA,GAAcD,kBAJT,EAKLwL,UAAA,GAAa/0B,SALR,EAMLg1B,cAAA,GAAiBh1B,SANZ,EAOLgyB,QAAA,GAAWhyB,SAPN,EAQLutB,QAAA,GAAWvtB,SARN,EASL;AAAA,IACA,IAAI,OAAO6oB,OAAP,IAAkB,QAAtB,EAAgC;AAAA,QAC9BA,OAAA,GAAUjgB,IAAA,CAAK9I,KAAL,CAAW+oB,OAAX,CAAV,CAD8B;AAAA,KADhC;AAAA,IAIA,IAAIA,OAAA,CAAQoM,OAAR,IAAmB,CAAvB,EAA0B;AAAA,QACxB,MAAM,IAAI3xB,KAAJ,CAAU,6BAAV,CAAN,CADwB;AAAA,KAJ1B;AAAA,IAOAsxB,iBAAA,CAAkB9L,mBAAA,CAAoBD,OAApB,EAA6BE,OAA7B,CAAlB,CAAA,GACE5iB,KAAA,CAAMqR,IAAN,CAAW0d,SAAX,CADF,CAPA;AAAA,IAUA,IAAI9G,WAAJ,EAAiB+G,eAAjB,CAVA;AAAA,IAWA,IAAIC,kBAAJ,CAXA;AAAA,IAaA,IAAIJ,cAAJ,EAAoB;AAAA,QAClB,IAAI,OAAOK,KAAP,KAAiB,WAArB,EAAkC;AAAA,YAChC,MAAM/H,GAAA,GAAM,IAAI+H,KAAJ,EAAZ,CADgC;AAAA,YAEhC,IAAIC,OAAJ,CAFgC;AAAA,YAGhCrK,SAAA,CAAU,MAAM+J,cAAhB,EAAgC9J,IAAhC,CAAsC8J,cAAD,IAAoB;AAAA,gBACvD,IAAIA,cAAA,YAA0B7J,OAA9B,EAAuC;AAAA,oBACrCE,KAAA,CAAM2J,cAAN,CACG9J,CAAAA,IADH,CACSI,QAAD,IAAcA,QAAA,CAASkC,IAAT,EADtB,CAAA,CAEGtC,IAFH,CAESsC,IAAD,IAAU;AAAA,wBACd8H,OAAA,GAAU5N,GAAA,CAAI+F,eAAJ,CAAoBD,IAApB,CAAV,CADc;AAAA,wBAEdF,GAAA,CAAId,GAAJ,GAAU8I,OAAV,CAFc;AAAA,qBAFlB,CAAA,CAMG3J,KANH,CAMS,MAAM;AAAA,qBANf,CADqC,CAAA;AAAA,iBAAvC,MAQO;AAAA,oBACL2B,GAAA,CAAIiI,WAAJ,GAAkB,WAAlB,CADK;AAAA,oBAELjI,GAAA,CAAId,GAAJ,GAAUwI,cAAV,CAFK;AAAA,oBAGL,IAAIM,OAAJ,EAAa;AAAA,wBACX5N,GAAA,CAAIiG,eAAJ,CAAoB2H,OAApB,CADW,CAAA;AAAA,qBAHR;AAAA,iBATgD;AAAA,aAAzD,CAHgC,CAAA;AAAA,YAoBhChI,GAAA,CAAIkI,MAAJ,GAAa,YAAY;AAAA,gBACvBpH,WAAA,GAAcd,GAAd,CADuB;AAAA,gBAEvB6H,eAAA,GAAkB;AAAA,oBAAC7H,GAAA,CAAI3D,KAAL;AAAA,oBAAY2D,GAAA,CAAI1D,MAAhB;AAAA,iBAAlB,CAFuB;AAAA,gBAGvBb,OAAA,CAAQ0M,OAAR,EAHuB,CAAA;AAAA,gBAIvBnI,GAAA,CAAIkI,MAAJ,GAAa,IAAb,CAJuB;AAAA,aAAzB,CApBgC;AAAA,SAAlC,MA0BO,IAAI,OAAO3L,iBAAP,KAA6B,WAA7B,IAA4CC,IAAA,YAAgBD,iBAAhE,EAAmF;AAAA;AACxF,YAAM6L,MAAAA,MAAA,GAA2B5L,IAAjC,CADwF;AAAA;AAGxF,YAAA4L,MAAA,CAAOC,WAAP,CAAmB;AAAA,gBACjBC,MAAA,EAAQ,WADS;AAAA,gBAEjBpJ,GAAA,EAAKwI,cAFY;AAAA,aAAnB,CAHwF,CAAA;AAAA,YAOxFU,MAAA,CAAOhI,gBAAP,CAAwB,SAAxB,EAAmC,SAASmI,OAAT,CAAiBC,KAAjB,EAAwB;AAAA,gBACzD,IACEA,KAAA,CAAMhJ,IAAN,CAAW8I,MAAX,KAAsB,aAAtB,IACAE,KAAA,CAAMhJ,IAAN,CAAWN,GAAX,KAAmBwI,cAFrB,EAGE;AAAA,oBACA5G,WAAA,GAAc0H,KAAA,CAAMhJ,IAAN,CAAW1lB,KAAzB,CADA;AAAA,oBAEA+tB,eAAA,GAAkB;AAAA,wBAAC/G,WAAA,CAAYzE,KAAb;AAAA,wBAAoByE,WAAA,CAAYxE,MAAhC;AAAA,qBAAlB,CAFA;AAAA,iBAJuD;AAAA,aAA3D,CAPwF,CAAA;AAAA,SA3BxE;AAAA,KAbpB;AAAA,IA2DA,MAAMmM,SAAA,GAAYlR,WAAA,CAAYgE,OAAA,CAAQ/D,MAApB,CAAlB,CA3DA;AAAA,IA6DA,MAAMkR,mBAAA,GAAsB,EAA5B,CA7DA;AAAA,IA8DA,MAAMC,YAAA,GAAe,EAArB,CA9DA;AAAA,IAgEA,MAAMC,cAAA,GAAiB,EAAvB,CAhEA;AAAA,IAiEA,MAAMC,YAAA,GAAe,EAArB,CAjEA;AAAA,IAkEA,MAAMjN,aAAA,GAAgBD,gBAAA,CAAiBJ,OAAjB,CAAtB,CAlEA;AAAA,IAmEA,MAAMQ,WAAA,GAAcD,cAAA,CAAeP,OAAf,CAApB,CAnEA;AAAA,IAqEA,IAAIuN,YAAJ,CArEA;AAAA,IAsEA,KAAK,IAAI94B,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAKoP,SAAA,CAAUl4B,MAA1B,EAAkCP,CAAA,GAAIqpB,EAA3C,EAA+C,EAAErpB,CAAjD,EAAoD;AAAA,QAClD,MAAMqnB,KAAA,GAAQoR,SAAA,CAAUz4B,CAAV,CAAd,CADkD;AAAA,QAElD,MAAMm2B,OAAA,GAAU9O,KAAA,CAAMxY,EAAtB,CAFkD;AAAA,QAGlD,IACG,OAAO2oB,cAAP,IAAyB,QAAzB,IAAqCnQ,KAAA,CAAM0R,MAAN,IAAgBvB,cAAtD,IACC3uB,KAAA,CAAMC,OAAN,CAAc0uB,cAAd,CAAA,IAAiCA,cAAA,CAAej2B,OAAf,CAAuB40B,OAAvB,CAAA,KAAoC,CAAC,CAFzE,EAGE;AAAA,YACA,MAAM6C,WAAA,GAAc3R,KAAA,CAAM,cAAN,CAApB,CADA;AAAA,YAEA,IAAI,CAACyR,YAAL,EAAmB;AAAA,gBACjBA,YAAA,GAAezR,KAAA,CAAM0R,MAArB,CADiB;AAAA,gBAEjB,MAAMA,MAAA,GAASxN,OAAA,CAAQ0N,OAAR,CAAgBH,YAAhB,CAAf,CAFiB;AAAA,gBAGjB,IAAI,CAACC,MAAL,EAAa;AAAA,oBACX,MAAM,IAAI/yB,KAAJ,CAAU,CAAC,QAAD,GAAW8yB,YAAX,EAAwB,gBAAxB,CAAV,CAAN,CADW;AAAA,iBAHI;AAAA,gBAMjB,MAAMr0B,IAAA,GAAOs0B,MAAA,CAAOt0B,IAApB,CANiB;AAAA,gBAOjB,IAAIA,IAAA,KAAS,QAAT,IAAqBA,IAAA,KAAS,SAAlC,EAA6C;AAAA,oBAC3C,MAAM,IAAIuB,KAAJ,CACJ,CAAC,QAAD,GAAW8yB,YAAX,EAAwB,6CAAxB,GAAuEr0B,IAAvE,EAA4E,CAA5E,CADI,CAAN,CAD2C;AAAA,iBAP5B;AAAA,aAAnB,MAYO,IAAI4iB,KAAA,CAAM0R,MAAN,KAAiBD,YAArB,EAAmC;AAAA,gBACxC,MAAM,IAAI9yB,KAAJ,CACJ,CAAC,OAAD,GAAUmwB,OAAV,EAAkB,uBAAlB,GAA2C2C,YAA3C,EAAA,CADI,CAAN,CADwC;AAAA,aAd1C;AAAA,YAmBA,IAAItR,MAAA,GAASkR,mBAAA,CAAoBM,WAApB,CAAb,CAnBA;AAAA,YAoBA,IAAI,CAACxR,MAAL,EAAa;AAAA,gBACXA,MAAA,GAAS,EAAT,CADW;AAAA,gBAEXkR,mBAAA,CAAoBM,WAApB,CAAA,GAAmCxR,MAAnC,CAFW;AAAA,aApBb;AAAA,YAwBAA,MAAA,CAAOniB,IAAP,CAAY;AAAA,gBACVgiB,KAAA,EAAOA,KADG;AAAA,gBAEVtQ,KAAA,EAAO/W,CAFG;AAAA,aAAZ,CAxBA,CAAA;AAAA,YA4BA24B,YAAA,CAAatzB,IAAb,CAAkB8wB,OAAlB,CA5BA,CAAA;AAAA,SANgD;AAAA,KAtEpD;AAAA,IA4GA,MAAM+C,QAAA,GAAW,IAAIC,MAAJ,EAAjB,CA5GA;AAAA,IA6GA,MAAMlvB,SAAA,GAAY,IAAImvB,IAAJ,EAAlB,CA7GA;AAAA,IA+GA,MAAMC,MAAA,GAAS,EAAf,CA/GA;AAAA;AAuHA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAMC,MAAAA,aAAA,GAAgB,UAAUhrB,OAAV,EAAmBwe,UAAnB,EAA+ByM,SAA/B,EAA0C;AAAA,QAC9D,MAAMtqB,UAAA,GAAaX,OAAA,CAAQkrB,aAAR,EAAnB,CAD8D;AAAA,QAE9D,MAAMhS,MAAA,GAASkR,mBAAA,CAAoBzpB,UAAA,CAAWoY,KAA/B,CAAf,CAF8D;AAAA,QAG9D,IAAI,CAACG,MAAL,EAAa;AAAA,YACX,OAAO9kB,SAAP,CADW;AAAA,SAHiD;AAAA,QAM9D,IAAI0C,IAAA,GAAO8mB,WAAA,CAAY3qB,OAAZ,CAAoBurB,UAApB,CAAX,CAN8D;AAAA,QAO9D,IAAI1nB,IAAA,IAAQ,CAAC,CAAb,EAAgB;AAAA,YACdA,IAAA,GAAOynB,oBAAA,CAAqBC,UAArB,EAAiCZ,WAAjC,CAAP,CADc;AAAA,SAP8C;AAAA,QAU9D,MAAMznB,IAAA,GAAOyH,KAAA,CAAMoC,OAAA,CAAQmrB,WAAR,EAAsBC,CAAAA,OAAtB,EAAN,CAAb,CAV8D;AAAA,QAW9D,MAAMt5B,CAAA,GAAI;AAAA,YACRyO,EAAA,EAAIP,OAAA,CAAQqrB,KAAR,EADI;AAAA,YAER1qB,UAAA,EAAYA,UAFJ;AAAA,YAGRxK,IAAA,EAAMA,IAHE;AAAA,SAAV,CAX8D;AAAA,QAgB9D,MAAM8J,YAAA,GAAekd,OAAA,CAAQlnB,GAAR,CAAY,qBAAZ,CAAA,CAAmC+J,OAAA,CAAQqrB,KAAR,EAAnC,CAArB,CAhB8D;AAAA,QAiB9D,IAAIC,YAAA,GAAe,CAAC,CAApB,CAjB8D;AAAA,QAkB9D,IAAIC,qBAAJ,CAlB8D;AAAA,QAmB9D,KAAK,IAAI75B,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAK7B,MAAA,CAAOjnB,MAAvB,EAA+BP,CAAA,GAAIqpB,EAAxC,EAA4C,EAAErpB,CAA9C,EAAiD;AAAA,YAC/C,MAAM85B,SAAA,GAAYtS,MAAA,CAAOxnB,CAAP,CAAlB,CAD+C;AAAA,YAE/C,MAAMqnB,KAAA,GAAQyS,SAAA,CAAUzS,KAAxB,CAF+C;AAAA,YAG/C,MAAM8O,OAAA,GAAU9O,KAAA,CAAMxY,EAAtB,CAH+C;AAAA,YAI/C,IAAI0qB,SAAA,KAAc72B,SAAd,IAA2B62B,SAAA,KAAcpD,OAA7C,EAAsD;AAAA,gBACpD,SADoD;AAAA,aAJP;AAAA,YAQ/C,MAAM4D,MAAA,GAAS1S,KAAA,CAAM0S,MAAN,IAAgBlE,UAA/B,CAR+C;AAAA,YAS/C,MAAMmE,KAAA,GAAQ3S,KAAA,CAAM2S,KAAN,IAAenE,UAA7B,CAT+C;AAAA,YAU/C,IACEkE,MAAA,CAAOE,UAAP,KAAsB,MAAtB,IACC,SAAA,IAAa5S,KAAb,IAAsBjiB,IAAA,GAAOiiB,KAAA,CAAM6S,OADpC,IAEC,SAAA,IAAa7S,KAAb,IAAsBjiB,IAAA,IAAQiiB,KAAA,CAAM8S,OAHvC,EAIE;AAAA,gBACA,SADA;AAAA,aAd6C;AAAA,YAiB/C,MAAMhqB,MAAA,GAASkX,KAAA,CAAMlX,MAArB,CAjB+C;AAAA,YAkB/C,IAAI,CAACA,MAAD,IAAWwmB,cAAA,CAAeR,OAAf,EAAwBhmB,MAAxB,EAAgC/P,CAAhC,EAAmCgF,IAAnC,EAAyC2mB,WAAzC,CAAf,EAAsE;AAAA,gBACpE8N,qBAAA,GAAwBxS,KAAxB,CADoE;AAAA,gBAEpE,IAAIpN,KAAJ,EAAW+c,OAAX,EAAoBlF,IAApB,EAA0BsI,MAA1B,EAAkCC,WAAlC,EAA+CtZ,KAA/C,CAFoE;AAAA,gBAGpE,MAAMhK,KAAA,GAAQ+iB,SAAA,CAAU/iB,KAAxB,CAHoE;AAAA,gBAIpE,IACEtS,IAAA,IAAQ,CAAR,KACC4iB,KAAA,CAAM5iB,IAAN,IAAc,MAAd,IAAwB4iB,KAAA,CAAM5iB,IAAN,IAAc,gBAAtC,CAFH,EAGE;AAAA,oBACAuyB,OAAA,GAAUf,QAAA,CACR5O,KADQ,EAER,OAFQ,EAGRA,KAAA,CAAM5iB,IAAN,GAAa,UAHL,EAIRW,IAJQ,EAKRhF,CALQ,EAMRwrB,aANQ,EAORrd,YAPQ,CAAV,CADA;AAAA,oBAUA,IAAI8Y,KAAA,CAAM5iB,IAAN,GAAa,UAAb,IAA2Bu1B,KAA/B,EAAsC;AAAA,wBACpC,MAAMM,QAAA,GAAWrE,QAAA,CACf5O,KADe,EAEf,OAFe,EAGfA,KAAA,CAAM5iB,IAAN,GAAa,UAHE,EAIfW,IAJe,EAKfhF,CALe,EAMfwrB,aANe,EAOfrd,YAPe,CAAjB,CADoC;AAAA,wBAUpC,IAAI+rB,QAAJ,EAAc;AAAA,4BACZ,MAAMC,IAAA,GACJ,OAAOD,QAAP,KAAoB,QAApB,GACIpD,YAAA,CAAaoD,QAAb,EAAuBrrB,UAAvB,CADJ,GAEIqrB,QAAA,CAAS13B,QAAT,EAHN,CADY;AAAA,4BAKZ,IAAIkuB,WAAA,IAAe2G,UAAf,IAA6BA,UAAA,CAAW8C,IAAX,CAAjC,EAAmD;AAAA,gCACjD,EAAEX,YAAF,CADiD;AAAA,gCAEjD7Y,KAAA,GAAQsY,MAAA,CAAOO,YAAP,CAAR,CAFiD;AAAA,gCAGjD,IACE,CAAC7Y,KAAD,IACA,CAACA,KAAA,CAAMyZ,OAAN,EADD,IAEAzZ,KAAA,CAAM0Z,SAAN,EAFA,IAGA1Z,KAAA,CAAM2Z,OAAN,EAJF,EAKE;AAAA,oCACA3Z,KAAA,GAAQ,IAAI4Z,KAAJ,CAAU,EAChB7I,IAAA,EAAM,IAAIsH,IAAJ,EADU,EAAV,CAAR,CADA;AAAA,oCAIAC,MAAA,CAAOO,YAAP,CAAA,GAAuB7Y,KAAvB,CAJA;AAAA,iCAR+C;AAAA,gCAcjD+Q,IAAA,GAAO/Q,KAAA,CAAMyZ,OAAN,EAAP,CAdiD;AAAA,gCAejDzZ,KAAA,CAAM6Z,SAAN,CAAgB7jB,KAAhB,CAfiD,CAAA;AAAA,gCAgBjD,MAAM8jB,cAAA,GAAiBN,IAAA,GAAO,GAAP,GAAavD,OAApC,CAhBiD;AAAA,gCAiBjD,IAAI8D,OAAA,GAAUjC,YAAA,CAAagC,cAAb,CAAd,CAjBiD;AAAA,gCAkBjD,IAAI,CAACC,OAAL,EAAc;AAAA,oCACZ,MAAM/J,eAAA,GAAkB0G,UAAA,CAAW8C,IAAX,CAAxB,CADY;AAAA,oCAEZ,MAAM7N,MAAA,GAASN,YAAA,CACb2E,eAAA,CAAgB1E,KADH,EAEb0E,eAAA,CAAgBzE,MAFH,CAAf,CAFY;AAAA,oCAMZ,MAAM5f,GAAA,GACJggB,MAAA,CAAO4E,UAAP,CAAkB,IAAlB,CADF,CANY;AAAA,oCASZ5kB,GAAA,CAAIquB,WAAJ,GAAkB/D,OAAlB,CATY;AAAA,oCAUZtqB,GAAA,CAAI6kB,SAAJ,CACET,WADF,EAEEC,eAAA,CAAgB3hB,CAFlB,EAGE2hB,eAAA,CAAgB1hB,CAHlB,EAIE0hB,eAAA,CAAgB1E,KAJlB,EAKE0E,eAAA,CAAgBzE,MALlB,EAME,CANF,EAOE,CAPF,EAQEyE,eAAA,CAAgB1E,KARlB,EASE0E,eAAA,CAAgBzE,MATlB,CAVY,CAAA;AAAA,oCAqBZwO,OAAA,GAAUpuB,GAAA,CAAIsuB,aAAJ,CAAkBtO,MAAlB,EAA0B,QAA1B,CAAV,CArBY;AAAA,oCAsBZmM,YAAA,CAAagC,cAAb,CAAA,GAA+BC,OAA/B,CAtBY;AAAA,iCAlBmC;AAAA,gCA0CjDhJ,IAAA,CAAKmJ,QAAL,CAAcH,OAAd,CA1CiD,CAAA;AAAA,6BALvC;AAAA,yBAVsB;AAAA,qBAAtC,MA4DO;AAAA,wBACL7gB,KAAA,GAAQ8c,gBAAA,CACNd,QAAA,CACE5O,KADF,EAEE,OAFF,EAGEA,KAAA,CAAM5iB,IAAN,GAAa,QAHf,EAIEW,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADM,EAUNyoB,OAVM,CAAR,CADK;AAAA,wBAaL,IAAI3P,KAAA,CAAM5iB,IAAN,GAAa,gBAAb,IAAiCu1B,KAArC,EAA4C;AAAA,4BAC1CK,WAAA,GAActD,gBAAA,CACZd,QAAA,CACE5O,KADF,EAEE,OAFF,EAGEA,KAAA,CAAM5iB,IAAN,GAAa,gBAHf,EAIEW,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADY,EAUZyoB,OAVY,CAAd,CAD0C;AAAA,yBAbvC;AAAA,wBA2BL,IAAI,CAACqD,WAAL,EAAkB;AAAA,4BAChBA,WAAA,GAAcpgB,KAAd,CADgB;AAAA,yBA3Bb;AAAA,wBA8BL,IAAIA,KAAA,IAASogB,WAAb,EAA0B;AAAA,4BACxB,EAAET,YAAF,CADwB;AAAA,4BAExB7Y,KAAA,GAAQsY,MAAA,CAAOO,YAAP,CAAR,CAFwB;AAAA,4BAGxB,IACE,CAAC7Y,KAAD,IACC9G,KAAA,IAAS,CAAC8G,KAAA,CAAMyZ,OAAN,EADX,IAEC,CAACvgB,KAAD,IAAU8G,KAAA,CAAMyZ,OAAN,EAFX,IAGCH,WAAA,IAAe,CAACtZ,KAAA,CAAM0Z,SAAN,EAHjB,IAIC,CAACJ,WAAD,IAAgBtZ,KAAA,CAAM0Z,SAAN,EAJjB,IAKA1Z,KAAA,CAAM2Z,OAAN,EANF,EAOE;AAAA,gCACA3Z,KAAA,GAAQ,IAAI4Z,KAAJ,CAAU;AAAA,oCAChB7I,IAAA,EAAM7X,KAAA,GAAQ,IAAImf,IAAJ,EAAR,GAAqB12B,SADX;AAAA,oCAEhB03B,MAAA,EAAQC,WAAA,GAAc,IAAIlB,MAAJ,EAAd,GAA6Bz2B,SAFrB;AAAA,iCAAV,CAAR,CADA;AAAA,gCAKA22B,MAAA,CAAOO,YAAP,CAAA,GAAuB7Y,KAAvB,CALA;AAAA,6BAVsB;AAAA,4BAiBxB,IAAI9G,KAAJ,EAAW;AAAA,gCACT6X,IAAA,GAAO/Q,KAAA,CAAMyZ,OAAN,EAAP,CADS;AAAA,gCAET1I,IAAA,CAAKmJ,QAAL,CAAchhB,KAAd,CAFS,CAAA;AAAA,6BAjBa;AAAA,4BAqBxB,IAAIogB,WAAJ,EAAiB;AAAA,gCACfD,MAAA,GAASrZ,KAAA,CAAM0Z,SAAN,EAAT,CADe;AAAA,gCAEfL,MAAA,CAAOa,QAAP,CAAgBZ,WAAhB,CAFe,CAAA;AAAA,gCAGfD,MAAA,CAAOc,QAAP,CAAgB,GAAhB,CAHe,CAAA;AAAA,6BArBO;AAAA,4BA0BxBna,KAAA,CAAM6Z,SAAN,CAAgB7jB,KAAhB,CA1BwB,CAAA;AAAA,yBA9BrB;AAAA,qBAtEP;AAAA,iBAPkE;AAAA,gBAyIpE,IAAItS,IAAA,IAAQ,CAAR,IAAa4iB,KAAA,CAAM5iB,IAAN,IAAc,MAA/B,EAAuC;AAAA,oBACrC,IAAI,EAAoBu1B,cAAAA,IAAAA,KAAlB,CAAN,EAAgC;AAAA,wBAC9B/f,KAAA,GAAQ8c,gBAAA,CACNd,QAAA,CACE5O,KADF,EAEE,OAFF,EAGE,YAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADM,EAUN0nB,QAAA,CACE5O,KADF,EAEE,OAFF,EAGE,cAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CAVM,CAAR,CAD8B;AAAA,qBAAhC,MAqBO;AAAA,wBACL0L,KAAA,GAAQvX,SAAR,CADK;AAAA,qBAtB8B;AAAA,oBAyBrC,MAAM2pB,KAAA,GAAQ4J,QAAA,CACZ5O,KADY,EAEZ,OAFY,EAGZ,YAHY,EAIZjiB,IAJY,EAKZhF,CALY,EAMZwrB,aANY,EAOZrd,YAPY,CAAd,CAzBqC;AAAA,oBAkCrC,IAAI0L,KAAA,IAASoS,KAAA,GAAQ,CAArB,EAAwB;AAAA,wBACtB,EAAEuN,YAAF,CADsB;AAAA,wBAEtB7Y,KAAA,GAAQsY,MAAA,CAAOO,YAAP,CAAR,CAFsB;AAAA,wBAGtB,IACE,CAAC7Y,KAAD,IACA,CAACA,KAAA,CAAM0Z,SAAN,EADD,IAEA1Z,KAAA,CAAMyZ,OAAN,EAFA,IAGAzZ,KAAA,CAAM2Z,OAAN,EAJF,EAKE;AAAA,4BACA3Z,KAAA,GAAQ,IAAI4Z,KAAJ,CAAU,EAChBP,MAAA,EAAQ,IAAIjB,MAAJ,EADQ,EAAV,CAAR,CADA;AAAA,4BAIAE,MAAA,CAAOO,YAAP,CAAA,GAAuB7Y,KAAvB,CAJA;AAAA,yBARoB;AAAA,wBActBqZ,MAAA,GAASrZ,KAAA,CAAM0Z,SAAN,EAAT,CAdsB;AAAA,wBAetBL,MAAA,CAAOe,UAAP,CACElF,QAAA,CACE5O,KADF,EAEE,QAFF,EAGE,UAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADF,CAfsB,CAAA;AAAA,wBA0BtB6rB,MAAA,CAAOgB,WAAP,CACEnF,QAAA,CACE5O,KADF,EAEE,QAFF,EAGE,WAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADF,CA1BsB,CAAA;AAAA,wBAqCtB6rB,MAAA,CAAOiB,aAAP,CACEpF,QAAA,CACE5O,KADF,EAEE,QAFF,EAGE,kBAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADF,CArCsB,CAAA;AAAA,wBAgDtB6rB,MAAA,CAAOa,QAAP,CAAgBhhB,KAAhB,CAhDsB,CAAA;AAAA,wBAiDtBmgB,MAAA,CAAOc,QAAP,CAAgB7O,KAAhB,CAjDsB,CAAA;AAAA,wBAkDtB+N,MAAA,CAAOkB,WAAP,CACEtB,KAAA,CAAM,gBAAN,CAAA,GACI/D,QAAA,CACE5O,KADF,EAEE,OAFF,EAGE,gBAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CAAA,CAQEvK,GARF,CAQM,UAAUoL,CAAV,EAAa;AAAA,4BACjB,OAAOA,CAAA,GAAIid,KAAX,CADiB;AAAA,yBARnB,CADJ,GAYI,IAbN,CAlDsB,CAAA;AAAA,wBAiEtBtL,KAAA,CAAM6Z,SAAN,CAAgB7jB,KAAhB,CAjEsB,CAAA;AAAA,qBAlCa;AAAA,iBAzI6B;AAAA,gBAgPpE,IAAIwkB,QAAA,GAAW,KAAf,CAhPoE;AAAA,gBAiPpE,IAAI1xB,IAAA,GAAO,IAAX,CAjPoE;AAAA,gBAkPpE,IAAI2xB,cAAA,GAAiB,CAArB,CAlPoE;AAAA,gBAmPpE,IAAIjB,IAAJ,EAAUkB,OAAV,EAAmBC,SAAnB,CAnPoE;AAAA,gBAoPpE,IAAK,CAAAj3B,IAAA,IAAQ,CAAR,IAAaA,IAAA,IAAQ,CAArB,KAA2B,YAAA,IAAgBs1B,MAAhD,EAAwD;AAAA,oBACtD,MAAM4B,SAAA,GAAY1F,QAAA,CAChB5O,KADgB,EAEhB,QAFgB,EAGhB,YAHgB,EAIhBjiB,IAJgB,EAKhBhF,CALgB,EAMhBwrB,aANgB,EAOhBrd,YAPgB,CAAlB,CADsD;AAAA,oBAUtD,IAAIotB,SAAJ,EAAe;AAAA,wBACbpB,IAAA,GACE,OAAOoB,SAAP,KAAqB,QAArB,GACIzE,YAAA,CAAayE,SAAb,EAAwB1sB,UAAxB,CADJ,GAEI0sB,SAAA,CAAU/4B,QAAV,EAHN,CADa;AAAA,wBAKb,IAAIg5B,SAAA,GAAYl5B,SAAhB,CALa;AAAA,wBAMb,MAAMm5B,YAAA,GAAe5L,QAAA,GAAWA,QAAA,CAASxE,OAAT,EAAkB8O,IAAlB,CAAX,GAAqC73B,SAA1D,CANa;AAAA,wBAOb,IACGouB,WAAA,IAAe2G,UAAf,IAA6BA,UAAA,CAAW8C,IAAX,CAA9B,IACAsB,YAFF,EAGE;AAAA,4BACA,MAAMC,qBAAA,GAAwB7F,QAAA,CAC5B5O,KAD4B,EAE5B,QAF4B,EAG5B,yBAH4B,EAI5BjiB,IAJ4B,EAK5BhF,CAL4B,EAM5BwrB,aAN4B,EAO5Brd,YAP4B,CAA9B,CADA;AAAA,4BAUA,IAAI9J,IAAA,IAAQ,CAAZ,EAAe;AAAA,gCACb,MAAMs3B,IAAA,GAAyBztB,OAAA,CAAQmrB,WAAR,EAA/B,CADa;AAAA;AAGb,gCAAA,IAAIsC,IAAA,CAAKC,eAAL,IAAwBD,IAAA,CAAKE,gBAAjC,EAAmD;AAAA,oCACjD,MAAM5M,MAAA,GAAS0M,IAAA,CAAKG,SAAL,EAAf,CADiD;AAAA,oCAEjD,MAAMpT,IAAA,GAAO7oB,IAAA,CAAKqb,IAAL,CACXrb,IAAA,CAAKsR,GAAL,CACEtR,IAAA,CAAKoS,GAAL,CAAU,CAAAgd,MAAA,CAAO,CAAP,IAAYA,MAAA,CAAO,CAAP,CAAZ,IAAyBvC,UAAnC,EAA+C,CAA/C,CADF,EAEE7sB,IAAA,CAAKoS,GAAL,CAAU,CAAAgd,MAAA,CAAO,CAAP,CAAA,GAAYA,MAAA,CAAO,CAAP,CAAZ,IAAyBvC,UAAnC,EAA+C,CAA/C,CAFF,CADW,CAAb,CAFiD;AAAA,oCAQjD,IAAIhE,IAAA,GAAO,GAAX,EAAgB;AAAA;AAEd,wCAAA,MAAMqT,QAAA,GACJJ,IAAA,CAAKrC,OAAL,OAAmB,iBAAnB,GACIqC,IAAA,CAAKE,gBAAL,EADJ,GAEIF,IAAA,CAAKC,eAAL,EAHN,CAFc;AAAA,wCAMd,IAAI,CAAChG,aAAL,EAAoB;AAAA,4CAClBD,wBAAA,GAA2B;AAAA,gDAACqG,GAAD;AAAA,gDAAMA,GAAN;AAAA,6CAA3B,CADkB;AAAA,4CAElBpG,aAAA,GAAgB,IAAIqG,aAAJ,CACd,OADc,EAEdtG,wBAFc,EAGd,EAHc,EAId,CAJc,EAKd,EALc,EAMdrzB,SANc,CAAhB,CAFkB;AAAA,yCANN;AAAA,wCAiBdk5B,SAAA,GAAY5F,aAAZ,CAjBc;AAAA,wCAkBdD,wBAAA,CAAyB,CAAzB,CAAA,GAA8BoG,QAAA,CAAS,CAAT,CAA9B,CAlBc;AAAA,wCAmBdpG,wBAAA,CAAyB,CAAzB,CAAA,GAA8BoG,QAAA,CAAS,CAAT,CAA9B,CAnBc;AAAA,wCAoBd,MAAMG,SAAA,GAAYrG,QAAA,CAChB5O,KADgB,EAEhB,QAFgB,EAGhB,kBAHgB,EAIhBjiB,IAJgB,EAKhBhF,CALgB,EAMhBwrB,aANgB,EAOhBrd,YAPgB,CAAlB,CApBc;AAAA,wCA6Bd,IACE+tB,SAAA,KAAc,MAAd,IACAR,qBAAA,KAA0B,KAF5B,EAGE;AAAA,4CACA,MAAMS,MAAA,GAASR,IAAA,CAAKS,SAAL,EAAf,CADA;AAAA,4CAEA,MAAM5nB,WAAA,GAAcmnB,IAAA,CAAKU,kBAAL,EAApB,CAFA;AAAA,4CAGA,KACE,IAAIz8B,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAKzU,WAAA,CAAYrU,MAAZ,GAAqBg8B,MAArC,EACAv8B,CAAA,GAAIqpB,EAFN,EAGErpB,CAAA,IAAKu8B,MAHP,EAIE;AAAA,gDACA,MAAM9pB,EAAA,GAAKmC,WAAA,CAAY5U,CAAZ,CAAX,CADA;AAAA,gDAEA,MAAM0S,EAAA,GAAKkC,WAAA,CAAY5U,CAAA,GAAI,CAAhB,CAAX,CAFA;AAAA,gDAGA,MAAM2S,EAAA,GAAKiC,WAAA,CAAY5U,CAAA,GAAIu8B,MAAhB,CAAX,CAHA;AAAA,gDAIA,MAAM3pB,EAAA,GAAKgC,WAAA,CAAY5U,CAAA,GAAIu8B,MAAJ,GAAa,CAAzB,CAAX,CAJA;AAAA,gDAKA,MAAMG,IAAA,GAAOz8B,IAAA,CAAKqR,GAAL,CAASmB,EAAT,EAAaE,EAAb,CAAb,CALA;AAAA,gDAMA,MAAMgqB,IAAA,GAAO18B,IAAA,CAAKsR,GAAL,CAASkB,EAAT,EAAaE,EAAb,CAAb,CANA;AAAA,gDAOA,MAAMiqB,EAAA,GAAKT,QAAA,CAAS,CAAT,CAAX,CAPA;AAAA,gDAQA,MAAMU,EAAA,GAAKV,QAAA,CAAS,CAAT,CAAX,CARA;AAAA,gDASA,MAAMW,UAAA,GACH,CAAAlqB,EAAA,GAAKF,EAAL,KAAYkqB,EAAA,GAAKnqB,EAAL,CAAb,GAAyB,CAAAE,EAAA,GAAKF,EAAL,KAAYoqB,EAAA,GAAKnqB,EAAL,CADvC,CATA;AAAA,gDAWA,IACEzS,IAAA,CAAK6Z,GAAL,CAASgjB,UAAT,CAAA,GAAuB,KAAvB;AACA,oDAAAF,EAAA,IAAMD,IADN,IAEAC,EAAA,IAAMF,IAAAA;AAHR,EAIE;AAAA,oDACAlB,cAAA,GAAiBv7B,IAAA,CAAKob,KAAL,CAAW3I,EAAA,GAAKE,EAAhB,EAAoBD,EAAA,GAAKF,EAAzB,CAAjB,CADA;AAAA,oDAEA,MAFA;AAAA,iDAfF;AAAA,6CAPF;AAAA,yCAhCY;AAAA,qCARiC;AAAA,iCAHtC;AAAA,6BAVf;AAAA,4BAoFA,IAAIhO,IAAA,KAAS,CAAT,IAAcm3B,SAAlB,EAA6B;AAAA,gCAC3B,MAAMmB,QAAA,GAAW9G,QAAA,CACf5O,KADe,EAEf,QAFe,EAGf,WAHe,EAIfjiB,IAJe,EAKfhF,CALe,EAMfwrB,aANe,EAOfrd,YAPe,CAAjB,CAD2B;AAAA,gCAU3B,MAAMyuB,SAAA,GACJhD,KAAA,CAAM,YAAN,CAAA,KAAwBt3B,SAAxB,GACIuzB,QAAA,CACE5O,KADF,EAEE,OAFF,EAGE,YAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADJ,GAUI,IAXN,CAV2B;AAAA,gCAsB3B,IAAI,CAACyuB,SAAD,IAAcA,SAAA,CAAUz6B,CAAV,KAAgB,CAAlC,EAAqC;AAAA,oCACnC,MAAM0uB,SAAA,GAAYgF,QAAA,CAChB5O,KADgB,EAEhB,OAFgB,EAGhB,iBAHgB,EAIhBjiB,IAJgB,EAKhBhF,CALgB,EAMhBwrB,aANgB,EAOhBrd,YAPgB,CAAlB,CADmC;AAAA,oCAUnC,MAAMyiB,SAAA,GAAYiF,QAAA,CAChB5O,KADgB,EAEhB,OAFgB,EAGhB,iBAHgB,EAIhBjiB,IAJgB,EAKhBhF,CALgB,EAMhBwrB,aANgB,EAOhBrd,YAPgB,CAAlB,CAVmC;AAAA,oCAmBnC,IAAI0uB,YAAA,GAAe,IAAG1C,IAAH,EAAQ,CAAR,GAAWwC,QAAX,EAAoB,CAApB,GAAuB/L,SAAvB,EAAiC,CAAjC,GAAoCC,SAApC,GAAnB,CAnBmC;AAAA,oCAoBnC,IAAI+L,SAAA,KAAc,IAAlB,EAAwB;AAAA,wCACtBC,YAAA,IAAgB,CAAC,CAAD,GAAID,SAAJ,GAAhB,CADsB;AAAA,qCApBW;AAAA,oCAuBnCvB,OAAA,GAAU7C,cAAA,CAAeqE,YAAf,CAAV,CAvBmC;AAAA,oCAwBnC,IAAI,CAACxB,OAAL,EAAc;AAAA,wCACZ,MAAMyB,aAAA,GAAgB3G,gBAAA,CACpBlP,KADoB,EAEpBjiB,IAFoB,EAGpBhF,CAHoB,EAIpB,MAJoB,EAKpBwrB,aALoB,CAAtB,CADY;AAAA,wCAQZ,IAAIuR,YAAJ,CARY;AAAA,wCASZ,IAAI,aAAiBpD,IAAAA,MAArB,EAA6B;AAAA,4CAC3BoD,YAAA,GAAelH,QAAA,CACb5O,KADa,EAEb,QAFa,EAGb,aAHa,EAIbjiB,IAJa,EAKbhF,CALa,EAMbwrB,aANa,EAObrd,YAPa,EAQbpN,KARa,CAQP,CARO,CAAf,CAD2B;AAAA,4CAU3Bg8B,YAAA,CAAa,CAAb,CAAA,IAAmBJ,QAAnB,CAV2B;AAAA,4CAW3BI,YAAA,CAAa,CAAb,CAAmB,IAAA,CAACJ,QAApB,CAX2B;AAAA,yCATjB;AAAA,wCAsBZ,IAAI9iB,KAAA,GAAQ+iB,SAAA,GACR;AAAA,4CACEA,SAAA,CAAU56B,CAAV,GAAc,GADhB;AAAA,4CAEE46B,SAAA,CAAU36B,CAAV,GAAc,GAFhB;AAAA,4CAGE26B,SAAA,CAAU16B,CAAV,GAAc,GAHhB;AAAA,4CAIE06B,SAAA,CAAUz6B,CAJZ;AAAA,yCADQ,GAORG,SAPJ,CAtBY;AAAA,wCA8BZ,IAAIm5B,YAAJ,EAAkB;AAAA,4CAChB,MAAMuB,WAAA,GAAc;AAAA,gDAClBnjB,KAAA,EAAOA,KADW;AAAA,gDAElBojB,cAAA,EAAgBvB,qBAAA,KAA0B,KAFxB;AAAA,gDAGlBqB,YAAA,EAAcA,YAHI;AAAA,gDAIlBD,aAAA,EAAeA,aAJG;AAAA,gDAKlBnzB,KAAA,EAAOgzB,QALW;AAAA,6CAApB,CADgB;AAAA,4CAQhB,IAAI,OAAOlB,YAAP,KAAwB,QAA5B,EAAsC;AAAA;AAEpC,gDAAAuB,WAAA,CAAYlO,GAAZ,GAAkB2M,YAAlB,CAFoC;AAAA,6CAAtC,MAGO;AAAA,gDACLuB,WAAA,CAAYpN,GAAZ,GAAkB6L,YAAlB,CADK;AAAA,gDAELuB,WAAA,CAAYlM,OAAZ,GAAsB;AAAA,oDACpB2K,YAAA,CAAaxP,KADO;AAAA,oDAEpBwP,YAAA,CAAavP,MAFO;AAAA,iDAAtB,CAFK;AAAA,6CAXS;AAAA,4CAkBhBmP,OAAA,GAAU,IAAI6B,IAAJ,CAASF,WAAT,CAAV,CAlBgB;AAAA,yCAAlB,MAmBO;AAAA,4CACL,MAAMrM,eAAA,GAAkB0G,UAAA,CAAW8C,IAAX,CAAxB,CADK;AAAA,4CAEL,IAAIvK,GAAJ,EAASlH,IAAT,EAAeyU,MAAf,CAFK;AAAA,4CAGL,IAAIvM,SAAJ,EAAe;AAAA,gDACb,IAAID,eAAA,CAAgByM,GAApB,EAAyB;AAAA,oDACvBxN,GAAA,GAAMa,YAAA,CACJmB,OAAA,CACElB,WADF,EAEEC,eAFF,EAGEiM,SAAA,IAAa;AAAA,wDAAC,CAAD;AAAA,wDAAI,CAAJ;AAAA,wDAAO,CAAP;AAAA,wDAAU,CAAV;AAAA,qDAHf,CADI,EAMJ;AAAA,wDACE5tB,CAAA,EAAG,CADL;AAAA,wDAEEC,CAAA,EAAG,CAFL;AAAA,wDAGEgd,KAAA,EAAO0E,eAAA,CAAgB1E,KAHzB;AAAA,wDAIEC,MAAA,EAAQyE,eAAA,CAAgBzE,MAJ1B;AAAA,wDAKE6E,UAAA,EAAYJ,eAAA,CAAgBI,UAL9B;AAAA,qDANI,EAaJH,SAbI,EAcJC,SAdI,CAAN,CADuB;AAAA,oDAiBvBhX,KAAA,GAAQvX,SAAR,CAAA;AAjBuB,iDAAzB,MAkBO;AAAA,oDACLstB,GAAA,GAAMa,YAAA,CACJC,WADI,EAEJC,eAFI,EAGJC,SAHI,EAIJC,SAJI,CAAN,CADK;AAAA,iDAnBM;AAAA,6CAAf,MA2BO;AAAA,gDACL,IAAIF,eAAA,CAAgByM,GAApB,EAAyB;AAAA,oDACvB,IAAI,CAAC1F,kBAAL,EAAyB;AAAA,wDACvBA,kBAAA,GAAqB9F,OAAA,CACnBlB,WADmB,EAEnB;AAAA,4DACE1hB,CAAA,EAAG,CADL;AAAA,4DAEEC,CAAA,EAAG,CAFL;AAAA,4DAGEgd,KAAA,EAAOwL,eAAA,CAAgB,CAAhB,CAHT;AAAA,4DAIEvL,MAAA,EAAQuL,eAAA,CAAgB,CAAhB,CAJV;AAAA,yDAFmB,EAQnB;AAAA,4DAACz1B,CAAA,EAAG,CAAJ;AAAA,4DAAOC,CAAA,EAAG,CAAV;AAAA,4DAAaC,CAAA,EAAG,CAAhB;AAAA,4DAAmBC,CAAA,EAAG,CAAtB;AAAA,yDARmB,CAArB,CADuB;AAAA,qDADF;AAAA,oDAavBytB,GAAA,GAAM8H,kBAAN,CAbuB;AAAA,iDAAzB,MAcO;AAAA,oDACL9H,GAAA,GAAMc,WAAN,CADK;AAAA,iDAfF;AAAA,gDAkBLhI,IAAA,GAAO;AAAA,oDAACiI,eAAA,CAAgB1E,KAAjB;AAAA,oDAAwB0E,eAAA,CAAgBzE,MAAxC;AAAA,iDAAP,CAlBK;AAAA,gDAmBLiR,MAAA,GAAS;AAAA,oDAACxM,eAAA,CAAgB3hB,CAAjB;AAAA,oDAAoB2hB,eAAA,CAAgB1hB,CAApC;AAAA,iDAAT,CAnBK;AAAA,6CA9BF;AAAA,4CAmDLosB,OAAA,GAAU,IAAI6B,IAAJ,CAAS;AAAA,gDACjBrjB,KAAA,EAAOA,KADU;AAAA,gDAEjB+V,GAAA,EAAKA,GAFY;AAAA;AAIjB,gDAAAkB,OAAA,EAAS2G,eAJQ;AAAA,gDAKjB/O,IAAA,EAAMA,IALW;AAAA,gDAMjByU,MAAA,EAAQA,MANS;AAAA,gDAOjBF,cAAA,EAAgBvB,qBAAA,KAA0B,KAPzB;AAAA,gDAQjB/xB,KAAA,EAAOgzB,QAAA,GAAWhM,eAAA,CAAgBI,UARjB;AAAA,gDASjBgM,YAAA,EAAcA,YATG;AAAA,gDAUjBD,aAAA,EAAeA,aAVE;AAAA,6CAAT,CAAV,CAnDK;AAAA,yCAjDK;AAAA,wCAiHZtE,cAAA,CAAeqE,YAAf,CAAA,GAA+BxB,OAA/B,CAjHY;AAAA,qCAxBqB;AAAA,iCAtBV;AAAA,gCAkK3B,IAAIA,OAAJ,EAAa;AAAA,oCACX,EAAE7B,YAAF,CADW;AAAA,oCAEX7Y,KAAA,GAAQsY,MAAA,CAAOO,YAAP,CAAR,CAFW;AAAA,oCAGX,IACE,CAAC7Y,KAAD,IACA,CAACA,KAAA,CAAMkP,QAAN,EADD,IAEAlP,KAAA,CAAMyZ,OAAN,EAFA,IAGAzZ,KAAA,CAAM0Z,SAAN,EAJF,EAKE;AAAA,wCACA1Z,KAAA,GAAQ,IAAI4Z,KAAJ,EAAR,CADA;AAAA,wCAEAtB,MAAA,CAAOO,YAAP,CAAA,GAAuB7Y,KAAvB,CAFA;AAAA,qCARS;AAAA,oCAYXA,KAAA,CAAM0c,WAAN,CAAkB7B,SAAlB,CAZW,CAAA;AAAA,oCAaXH,OAAA,CAAQiC,WAAR,CACElC,cAAA,GACEhhB,OAAA,CACEyb,QAAA,CACE5O,KADF,EAEE,QAFF,EAGE,aAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADF,CAFJ,CAbW,CAAA;AAAA,oCA2BXktB,OAAA,CAAQkC,UAAR,CACE1H,QAAA,CACE5O,KADF,EAEE,OAFF,EAGE,cAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADF,CA3BW,CAAA;AAAA,oCAsCXktB,OAAA,CAAQmC,SAAR,CACEnI,MAAA,CACEQ,QAAA,CACE5O,KADF,EAEE,QAFF,EAGE,aAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADF,CADF,CAtCW,CAAA;AAAA,oCAmDXwS,KAAA,CAAM8c,QAAN,CAAepC,OAAf,CAnDW,CAAA;AAAA,oCAoDX5xB,IAAA,GAAOkX,KAAA,CAAM2Z,OAAN,EAAP,CApDW;AAAA,oCAqDX3Z,KAAA,CAAM+c,OAAN,CAAcp7B,SAAd,CArDW,CAAA;AAAA,oCAsDXqe,KAAA,CAAM6Z,SAAN,CAAgB7jB,KAAhB,CAtDW,CAAA;AAAA,oCAuDXwkB,QAAA,GAAW,IAAX,CAvDW;AAAA,oCAwDXG,SAAA,GAAY,KAAZ,CAxDW;AAAA,iCAlKc;AAAA,6BAA7B,MA4NO;AAAA,gCACLA,SAAA,GAAY,IAAZ,CADK;AAAA,6BAhTP;AAAA,yBAVW;AAAA,qBAVuC;AAAA,iBApPY;AAAA,gBA+jBpE,IAAIj3B,IAAA,IAAQ,CAAR,IAAa4iB,KAAA,CAAM5iB,IAAN,KAAe,QAAhC,EAA0C;AAAA,oBACxC,EAAEm1B,YAAF,CADwC;AAAA,oBAExC7Y,KAAA,GAAQsY,MAAA,CAAOO,YAAP,CAAR,CAFwC;AAAA,oBAGxC,IACE,CAAC7Y,KAAD,IACA,CAACA,KAAA,CAAMkP,QAAN,EADD,IAEAlP,KAAA,CAAMyZ,OAAN,EAFA,IAGAzZ,KAAA,CAAM0Z,SAAN,EAJF,EAKE;AAAA,wBACA1Z,KAAA,GAAQ,IAAI4Z,KAAJ,EAAR,CADA;AAAA,wBAEAtB,MAAA,CAAOO,YAAP,CAAA,GAAuB7Y,KAAvB,CAFA;AAAA,qBARsC;AAAA,oBAYxC,MAAMgd,YAAA,GACJ,eAAmB/D,IAAAA,KAAnB,GACI/D,QAAA,CACE5O,KADF,EAEE,OAFF,EAGE,eAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADJ,GAUI,CAXN,CAZwC;AAAA,oBAwBxC,MAAMyvB,iBAAA,GAAoBjH,gBAAA,CACxBd,QAAA,CACE5O,KADF,EAEE,OAFF,EAGE,qBAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADwB,EAUxB0nB,QAAA,CACE5O,KADF,EAEE,OAFF,EAGE,uBAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CAVwB,CAA1B,CAxBwC;AAAA,oBA6CxC,MAAM0vB,eAAA,GAAkBhI,QAAA,CACtB5O,KADsB,EAEtB,OAFsB,EAGtB,kBAHsB,EAItBjiB,IAJsB,EAKtBhF,CALsB,EAMtBwrB,aANsB,EAOtBrd,YAPsB,CAAxB,CA7CwC;AAAA,oBAsDxC,MAAM2vB,WAAA,GAAcnH,gBAAA,CAClBd,QAAA,CACE5O,KADF,EAEE,OAFF,EAGE,cAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADkB,EAUlB0nB,QAAA,CACE5O,KADF,EAEE,OAFF,EAGE,gBAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CAVkB,CAApB,CAtDwC;AAAA,oBA0ExC,MAAM4vB,iBAAA,GAAoBlI,QAAA,CACxB5O,KADwB,EAExB,OAFwB,EAGxB,qBAHwB,EAIxBjiB,IAJwB,EAKxBhF,CALwB,EAMxBwrB,aANwB,EAOxBrd,YAPwB,CAA1B,CA1EwC;AAAA,oBAmFxC,MAAM6vB,SAAA,GACJL,YAAA,GACA,GADA,GAEAC,iBAFA,GAGA,GAHA,GAIAE,WAJA,GAKA,GALA,GAMAC,iBANA,GAOA,GAPA,GAQAF,eAAA,CAAgB,CAAhB,CARA,GASA,GATA,GAUAA,eAAA,CAAgB,CAAhB,CAXF,CAnFwC;AAAA,oBAgGxCxC,OAAA,GAAU7C,cAAA,CAAewF,SAAf,CAAV,CAhGwC;AAAA,oBAiGxC,IAAI,CAAC3C,OAAL,EAAc;AAAA,wBACZA,OAAA,GAAU,IAAI4C,MAAJ,CAAW;AAAA,4BACnBC,MAAA,EAAQP,YADW;AAAA,4BAEnBZ,YAAA,EAAc;AAAA,gCAACc,eAAA,CAAgB,CAAhB,CAAD;AAAA,gCAAqB,CAACA,eAAA,CAAgB,CAAhB,CAAtB;AAAA,6BAFK;AAAA,4BAGnB7D,MAAA,EACE4D,iBAAA,IAAqBG,iBAAA,GAAoB,CAAzC,GACI,IAAIhF,MAAJ,CAAW;AAAA,gCACT9M,KAAA,EAAO8R,iBADE;AAAA,gCAETlkB,KAAA,EAAO+jB,iBAFE;AAAA,6BAAX,CADJ,GAKIt7B,SATa;AAAA,4BAUnBovB,IAAA,EAAMoM,WAAA,GACF,IAAI9E,IAAJ,CAAS,EACPnf,KAAA,EAAOikB,WADA,EAAT,CADE,GAIFx7B,SAde;AAAA,4BAenBw6B,aAAA,EAAe,MAfI;AAAA,yBAAX,CAAV,CADY;AAAA,wBAkBZtE,cAAA,CAAewF,SAAf,CAAA,GAA4B3C,OAA5B,CAlBY;AAAA,qBAjG0B;AAAA,oBAqHxC1a,KAAA,CAAM8c,QAAN,CAAepC,OAAf,CArHwC,CAAA;AAAA,oBAsHxC5xB,IAAA,GAAOkX,KAAA,CAAM2Z,OAAN,EAAP,CAtHwC;AAAA,oBAuHxC3Z,KAAA,CAAM+c,OAAN,CAAcp7B,SAAd,CAvHwC,CAAA;AAAA,oBAwHxCqe,KAAA,CAAM0c,WAAN,CAAkB/6B,SAAlB,CAxHwC,CAAA;AAAA,oBAyHxCqe,KAAA,CAAM6Z,SAAN,CAAgB7jB,KAAhB,CAzHwC,CAAA;AAAA,oBA0HxCwkB,QAAA,GAAW,IAAX,CA1HwC;AAAA,iBA/jB0B;AAAA,gBA4rBpE,IAAIpjB,KAAJ,EAAWjL,IAAX,EAAiBqxB,cAAjB,EAAiCC,QAAjC,EAA2CjM,aAA3C,EAA0DkM,YAA1D,CA5rBoE;AAAA,gBA6rBpE,IAAI,YAAgB1E,IAAAA,MAApB,EAA4B;AAAA,oBAC1ByE,QAAA,GAAWv+B,IAAA,CAAKC,KAAL,CACT+1B,QAAA,CACE5O,KADF,EAEE,QAFF,EAGE,WAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADS,CAAX,CAD0B;AAAA,oBAY1B,MAAMmwB,SAAA,GAAYzI,QAAA,CAChB5O,KADgB,EAEhB,QAFgB,EAGhB,WAHgB,EAIhBjiB,IAJgB,EAKhBhF,CALgB,EAMhBwrB,aANgB,EAOhBrd,YAPgB,CAAlB,CAZ0B;AAAA,oBAqB1BgwB,cAAA,GAAiBtI,QAAA,CACf5O,KADe,EAEf,QAFe,EAGf,kBAHe,EAIfjiB,IAJe,EAKfhF,CALe,EAMfwrB,aANe,EAOfrd,YAPe,CAAjB,CArB0B;AAAA,oBA8B1BrB,IAAA,GAAO6nB,MAAA,CACLL,QAAA,GACIA,QAAA,CACEgK,SADF,EAEEnT,OAAA,CAAQ+B,QAAR,GACI/B,OAAA,CAAQ+B,QAAR,CAAiB,aAAjB,CADJ,GAEI5qB,SAJN,CADJ,GAOIg8B,SARC,EASLF,QATK,EAULD,cAVK,CAAP,CA9B0B;AAAA,oBA0C1B,IAAI,CAACrxB,IAAA,CAAKyxB,QAAL,CAAc,YAAd,CAAL,EAAkC;AAAA,wBAChCzxB,IAAA,IAAQ,aAAR,CADgC;AAAA,qBA1CR;AAAA,oBA6C1BqlB,aAAA,GAAgB0D,QAAA,CACd5O,KADc,EAEd,QAFc,EAGd,qBAHc,EAIdjiB,IAJc,EAKdhF,CALc,EAMdwrB,aANc,EAOdrd,YAPc,CAAhB,CA7C0B;AAAA,oBAsD1BkwB,YAAA,GAAexI,QAAA,CACb5O,KADa,EAEb,QAFa,EAGb,gBAHa,EAIbjiB,IAJa,EAKbhF,CALa,EAMbwrB,aANa,EAObrd,YAPa,CAAf,CAtD0B;AAAA,oBA+D1B,MAAMqwB,SAAA,GAAY3I,QAAA,CAChB5O,KADgB,EAEhB,QAFgB,EAGhB,YAHgB,EAIhBjiB,IAJgB,EAKhBhF,CALgB,EAMhBwrB,aANgB,EAOhBrd,YAPgB,CAAlB,CA/D0B;AAAA,oBAwE1B,IAAI,OAAOqwB,SAAP,KAAqB,QAArB,IAAiCA,SAAA,CAAUx0B,QAA/C,EAAyD;AAAA,wBACvD,IAAIw0B,SAAA,CAAUx0B,QAAV,CAAmB7J,MAAnB,KAA8B,CAAlC,EAAqC;AAAA,4BACnC4X,KAAA,GAAQymB,SAAA,CAAUh8B,QAAV,EAAR,CADmC;AAAA,yBAArC,MAEO;AAAA,4BACLuV,KAAA,GAAQymB,SAAA,CAAUx0B,QAAV,CAAmBy0B,MAAnB,CAA0B,CAACC,GAAD,EAAMC,KAAN,EAAa/+B,CAAb,KAAmB;AAAA,gCACnD,MAAM6oB,KAAA,GAAQkW,KAAA,CAAM/0B,SAAN,GACV+0B,KAAA,CAAM/0B,SAAN,CAAgBrI,KAAhB,CAAsB,GAAtB,CADU,GAEV+8B,SAFJ,CADmD;AAAA,gCAInD,MAAMM,SAAA,GAAYjK,MAAA,CAChBL,QAAA,GAAWA,QAAA,CAAS7L,KAAT,CAAX,GAA6BA,KADb,EAEhB2V,QAAA,IAAYO,KAAA,CAAMh1B,KAAN,IAAe,CAAf,CAFI,EAGhBw0B,cAHgB,CAAlB,CAJmD;AAAA,gCASnD,IAAI10B,IAAA,GAAOk1B,KAAA,CAAMl1B,IAAjB,CATmD;AAAA,gCAUnD,IAAIA,IAAA,KAAS,IAAb,EAAmB;AAAA,oCACjBi1B,GAAA,CAAIz5B,IAAJ,CAAS,IAAT,EAAe,EAAf,CADiB,CAAA;AAAA,oCAEjB,OAAOy5B,GAAP,CAFiB;AAAA,iCAVgC;AAAA,gCAcnD,IAAIr6B,IAAA,IAAQ,CAAZ,EAAe;AAAA,oCACbq6B,GAAA,CAAIz5B,IAAJ,CAASitB,kBAAA,CAAmBzoB,IAAnB,EAAyB0oB,aAAzB,CAAT,EAAkDyM,SAAlD,CADa,CAAA;AAAA,oCAEb,OAAOF,GAAP,CAFa;AAAA,iCAdoC;AAAA,gCAkBnDj1B,IAAA,GAAOmpB,QAAA,CACLnpB,IADK,EAELm1B,SAFK,EAGLP,YAHK,EAILlM,aAJK,CAKL5wB,CAAAA,KALK,CAKC,IALD,CAAP,CAlBmD;AAAA,gCAwBnD,KAAK,IAAI3B,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAKxf,IAAA,CAAKtJ,MAArB,EAA6BP,CAAA,GAAIqpB,EAAtC,EAA0C,EAAErpB,CAA5C,EAA+C;AAAA,oCAC7C,IAAIA,CAAA,GAAI,CAAR,EAAW;AAAA,wCACT8+B,GAAA,CAAIz5B,IAAJ,CAAS,IAAT,EAAe,EAAf,CADS,CAAA;AAAA,qCADkC;AAAA,oCAI7Cy5B,GAAA,CAAIz5B,IAAJ,CAASwE,IAAA,CAAK7J,CAAL,CAAT,EAAkBg/B,SAAlB,CAJ6C,CAAA;AAAA,iCAxBI;AAAA,gCA8BnD,OAAOF,GAAP,CA9BmD;AAAA,6BAA7C,EA+BL,EA/BK,CAAR,CADK;AAAA,yBAHgD;AAAA,qBAAzD,MAqCO;AAAA,wBACL3mB,KAAA,GAAQ+e,YAAA,CAAa0H,SAAb,EAAwB3vB,UAAxB,CAAA,CAAoCuf,IAApC,EAAR,CADK;AAAA,qBA7GmB;AAAA,oBAgH1BwI,OAAA,GAAUf,QAAA,CACR5O,KADQ,EAER,OAFQ,EAGR,cAHQ,EAIRjiB,IAJQ,EAKRhF,CALQ,EAMRwrB,aANQ,EAORrd,YAPQ,CAAV,CAhH0B;AAAA,iBA7rBwC;AAAA,gBAuzBpE,IAAI4J,KAAA,IAAS6e,OAAT,IAAoB,CAAC0E,SAAzB,EAAoC;AAAA,oBAClC,IAAI,CAACH,QAAL,EAAe;AAAA,wBACb,EAAE3B,YAAF,CADa;AAAA,wBAEb7Y,KAAA,GAAQsY,MAAA,CAAOO,YAAP,CAAR,CAFa;AAAA,wBAGb,IACE,CAAC7Y,KAAD,IACA,CAACA,KAAA,CAAM2Z,OAAN,EADD,IAEA3Z,KAAA,CAAMyZ,OAAN,EAFA,IAGAzZ,KAAA,CAAM0Z,SAAN,EAJF,EAKE;AAAA,4BACA1Z,KAAA,GAAQ,IAAI4Z,KAAJ,EAAR,CADA;AAAA,4BAEAtB,MAAA,CAAOO,YAAP,CAAA,GAAuB7Y,KAAvB,CAFA;AAAA,yBARW;AAAA,wBAYbA,KAAA,CAAM8c,QAAN,CAAen7B,SAAf,CAZa,CAAA;AAAA,wBAabqe,KAAA,CAAM0c,WAAN,CAAkB/6B,SAAlB,CAba,CAAA;AAAA,qBADmB;AAAA,oBAgBlC,MAAMw6B,aAAA,GAAgB3G,gBAAA,CACpBlP,KADoB,EAEpBjiB,IAFoB,EAGpBhF,CAHoB,EAIpB,MAJoB,EAKpBwrB,aALoB,CAAtB,CAhBkC;AAAA,oBAuBlC,IAAI,CAAC7K,KAAA,CAAM2Z,OAAN,EAAL,EAAsB;AAAA,wBACpB3Z,KAAA,CAAM+c,OAAN,CAAcj0B,IAAd,CADoB,CAAA;AAAA,qBAvBY;AAAA,oBA0BlCA,IAAA,GAAOkX,KAAA,CAAM2Z,OAAN,EAAP,CA1BkC;AAAA,oBA2BlC,IACE,CAAC7wB,IAAD,IACC,kBAAsBA,IAAAA,IAAtB,IACCA,IAAA,CAAK0sB,gBAAL,EAA4B2G,KAAAA,aAHhC,EAIE;AAAA,wBACArzB,IAAA,GAAO,IAAIo1B,IAAJ,CAAS;AAAA,4BACdC,OAAA,EAAS;AAAA,gCAAC,CAAD;AAAA,gCAAI,CAAJ;AAAA,gCAAO,CAAP;AAAA,gCAAU,CAAV;AAAA,6BADK;AAAA;AAGd,4BAAAhC,aAAA,EAAeA,aAHD;AAAA,yBAAT,CAAP,CADA;AAAA,wBAMAnc,KAAA,CAAM+c,OAAN,CAAcj0B,IAAd,CANA,CAAA;AAAA,qBA/BgC;AAAA,oBAuClC,MAAMs1B,aAAA,GAAgBlJ,QAAA,CACpB5O,KADoB,EAEpB,QAFoB,EAGpB,gBAHoB,EAIpBjiB,IAJoB,EAKpBhF,CALoB,EAMpBwrB,aANoB,EAOpBrd,YAPoB,CAAtB,CAvCkC;AAAA,oBAgDlC,IAAI4wB,aAAA,IAAiB,WAArB,EAAkC;AAAA,wBAChChnB,KAAA,GAAQtP,KAAA,CAAMC,OAAN,CAAcqP,KAAd,CACJA,GAAAA,KAAA,CAAMnU,GAAN,CAAU,CAACsE,CAAD,EAAItI,CAAJ,KAAWA,CAAA,GAAI,CAAJ,GAAQsI,CAAR,GAAYA,CAAA,CAAEma,WAAF,EAAjC,CADI,GAEJtK,KAAA,CAAMsK,WAAN,EAFJ,CADgC;AAAA,qBAAlC,MAIO,IAAI0c,aAAA,IAAiB,WAArB,EAAkC;AAAA,wBACvChnB,KAAA,GAAQtP,KAAA,CAAMC,OAAN,CAAcqP,KAAd,CACJA,GAAAA,KAAA,CAAMnU,GAAN,CAAU,CAACsE,CAAD,EAAItI,CAAJ,KAAWA,CAAA,GAAI,CAAJ,GAAQsI,CAAR,GAAYA,CAAA,CAAEpH,WAAF,EAAjC,CADI,GAEJiX,KAAA,CAAMjX,WAAN,EAFJ,CADuC;AAAA,qBApDP;AAAA,oBAyDlC,MAAMk+B,YAAA,GAAev2B,KAAA,CAAMC,OAAN,CAAcqP,KAAd,CAAA,GACjBA,KADiB,GAEjB1T,IAAA,IAAQ,CAAR,GACE6tB,kBAAA,CAAmBna,KAAnB,EAA0Boa,aAA1B,CADF,GAEES,QAAA,CAAS7a,KAAT,EAAgBjL,IAAhB,EAAsBuxB,YAAtB,EAAoClM,aAApC,CAJN,CAzDkC;AAAA,oBA8DlC1oB,IAAA,CAAKi0B,OAAL,CAAasB,YAAb,CA9DkC,CAAA;AAAA,oBA+DlCv1B,IAAA,CAAKw1B,OAAL,CAAanyB,IAAb,CA/DkC,CAAA;AAAA,oBAgElCrD,IAAA,CAAK6zB,WAAL,CACEljB,OAAA,CACEyb,QAAA,CACE5O,KADF,EAEE,QAFF,EAGE,aAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADF,CADF,CAhEkC,CAAA;AAAA,oBA6ElC,IAAI,OAAO1E,IAAA,CAAKy1B,cAAZ,KAA+B,UAAnC,EAA+C;AAAA,wBAC7C,MAAMC,WAAA,GAActJ,QAAA,CAClB5O,KADkB,EAElB,QAFkB,EAGlB,mBAHkB,EAIlBjiB,IAJkB,EAKlBhF,CALkB,EAMlBwrB,aANkB,EAOlBrd,YAPkB,CAApB,CAD6C;AAAA,wBAU7C1E,IAAA,CAAKy1B,cAAL,CAAoBC,WAApB,CAV6C,CAAA;AAAA,qBA7Eb;AAAA,oBAyFlC,MAAMC,UAAA,GAAavJ,QAAA,CACjB5O,KADiB,EAEjB,QAFiB,EAGjB,aAHiB,EAIjBjiB,IAJiB,EAKjBhF,CALiB,EAMjBwrB,aANiB,EAOjBrd,YAPiB,CAAnB,CAzFkC;AAAA,oBAkGlC,MAAM+tB,SAAA,GACJf,QAAA,IAAY92B,IAAA,IAAQ,CAApB,GACI,OADJ,GAEIwxB,QAAA,CACE5O,KADF,EAEE,QAFF,EAGE,kBAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CAHN,CAlGkC;AAAA,oBA8GlC,IAAIkxB,SAAJ,CA9GkC;AAAA,oBA+GlC,IAAInD,SAAA,KAAc,aAAlB,EAAiC;AAAA,wBAC/BzyB,IAAA,CAAK61B,YAAL,CAAkB,MAAlB,CAD+B,CAAA;AAAA,wBAE/BD,SAAA,GAAY,QAAZ,CAF+B;AAAA,qBAAjC,MAGO;AAAA,wBACL51B,IAAA,CAAK61B,YAAL,CAAkBpD,SAAlB,CADK,CAAA;AAAA,qBAlH2B;AAAA,oBAqHlC,IAAIA,SAAA,KAAc,MAAd,IAAwB,OAAOzyB,IAAA,CAAK81B,SAAZ,KAA0B,UAAtD,EAAkE;AAAA,wBAChE,MAAMC,aAAA,GAAgB3J,QAAA,CACpB5O,KADoB,EAEpB,QAFoB,EAGpB,gBAHoB,EAIpBjiB,IAJoB,EAKpBhF,CALoB,EAMpBwrB,aANoB,EAOpBrd,YAPoB,CAAtB,CADgE;AAAA,wBAUhE1E,IAAA,CAAK81B,SAAL,CAAeC,aAAA,GAAgB,CAA/B,CAVgE,CAAA;AAAA,qBArHhC;AAAA,oBAiIlC/1B,IAAA,CAAKg2B,WAAL,CAAiBvD,SAAA,KAAc,OAA/B,CAjIkC,CAAA;AAAA,oBAkIlC,IAAIwD,aAAA,GAAgB7J,QAAA,CAClB5O,KADkB,EAElB,OAFkB,EAGlB,iBAHkB,EAIlBjiB,IAJkB,EAKlBhF,CALkB,EAMlBwrB,aANkB,EAOlBrd,YAPkB,CAApB,CAlIkC;AAAA,oBA2IlC,MAAMwxB,UAAA,GAAa9J,QAAA,CACjB5O,KADiB,EAEjB,QAFiB,EAGjB,aAHiB,EAIjBjiB,IAJiB,EAKjBhF,CALiB,EAMjBwrB,aANiB,EAOjBrd,YAPiB,CAAnB,CA3IkC;AAAA,oBAoJlC,MAAMyxB,aAAA,GAAgB/J,QAAA,CACpB5O,KADoB,EAEpB,OAFoB,EAGpB,gBAHoB,EAIpBjiB,IAJoB,EAKpBhF,CALoB,EAMpBwrB,aANoB,EAOpBrd,YAPoB,CAAtB,CApJkC;AAAA;AA8JlC,oBAAI0xB,IAAAA,OAAA,GAAU,CAAd,CA9JkC;AAAA,oBA+JlC,IAAIC,OAAA,GAAU,CAAd,CA/JkC;AAAA,oBAgKlC,IAAI5D,SAAA,IAAa,OAAjB,EAA0B;AAAA,wBACxBmD,SAAA,GAAY,QAAZ,CADwB;AAAA,wBAExB,IAAID,UAAA,CAAWj+B,OAAX,CAAmB,MAAnB,CAAA,KAA+B,CAAC,CAApC,EAAuC;AAAA,4BACrCk+B,SAAA,GAAY,MAAZ,CADqC;AAAA,4BAErCS,OAAA,GAAUJ,aAAV,CAFqC;AAAA,yBAAvC,MAGO,IAAIN,UAAA,CAAWj+B,OAAX,CAAmB,OAAnB,CAAA,KAAgC,CAAC,CAArC,EAAwC;AAAA,4BAC7Ck+B,SAAA,GAAY,OAAZ,CAD6C;AAAA,4BAE7CS,OAAA,GAAU,CAACJ,aAAX,CAF6C;AAAA,yBALvB;AAAA,wBASxB,MAAMK,qBAAA,GAAwBlK,QAAA,CAC5B5O,KAD4B,EAE5B,QAF4B,EAG5B,yBAH4B,EAI5BjiB,IAJ4B,EAK5BhF,CAL4B,EAM5BwrB,aAN4B,EAO5Brd,YAP4B,CAA9B,CATwB;AAAA,wBAkBxB1E,IAAA,CAAKu2B,iBAAL,CAAuBD,qBAAA,IAAyB,KAAhD,CAlBwB,CAAA;AAAA,qBAA1B,MAmBO;AAAA,wBACLt2B,IAAA,CAAKw2B,WAAL,CACG7lB,OAAA,CACCyb,QAAA,CACE5O,KADF,EAEE,QAFF,EAGE,gBAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADD,CAAA,GAWC4J,KAAA,CAAM5X,MAXR,GAYE6+B,YAAA,CAAa7+B,MAbjB,CADK,CAAA;AAAA,wBAgBLsJ,IAAA,CAAKu2B,iBAAL,CAAuB,KAAvB,CAhBK,CAAA;AAAA,qBAnL2B;AAAA,oBAqMlCv2B,IAAA,CAAKy2B,YAAL,CAAkBb,SAAlB,CArMkC,CAAA;AAAA,oBAsMlC,IAAIc,YAAA,GAAe,QAAnB,CAtMkC;AAAA,oBAuMlC,IAAIf,UAAA,CAAWj+B,OAAX,CAAmB,QAAnB,CAAA,IAAgC,CAApC,EAAuC;AAAA,wBACrCg/B,YAAA,GAAe,QAAf,CADqC;AAAA,wBAErCN,OAAA,GAAU,CAACH,aAAD,GAAiB,GAAA,IAAOvB,cAAA,GAAiB,CAAjB,CAAP,GAA6BC,QAAxD,CAFqC;AAAA,qBAAvC,MAGO,IAAIgB,UAAA,CAAWj+B,OAAX,CAAmB,KAAnB,CAA6B,IAAA,CAAjC,EAAoC;AAAA,wBACzCg/B,YAAA,GAAe,KAAf,CADyC;AAAA,wBAEzCN,OAAA,GAAUH,aAAA,GAAgB,GAAO,IAAAvB,cAAA,GAAiB,CAAjB,CAAP,GAA6BC,QAAvD,CAFyC;AAAA,qBA1MT;AAAA,oBA8MlC30B,IAAA,CAAK22B,eAAL,CAAqBD,YAArB,CA9MkC,CAAA;AAAA,oBA+MlC,MAAME,WAAA,GAAcxK,QAAA,CAClB5O,KADkB,EAElB,QAFkB,EAGlB,cAHkB,EAIlBjiB,IAJkB,EAKlBhF,CALkB,EAMlBwrB,aANkB,EAOlBrd,YAPkB,CAApB,CA/MkC;AAAA,oBAwNlC1E,IAAA,CAAK62B,UAAL,CAAgBD,WAAA,KAAgB,MAAhB,GAAyB/9B,SAAzB,GAAqC+9B,WAArD,CAxNkC,CAAA;AAAA,oBAyNlC52B,IAAA,CAAK82B,UAAL,CACEZ,UAAA,CAAW,CAAX,CAAA,GAAgBvB,QAAhB,GAA2B0B,OAA3B,GAAqCF,aAAA,CAAc,CAAd,CADvC,CAzNkC,CAAA;AAAA,oBA4NlCn2B,IAAA,CAAK+2B,UAAL,CACEb,UAAA,CAAW,CAAX,CAAA,GAAgBvB,QAAhB,GAA2ByB,OAA3B,GAAqCD,aAAA,CAAc,CAAd,CADvC,CA5NkC,CAAA;AAAA,oBA+NlC/1B,SAAA,CAAUgxB,QAAV,CACElE,gBAAA,CACEd,QAAA,CACE5O,KADF,EAEE,OAFF,EAGE,YAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADF,EAUEyoB,OAVF,CADF,CA/NkC,CAAA;AAAA,oBA6OlCntB,IAAA,CAAKg3B,OAAL,CAAa52B,SAAb,CA7OkC,CAAA;AAAA,oBA8OlC,MAAMgnB,SAAA,GAAY8F,gBAAA,CAChBd,QAAA,CACE5O,KADF,EAEE,OAFF,EAGE,iBAHF,EAIEjiB,IAJF,EAKEhF,CALF,EAMEwrB,aANF,EAOErd,YAPF,CADgB,EAUhByoB,OAVgB,CAAlB,CA9OkC;AAAA,oBA0PlC,IAAI/F,SAAA,IAAa6O,aAAA,GAAgB,CAAjC,EAAoC;AAAA,wBAClC5G,QAAA,CAAS+B,QAAT,CAAkBhK,SAAlB,CADkC,CAAA;AAAA;AAIlC;AAAA,wBAAA6O,aAAA,IAAiB,CAAjB,CAJkC;AAAA;AAMlC,wBAAA,MAAMgB,YAAA,GAAe,GAAMtC,GAAAA,QAA3B,CANkC;AAAA,wBAOlCtF,QAAA,CAASgC,QAAT,CACE4E,aAAA,IAAiBgB,YAAjB,GAAgChB,aAAhC,GAAgDgB,YADlD,CAPkC,CAAA;AAAA,wBAUlCj3B,IAAA,CAAKk3B,SAAL,CAAe7H,QAAf,CAVkC,CAAA;AAAA,qBAApC,MAWO;AAAA,wBACLrvB,IAAA,CAAKk3B,SAAL,CAAer+B,SAAf,CADK,CAAA;AAAA,qBArQ2B;AAAA,oBAwQlC,MAAMs+B,WAAA,GAAc/K,QAAA,CAClB5O,KADkB,EAElB,QAFkB,EAGlB,cAHkB,EAIlBjiB,IAJkB,EAKlBhF,CALkB,EAMlBwrB,aANkB,EAOlBrd,YAPkB,CAApB,CAxQkC;AAAA,oBAiRlC,MAAM2wB,OAAA,GAAUr1B,IAAA,CAAKo3B,UAAL,EAAhB,CAjRkC;AAAA,oBAkRlC,IAAID,WAAA,KAAgB9B,OAAA,CAAQ,CAAR,CAApB,EAAgC;AAAA,wBAC9BA,OAAA,CAAQ,CAAR,CAAA,GAAa8B,WAAb,CAD8B;AAAA,wBAE9B9B,OAAA,CAAQ,CAAR,CAAA,GAAa8B,WAAb,CAF8B;AAAA,wBAG9B9B,OAAA,CAAQ,CAAR,CAAA,GAAa8B,WAAb,CAH8B;AAAA,wBAI9B9B,OAAA,CAAQ,CAAR,CAAA,GAAa8B,WAAb,CAJ8B;AAAA,qBAlRE;AAAA,oBAwRlCjgB,KAAA,CAAM6Z,SAAN,CAAgB7jB,KAAhB,CAxRkC,CAAA;AAAA,iBAvzBgC;AAAA,aAlBvB;AAAA,SAnBa;AAAA,QAynC9D,IAAI6iB,YAAA,GAAe,CAAC,CAApB,EAAuB;AAAA,YACrBP,MAAA,CAAO94B,MAAP,GAAgBq5B,YAAA,GAAe,CAA/B,CADqB;AAAA,YAErB,IAAIzC,WAAJ,EAAiB;AAAA,gBACf,IAAI,KAAS7oB,IAAAA,OAAb,EAAsB;AAAA;AAEpB,oBAAAA,OAAA,CAAQwc,GAAR,CAAY,cAAZ,EAA4B+O,qBAA5B,CAFoB,CAAA;AAAA,iBAAtB,MAGO;AAAA;AAEL,oBAAAvrB,OAAA,CAAQkrB,aAAR,GAAwB,cAAxB,CAAA,GAA0CK,qBAA1C,CAFK;AAAA,iBAJQ;AAAA,aAFI;AAAA,YAWrB,OAAOR,MAAP,CAXqB;AAAA,SAznCuC;AAAA,QAsoC9D,OAAO32B,SAAP,CAtoC8D;AAAA,KAAhE,CAvHA;AAAA,IAgwCA+oB,OAAA,CAAQyV,QAAR,CAAiB5H,aAAjB,CAhwCA,CAAA;AAAA,IAiwCA7N,OAAA,CAAQX,GAAR,CAAY,eAAZ,EAA6BgO,YAA7B,CAjwCA,CAAA;AAAA,IAkwCArN,OAAA,CAAQX,GAAR,CAAY,eAAZ,EAA6B6N,YAA7B,CAlwCA,CAAA;AAAA,IAmwCAlN,OAAA,CAAQX,GAAR,CAAY,qBAAZ,EAAmCW,OAAA,CAAQlnB,GAAR,CAAY,qBAAZ,CAAA,IAAsC,EAAzE,CAnwCA,CAAA;AAAA,IAowCA,OAAO+0B,aAAP,CApwCA;AAAA,CA5VF;AA2mDA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAAS6H,gBAAT,CAA0B7yB,OAA1B,EAAmCwe,UAAnC,EAA+CrB,OAA/C,EAAwD0K,OAAxD,EAAiE;AAAA,IACtE,MAAMiL,aAAA,GAAgB3V,OAAA,CAAQ4V,gBAAR,EAAtB,CADsE;AAAA,IAEtE,IAAID,aAAA,CAAc7gC,MAAd,KAAyB,CAA7B,EAAgC;AAAA;AAE9B,QAAO6gC,OAAAA,aAAA,CAAc9yB,OAAd,EAAuBwe,UAAvB,EAAmCqJ,OAAnC,CAAP,CAF8B;AAAA,KAFsC;AAAA,IAMtE,OAAOzzB,SAAP,CANsE;AAAA;;ACpmDxE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAAS4+B,SAAT,CAAmBC,MAAnB,EAA2B/R,IAA3B,EAAiC;AAAA,IACtC,MAAMgS,cAAA,GAAiBD,MAAA,CAAO,CAAP,CAAvB,CADsC;AAAA,IAEtC,MAAMlV,KAAA,GAAQmV,cAAA,CAAenV,KAA7B,CAFsC;AAAA,IAGtC,MAAMC,MAAA,GAASkV,cAAA,CAAelV,MAA9B,CAHsC;AAAA,IAItC,MAAMmV,aAAA,GAAgBD,cAAA,CAAehS,IAArC,CAJsC;AAAA,IAKtC,MAAMkS,SAAA,GAAY,IAAIC,iBAAJ,CAAsBF,aAAA,CAAclhC,MAApC,CAAlB,CALsC;AAAA,IAMtC,MAAMqhC,EAAA,GAAKpS,IAAA,CAAK1C,UAAL,GAAkB,CAA7B,CANsC;AAAA,IAOtC,MAAM6P,IAAA,GAAOtQ,KAAA,GAAQ,CAArB,CAPsC;AAAA,IAQtC,MAAMwV,IAAA,GAAOvV,MAAA,GAAS,CAAtB,CARsC;AAAA,IAStC,MAAMwV,KAAA,GAAQ;AAAA,QAAC,CAAD;AAAA,QAAI,CAAJ;AAAA,QAAO,CAAP;AAAA,QAAU,CAAV;AAAA,KAAd,CATsC;AAAA,IAUtC,MAAMC,KAAA,GAAQ,IAAI9hC,IAAA,CAAK2R,EAAvB,CAVsC;AAAA,IAWtC,MAAMowB,MAAA,GAAS/hC,IAAA,CAAK2R,EAAL,GAAU,CAAzB,CAXsC;AAAA,IAYtC,MAAMqwB,KAAA,GAAShiC,IAAA,CAAK2R,EAAL,GAAU4d,IAAA,CAAKyS,KAAhB,GAAyB,GAAvC,CAZsC;AAAA,IAatC,MAAMC,KAAA,GAASjiC,IAAA,CAAK2R,EAAL,GAAU4d,IAAA,CAAK0S,KAAhB,GAAyB,GAAvC,CAbsC;AAAA,IActC,MAAMC,QAAA,GAAWliC,IAAA,CAAKwb,GAAL,CAASwmB,KAAT,CAAjB,CAdsC;AAAA,IAetC,MAAMG,QAAA,GAAWniC,IAAA,CAAKyb,GAAL,CAASumB,KAAT,CAAjB,CAfsC;AAAA,IAgBtC,MAAMI,cAAA,GAAiB7S,IAAA,CAAK6S,cAA5B,CAhBsC;AAAA,IAiBtC,MAAMC,WAAA,GAAc9S,IAAA,CAAK8S,WAAzB,CAjBsC;AAAA,IAkBtC,MAAMC,WAAA,GAAc/S,IAAA,CAAK+S,WAAzB,CAlBsC;AAAA,IAmBtC,MAAMC,QAAA,GAAWhT,IAAA,CAAKgT,QAAtB,CAnBsC;AAAA,IAqBtC,IAAIC,MAAJ,EACEC,MADF,EAEEC,EAFF,EAGElwB,EAHF,EAIEmwB,EAJF,EAKElwB,EALF,EAME6qB,MANF,EAOEsF,EAPF,EAQEC,EARF,EASEC,IATF,EAUEC,IAVF,EAWEC,KAXF,EAYEC,MAZF,EAaEC,MAbF,EAcEC,MAdF,EAeEC,KAfF,EAgBEC,iBAhBF,EAiBEC,mBAjBF,EAkBEC,KAlBF,EAmBEC,cAnBF,EAoBEC,WApBF,EAqBEC,YArBF,CArBsC;AAAA,IA4CtC,SAASC,kBAAT,CAA4B9B,KAA5B,EAAmCU,QAAA,GAAW,QAA9C,EAAwD;AAAA;AAQtD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,QAAIA,IAAAA,QAAA,KAAa,QAAjB,EAA2B;AAAA,YACzB,OAAQ,CAAAV,KAAA,CAAM,CAAN,IAAW,GAAX,GAAiB,GAAjB,GAAuBA,KAAA,CAAM,CAAN,CAAW,GAAA,GAAlC,GAAwCA,KAAA,CAAM,CAAN,CAAxC,IAAoD,GAArD,GAA2D,KAAlE,CADyB;AAAA,SAR2B;AAAA,QAWtD,IAAIU,QAAA,KAAa,WAAjB,EAA8B;AAAA,YAC5B,OAAOV,KAAA,CAAM,CAAN,CAAW,GAAA,GAAX,GAAiBA,KAAA,CAAM,CAAN,CAAjB,GAA4BA,KAAA,CAAM,CAAN,IAAW,GAAvC,GAA6C,KAApD,CAD4B;AAAA,SAXwB;AAAA,KA5ClB;AAAA,IA2DtC,KAAKY,MAAA,GAAS,CAAd,EAAiBA,MAAA,IAAUb,IAA3B,EAAiC,EAAEa,MAAnC,EAA2C;AAAA,QACzCE,EAAA,GAAKF,MAAA,KAAW,CAAX,GAAe,CAAf,GAAmBA,MAAA,GAAS,CAAjC,CADyC;AAAA,QAEzChwB,EAAA,GAAKgwB,MAAA,KAAWb,IAAX,GAAkBA,IAAlB,GAAyBa,MAAA,GAAS,CAAvC,CAFyC;AAAA,QAGzC,KAAKD,MAAA,GAAS,CAAd,EAAiBA,MAAA,IAAU9F,IAA3B,EAAiC,EAAE8F,MAAnC,EAA2C;AAAA,YACzCE,EAAA,GAAKF,MAAA,KAAW,CAAX,GAAe,CAAf,GAAmBA,MAAA,GAAS,CAAjC,CADyC;AAAA,YAEzChwB,EAAA,GAAKgwB,MAAA,KAAW9F,IAAX,GAAkBA,IAAlB,GAAyB8F,MAAA,GAAS,CAAvC,CAFyC;AAAA;AAKzC,YAAAlF,MAAA,GAAU,CAAAmF,MAAA,GAASrW,KAAT,GAAiBsW,EAAjB,IAAuB,CAAjC,CALyC;AAAA,YAMzCb,KAAA,CAAM,CAAN,CAAA,GAAWL,aAAA,CAAclE,MAAd,CAAX,CANyC;AAAA,YAOzCuE,KAAA,CAAM,CAAN,CAAWL,GAAAA,aAAA,CAAclE,MAAA,GAAS,CAAvB,CAAX,CAPyC;AAAA,YAQzCuE,KAAA,CAAM,CAAN,CAAWL,GAAAA,aAAA,CAAclE,MAAA,GAAS,CAAvB,CAAX,CARyC;AAAA,YASzCuE,KAAA,CAAM,CAAN,CAAWL,GAAAA,aAAA,CAAclE,MAAA,GAAS,CAAvB,CAAX,CATyC;AAAA,YAUzCsF,EAAA,GAAKrT,IAAA,CAAKqU,IAAL,GAAYD,kBAAA,CAAmB9B,KAAnB,EAA0BU,QAA1B,CAAjB,CAVyC;AAAA;AAazC,YAAAjF,MAAA,GAAU,CAAAmF,MAAA,GAASrW,KAAT,GAAiB5Z,EAAjB,IAAuB,CAAjC,CAbyC;AAAA,YAczCqvB,KAAA,CAAM,CAAN,CAAA,GAAWL,aAAA,CAAclE,MAAd,CAAX,CAdyC;AAAA,YAezCuE,KAAA,CAAM,CAAN,CAAWL,GAAAA,aAAA,CAAclE,MAAA,GAAS,CAAvB,CAAX,CAfyC;AAAA,YAgBzCuE,KAAA,CAAM,CAAN,CAAWL,GAAAA,aAAA,CAAclE,MAAA,GAAS,CAAvB,CAAX,CAhByC;AAAA,YAiBzCuE,KAAA,CAAM,CAAN,CAAWL,GAAAA,aAAA,CAAclE,MAAA,GAAS,CAAvB,CAAX,CAjByC;AAAA,YAkBzCuF,EAAA,GAAKtT,IAAA,CAAKqU,IAAL,GAAYD,kBAAA,CAAmB9B,KAAnB,EAA0BU,QAA1B,CAAjB,CAlByC;AAAA,YAoBzCO,IAAA,GAAQ,CAAAD,EAAA,GAAKD,EAAL,IAAWjB,EAAnB,CApByC;AAAA;AAuBzC,YAAArE,MAAA,GAAU,CAAAqF,EAAA,GAAKvW,KAAL,GAAaoW,MAAb,IAAuB,CAAjC,CAvByC;AAAA,YAwBzCX,KAAA,CAAM,CAAN,CAAA,GAAWL,aAAA,CAAclE,MAAd,CAAX,CAxByC;AAAA,YAyBzCuE,KAAA,CAAM,CAAN,CAAWL,GAAAA,aAAA,CAAclE,MAAA,GAAS,CAAvB,CAAX,CAzByC;AAAA,YA0BzCuE,KAAA,CAAM,CAAN,CAAWL,GAAAA,aAAA,CAAclE,MAAA,GAAS,CAAvB,CAAX,CA1ByC;AAAA,YA2BzCuE,KAAA,CAAM,CAAN,CAAWL,GAAAA,aAAA,CAAclE,MAAA,GAAS,CAAvB,CAAX,CA3ByC;AAAA,YA4BzCsF,EAAA,GAAKrT,IAAA,CAAKqU,IAAL,GAAYD,kBAAA,CAAmB9B,KAAnB,EAA0BU,QAA1B,CAAjB,CA5ByC;AAAA;AA+BzC,YAAAjF,MAAA,GAAU,CAAA7qB,EAAA,GAAK2Z,KAAL,GAAaoW,MAAb,IAAuB,CAAjC,CA/ByC;AAAA,YAgCzCX,KAAA,CAAM,CAAN,CAAA,GAAWL,aAAA,CAAclE,MAAd,CAAX,CAhCyC;AAAA,YAiCzCuE,KAAA,CAAM,CAAN,CAAWL,GAAAA,aAAA,CAAclE,MAAA,GAAS,CAAvB,CAAX,CAjCyC;AAAA,YAkCzCuE,KAAA,CAAM,CAAN,CAAWL,GAAAA,aAAA,CAAclE,MAAA,GAAS,CAAvB,CAAX,CAlCyC;AAAA,YAmCzCuE,KAAA,CAAM,CAAN,CAAWL,GAAAA,aAAA,CAAclE,MAAA,GAAS,CAAvB,CAAX,CAnCyC;AAAA,YAoCzCuF,EAAA,GAAKtT,IAAA,CAAKqU,IAAL,GAAYD,kBAAA,CAAmB9B,KAAnB,EAA0BU,QAA1B,CAAjB,CApCyC;AAAA,YAsCzCQ,IAAA,GAAQ,CAAAF,EAAA,GAAKD,EAAL,IAAWjB,EAAnB,CAtCyC;AAAA,YAwCzCsB,MAAA,GAASjjC,IAAA,CAAKob,KAAL,CAAW2nB,IAAX,EAAiB,CAACD,IAAlB,CAAT,CAxCyC;AAAA,YAyCzC,IAAIG,MAAA,GAAS,CAAb,EAAgB;AAAA,gBACdA,MAAA,GAASlB,MAAA,GAASkB,MAAlB,CADc;AAAA,aAAhB,MAEO,IAAIA,MAAA,GAASlB,MAAb,EAAqB;AAAA,gBAC1BkB,MAAA,GAASnB,KAAA,GAAQmB,MAAR,GAAiBlB,MAA1B,CAD0B;AAAA,aAArB,MAEA;AAAA,gBACLkB,MAAA,GAASlB,MAAA,GAASkB,MAAlB,CADK;AAAA,aA7CkC;AAAA;AAkDzC,YAAAD,KAAA,GAAQhjC,IAAA,CAAKqiB,IAAL,CAAUriB,IAAA,CAAKqb,IAAL,CAAUynB,IAAA,GAAOA,IAAP,GAAcC,IAAA,GAAOA,IAA/B,CAAV,CAAR,CAlDyC;AAAA,YAmDzCW,YAAA,GACEvB,QAAA,GAAWniC,IAAA,CAAKwb,GAAL,CAASwnB,KAAT,CAAX,GACAd,QAAA,GAAWliC,IAAA,CAAKyb,GAAL,CAASunB,KAAT,CAAX,GAA6BhjC,IAAA,CAAKwb,GAAL,CAASymB,KAAA,GAAQgB,MAAjB,CAF/B,CAnDyC;AAAA,YAsDzCC,MAAA,GAASljC,IAAA,CAAKwb,GAAL,CAASwnB,KAAT,CAAT,CAtDyC;AAAA;AAwDzC,YAAAG,MAAA,GAAS,GAAMO,GAAAA,YAAf,CAxDyC;AAAA;AAgEzC;AAAA;AAAA;AAAA;AAAA,YAAAH,KAAA,GAAQvjC,IAAA,CAAKqR,GAAL,CAASrR,IAAA,CAAKsR,GAAL,CAAS,IAAIie,IAAA,CAAKyS,KAAlB,EAAyB,CAAzB,CAAT,EAAsC,CAAtC,CAAR,CAhEyC;AAAA;AAmEzC,YAAAwB,cAAA,GAAiB,KAAQjU,GAAAA,IAAA,CAAKwH,OAAL,GAAe,IAAxC,CAnEyC;AAAA;AAqEzC,YAAA0M,WAAA,GACElU,IAAA,CAAKwH,OAAL,KAAiB,GAAjB,GACIgL,MAAA,IACE,CAAA/hC,IAAA,CAAKoS,GAAL,CAASoxB,cAAT,EAAyBR,KAAzB,CAAA,GAAkC,CAAlC,KACChjC,IAAA,CAAKoS,GAAL,CAASoxB,cAAT,EAAyBzB,MAAzB,CAAmC,GAAA,CAAnC,CADF,CAFL,GAIIiB,KALN,CArEyC;AAAA;AA6EzC,YAAAK,iBAAA,GAAoB;AAAA,gBAClBlhC,CAAA,EAAI,CAAI+gC,CAAAA,GAAAA,MAAJ,IAAcZ,WAAA,CAAYngC,CAA3B,GAA+BohC,KAA/B,GAAuC,GADxB;AAAA,gBAElBnhC,CAAA,EAAI,CAAI8gC,CAAAA,GAAAA,MAAJ,IAAcZ,WAAA,CAAYlgC,CAA3B,GAA+BmhC,KAA/B,GAAuC,GAFxB;AAAA,gBAGlBlhC,CAAA,EAAI,CAAI6gC,CAAAA,GAAAA,MAAJ,IAAcZ,WAAA,CAAYjgC,CAA3B,GAA+BkhC,KAA/B,GAAuC,GAHxB;AAAA,gBAIlBjhC,CAAA,EAAI,CAAI4gC,CAAAA,GAAAA,MAAJ,IAAcZ,WAAA,CAAYhgC,CAA3B,GAA+BihC,KAA/B,GAAuC,GAJxB;AAAA,aAApB,CA7EyC;AAAA;AAqFzC,YAAAH,KAAA,GAAQpjC,IAAA,CAAK6Z,GAAL,CAAW,CAAC,CAAAopB,MAAA,GAAShB,KAAT,IAAkBjiC,IAAA,CAAK2R,EAAxB,GAA6B,GAA7B,IAAoC,CAAtC,GAA2C,CAApD,CAAR,CArFyC;AAAA;AAuFzC,YAAA2xB,mBAAA,GAAsB;AAAA,gBACpBnhC,CAAA,EAAI,CAAAigC,cAAA,CAAejgC,CAAf,IAAwBihC,CAAAA,GAAAA,KAAJ,CAApB,GAAiCf,WAAA,CAAYlgC,CAAZ,GAAgBihC,KAAjD,IAA0DD,MAD1C;AAAA,gBAEpB/gC,CAAA,EAAI,CAAAggC,cAAA,CAAehgC,CAAf,IAAwBghC,CAAAA,GAAAA,KAAJ,CAApB,GAAiCf,WAAA,CAAYjgC,CAAZ,GAAgBghC,KAAjD,IAA0DD,MAF1C;AAAA,gBAGpB9gC,CAAA,EAAI,CAAA+/B,cAAA,CAAe//B,CAAf,IAAwB+gC,CAAAA,GAAAA,KAAJ,CAApB,GAAiCf,WAAA,CAAYhgC,CAAZ,GAAgB+gC,KAAjD,IAA0DD,MAH1C;AAAA,gBAIpB7gC,CAAA,EAAI,CAAA8/B,cAAA,CAAe9/B,CAAf,IAAwB8gC,CAAAA,GAAAA,KAAJ,CAApB,GAAiCf,WAAA,CAAY//B,CAAZ,GAAgB8gC,KAAjD,IAA0DD,MAJ1C;AAAA,aAAtB,CAvFyC;AAAA;AA+FzC,YAAA7F,MAAA,GAAU,CAAAmF,MAAA,GAASrW,KAAT,GAAiBoW,MAAjB,IAA2B,CAArC,CA/FyC;AAAA,YAgGzCf,SAAA,CAAUnE,MAAV,CAAA,GACE+F,iBAAA,CAAkBlhC,CAAlB,IAAuB,CAAA,GAAIihC,KAAJ,CAAvB,GAAoCE,mBAAA,CAAoBnhC,CAD1D,CAhGyC;AAAA,YAkGzCs/B,SAAA,CAAUnE,MAAA,GAAS,CAAnB,IACE+F,iBAAA,CAAkBjhC,CAAlB,QAA2BghC,KAAJ,CAAvB,GAAoCE,mBAAA,CAAoBlhC,CAD1D,CAlGyC;AAAA,YAoGzCq/B,SAAA,CAAUnE,MAAA,GAAS,CAAnB,IACE+F,iBAAA,CAAkBhhC,CAAlB,QAA2B+gC,KAAJ,CAAvB,GAAoCE,mBAAA,CAAoBjhC,CAD1D,CApGyC;AAAA;AAuGzC,YAAAo/B,SAAA,CAAUnE,MAAA,GAAS,CAAnB,IACEkE,aAAA,CAAclE,MAAA,GAAS,CAAvB,CAAA,GACA/N,IAAA,CAAKwH,OADL,GAEAwM,KAFA,GAGAvjC,IAAA,CAAKyb,GAAL,CAASgoB,WAAT,CAJF,CAvGyC;AAAA,SAHF;AAAA,KA3DL;AAAA,IA6KtC,OAAO,IAAII,SAAJ,CAAcpC,SAAd,EAAyBrV,KAAzB,EAAgCC,MAAhC,CAAP,CA7KsC;AAAA;;ACDxC;AAAA;AAAA;AAAA;AAAA;AAsGA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAASyX,kBAAT,CAA4BzU,UAA5B,EAAwC0U,QAAA,GAAW,GAAnD,EAAwD;AAAA,IACtD,OAAO1U,UAAA,CAAW4M,SAAX,EAAA,GACH+H,SAAA,CAAU;AAAA,QACR5U,MAAA,EAAQC,UAAA,CAAW4M,SAAX,EADA;AAAA,QAER8H,QAAA,EAAUA,QAFF;AAAA,QAGRE,OAAA,EAAS,EAHD;AAAA,KAAV,CAIGC,CAAAA,cAJH,EADG,GAMHlY,kBANJ,CADsD;AAAA,CA5GxD;AA2HA;AAAA;AAAA;AAAA;AAAA;AAAA,SAASmY,eAAT,CAAyBna,QAAzB,EAAmCpf,OAAnC,EAA4C;AAAA,IAC1C,IAAI,CAACA,OAAA,CAAQ6jB,WAAb,EAA0B;AAAA,QACxB7jB,OAAA,GAAUnG,MAAA,CAAOgsB,MAAP,CAAc,EAAd,EAAkB7lB,OAAlB,CAAV,CADwB;AAAA,QAExB,MAAMggB,YAAA,GAAe,IAAIT,GAAJ,CAAQH,QAAR,CAAkBY,CAAAA,YAAvC,CAFwB;AAAA;AAIxB,QAAAA,YAAA,CAAaje,OAAb,CAAqB,CAACtJ,KAAD,EAAQsD,GAAR,KAAgB;AAAA,YACnCiE,OAAA,CAAQ6jB,WAAR,GAAsBprB,KAAtB,CADmC;AAAA,YAEnCuH,OAAA,CAAQ2lB,gBAAR,GAA2B5pB,GAA3B,CAFmC;AAAA,SAArC,CAJwB,CAAA;AAAA,KADgB;AAAA,IAU1C,OAAOiE,OAAP,CAV0C;AAAA,CA3H5C;AAwLA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASw5B,UAAT,CACLhd,KADK,EAELkE,OAFK,EAGL+Y,uBAAA,GAA0B,EAHrB,EAILC,aAAA,GAAgB,EAJX,EAKLrY,WAAA,GAAcxpB,SALT,EAML;AAAA,IACA,IAAIunB,QAAJ,EAAcua,QAAd,CADA;AAAA;AAGA,IAAA,IAAI35B,OAAJ,CAHA;AAAA,IAIA,IAAI2sB,cAAJ,CAJA;AAAA,IAKA,IAAIiN,YAAA,GAAe,IAAnB,CALA;AAAA,IAMA,IACE,OAAOH,uBAAP,KAAmC,QAAnC,IACA,CAACz7B,KAAA,CAAMC,OAAN,CAAcw7B,uBAAd,CAFH,EAGE;AAAA,QACAz5B,OAAA,GAAUy5B,uBAAV,CADA;AAAA,QAEA9M,cAAA,GAAiB3sB,OAAA,CAAQkuB,MAAR,IAAkBluB,OAAA,CAAQ2c,MAA3C,CAFA;AAAA,QAGA+c,aAAA,GAAgB15B,OAAhB,CAHA;AAAA,KAHF,MAOO;AAAA,QACL2sB,cAAA,GAAiB8M,uBAAjB,CADK;AAAA,KAbP;AAAA,IAgBA,IAAI,OAAOC,aAAP,KAAyB,QAA7B,EAAuC;AAAA,QACrCta,QAAA,GAAWsa,aAAX,CADqC;AAAA,QAErC15B,OAAA,GAAU,EAAV,CAFqC;AAAA,KAAvC,MAGO;AAAA,QACLof,QAAA,GAAWsa,aAAA,CAActa,QAAzB,CADK;AAAA,QAELpf,OAAA,GAAU05B,aAAV,CAFK;AAAA,KAnBP;AAAA,IAuBA,IAAI15B,OAAA,CAAQ45B,YAAR,KAAyB,KAA7B,EAAoC;AAAA,QAClCA,YAAA,GAAe,KAAf,CADkC;AAAA,KAvBpC;AAAA,IA0BA,IAAI,CAACvY,WAAL,EAAkB;AAAA,QAChBA,WAAA,GAAcrhB,OAAA,CAAQqhB,WAAtB,CADgB;AAAA,KA1BlB;AAAA,IA6BA,IACE,CAACjC,QAAD,IACA,OAAOsB,OAAP,KAAmB,QADnB,IAEA,CAACA,OAAA,CAAQiD,IAAR,EAAA,CAAe9E,UAAf,CAA0B,GAA1B,CAHH,EAIE;AAAA,QACAO,QAAA,GAAWsB,OAAX,CADA;AAAA,KAjCF;AAAA,IAoCA,IAAItB,QAAJ,EAAc;AAAA,QACZA,QAAA,GAAWA,QAAA,CAASP,UAAT,CAAoB,OAApB,IACPc,QAAA,CAASH,IADF,GAEPE,iBAAA,CAAkBN,QAAlB,EAA4Bpf,OAAA,CAAQ6jB,WAApC,CAFJ,CADY;AAAA,QAIZ7jB,OAAA,GAAUu5B,eAAA,CAAgBna,QAAhB,EAA0Bpf,OAA1B,CAAV,CAJY;AAAA,KApCd;AAAA,IA2CA,OAAO,IAAIsjB,OAAJ,CAAY,UAAUM,OAAV,EAAmBL,MAAnB,EAA2B;AAAA;AAI5C;AAAA;AAAA,QAAAE,UAAA,CAAW/C,OAAX,EAAoB1gB,OAApB,EACG+iB,IADH,CACQ,UAAUrC,OAAV,EAAmB;AAAA,YACvB,IAAIA,OAAA,CAAQoM,OAAR,IAAmB,CAAvB,EAA0B;AAAA,gBACxB,OAAOvJ,MAAA,CAAO,IAAIpoB,KAAJ,CAAU,6BAAV,CAAP,CAAP,CADwB;AAAA,aADH;AAAA,YAIvB,IACE,EAAEqhB,KAAA,YAAiBqd,WAAjB,IAAgCrd,KAAA,YAAiBsd,eAAjD,CADJ,EAEE;AAAA,gBACA,OAAOvW,MAAA,CACL,IAAIpoB,KAAJ,CAAU,kDAAV,CADK,CAAP,CADA;AAAA,aANqB;AAAA,YAYvB,MAAMvB,IAAA,GAAO4iB,KAAA,YAAiBsd,eAAjB,GAAmC,QAAnC,GAA8C,SAA3D,CAZuB;AAAA,YAavB,IAAI,CAACnN,cAAL,EAAqB;AAAA,gBACnBgN,QAAA,GAAW9/B,MAAA,CAAOC,IAAP,CAAY4mB,OAAA,CAAQ0N,OAApB,CAA6B2L,CAAAA,IAA7B,CAAkC,UAAUh+B,GAAV,EAAe;AAAA,oBAC1D,OAAO2kB,OAAA,CAAQ0N,OAAR,CAAgBryB,GAAhB,CAAqBnC,CAAAA,IAArB,KAA8BA,IAArC,CAD0D;AAAA,iBAAjD,CAAX,CADmB;AAAA,gBAInB+yB,cAAA,GAAiBgN,QAAjB,CAJmB;AAAA,aAArB,MAKO,IAAI37B,KAAA,CAAMC,OAAN,CAAc0uB,cAAd,CAAJ,EAAmC;AAAA,gBACxCgN,QAAA,GAAWjZ,OAAA,CAAQ/D,MAAR,CAAeod,IAAf,CAAoB,UAAUvd,KAAV,EAAiB;AAAA,oBAC9C,OAAOA,KAAA,CAAMxY,EAAN,KAAa2oB,cAAA,CAAe,CAAf,CAApB,CAD8C;AAAA,iBAArC,CAAA,CAERuB,MAFH,CADwC;AAAA,aAAnC,MAIA;AAAA,gBACLyL,QAAA,GAAWhN,cAAX,CADK;AAAA,aAtBgB;AAAA,YAyBvB,IAAI,CAACgN,QAAL,EAAe;AAAA,gBACb,OAAOpW,MAAA,CAAO,IAAIpoB,KAAJ,CAAU,CAAC,GAAD,GAAMvB,IAAN,EAAW,6BAAX,CAAV,CAAP,CAAP,CADa;AAAA,aAzBQ;AAAA,YA6BvB,SAASogC,YAAT,GAAwB;AAAA,gBACtB,IAAI,CAACJ,YAAL,EAAmB;AAAA,oBACjB,OAAOtW,OAAA,CAAQM,OAAR,EAAP,CADiB;AAAA,iBADG;AAAA,gBAItB,IAAIpH,KAAA,YAAiBsd,eAArB,EAAsC;AAAA,oBACpC,OAAOG,iBAAA,CACLvZ,OAAA,CAAQ0N,OAAR,CAAgBuL,QAAhB,CADK,EAELva,QAFK,EAGLpf,OAHK,CAAA,CAIL+iB,IAJK,CAIA,UAAUmL,MAAV,EAAkB;AAAA,wBACvB,MAAMgM,YAAA,GAAe1d,KAAA,CAAM2d,SAAN,EAArB,CADuB;AAAA,wBAEvB,IAAI,CAACD,YAAL,EAAmB;AAAA,4BACjB1d,KAAA,CAAM4d,SAAN,CAAgBlM,MAAhB,CADiB,CAAA;AAAA,yBAAnB,MAEO,IAAIA,MAAA,KAAWgM,YAAf,EAA6B;AAAA,4BAClCA,YAAA,CAAaG,kBAAb,CAAgCnM,MAAA,CAAOoM,kBAAP,EAAhC,CADkC,CAAA;AAAA,4BAElC,IACE,OAAOJ,YAAA,CAAaK,OAApB,KAAgC,UAAhC,IACA,OAAOrM,MAAA,CAAOsM,OAAd,KAA0B,UAF5B,EAGE;AAAA;AAEA,gCAAAN,YAAA,CAAaK,OAAb,CAAqBrM,MAAA,CAAOsM,OAAP,EAArB,CAFA,CAAA;AAAA,6BALgC;AAAA;AAUlC,4BAAA,IAAI,CAACN,YAAA,CAAaO,OAAlB,EAA2B;AAAA;AAEzB,gCAAAP,YAAA,CAAaO,OAAb,GAAuBvM,MAAA,CAAOuM,OAA9B,CAFyB;AAAA,6BAVO;AAAA,4BAclC,IAAI,CAACP,YAAA,CAAaQ,eAAb,EAAL,EAAqC;AAAA,gCACnCR,YAAA,CAAaS,eAAb,CAA6BzM,MAAA,CAAOwM,eAAP,EAA7B,CADmC,CAAA;AAAA,6BAdH;AAAA,4BAiBlC,IACER,YAAA,CAAaU,mBAAb,EAAA,KAAuCC,mBADzC,EAEE;AAAA,gCACAX,YAAA,CAAaY,mBAAb,CACE5M,MAAA,CAAO0M,mBAAP,EADF,CADA,CAAA;AAAA,6BAnBgC;AAAA,4BAwBlC,IACEG,UAAA,CACEb,YAAA,CAAac,aAAb,EADF,EAEE9M,MAAA,CAAO8M,aAAP,EAFF,CADF,EAKE;AAAA,gCACAd,YAAA,CAAae,QAAb,GAAwB/M,MAAA,CAAOgN,WAAP,EAAxB,CADA;AAAA,6BA7BgC;AAAA,yBAJb;AAAA,wBAqCvB,MAAMD,QAAA,GAAWze,KAAA,CAAM2d,SAAN,EAAA,CAAkBe,WAAlB,EAAjB,CArCuB;AAAA,wBAsCvB,IACE,CAACC,QAAA,CAAS3e,KAAA,CAAM4e,gBAAN,EAAT,CAAD,IACA,CAACD,QAAA,CAAS3e,KAAA,CAAM6e,UAAN,EAAT,CADD,IAEAJ,QAAA,CAASI,UAAT,EAAwB,GAAA,CAH1B,EAIE;AAAA,4BACA7e,KAAA,CAAM8e,gBAAN,CACElZ,oBAAA,CACEhtB,IAAA,CAAKsR,GAAL,CAAS,CAAT,EAAYu0B,QAAA,CAASI,UAAT,EAAwB,GAAA,KAApC,CADF,EAEEJ,QAAA,CAAS3B,cAAT,EAFF,CADF,CADA,CAAA;AAAA,yBA1CqB;AAAA,qBAJlB,CAAP,CADoC;AAAA,iBAJhB;AAAA,gBA6DtB,MAAMtV,QAAA,GAAWtD,OAAA,CAAQ0N,OAAR,CAAgBuL,QAAhB,CAAjB,CA7DsB;AAAA,gBA8DtB,IAAIzL,MAAA,GAAS1R,KAAA,CAAM2d,SAAN,EAAb,CA9DsB;AAAA,gBA+DtB,IAAI,CAACjM,MAAD,IAAWA,MAAA,CAAOx0B,GAAP,CAAW,eAAX,CAAgCsqB,KAAAA,QAA/C,EAAyD;AAAA,oBACvDkK,MAAA,GAASqN,kBAAA,CAAmBvX,QAAnB,EAA6B5E,QAA7B,EAAuCpf,OAAvC,CAAT,CADuD;AAAA,iBA/DnC;AAAA,gBAkEtB,MAAMk6B,YAAA,GAA4C1d,KAAA,CAAM2d,SAAN,EAAlD,CAlEsB;AAAA,gBAmEtB,IAAI,CAACD,YAAL,EAAmB;AAAA,oBACjB1d,KAAA,CAAM4d,SAAN,CAAgBlM,MAAhB,CADiB,CAAA;AAAA,iBAAnB,MAEO,IAAIA,MAAA,KAAWgM,YAAf,EAA6B;AAAA,oBAClC,IAAI,CAACA,YAAA,CAAaQ,eAAb,EAAL,EAAqC;AAAA,wBACnCR,YAAA,CAAaS,eAAb,CAA6BzM,MAAA,CAAOwM,eAAP,EAA7B,CADmC,CAAA;AAAA,qBADH;AAAA;AAKlC,oBAAA,IAAI,CAACR,YAAA,CAAaO,OAAlB,EAA2B;AAAA;AAEzB,wBAAAP,YAAA,CAAaO,OAAb,GAAuBvM,MAAA,CAAOtJ,SAAP,EAAvB,CAFyB;AAAA,qBALO;AAAA;AAUlC,oBAAAsV,YAAA,CAAasB,IAAb,GAAoBtN,MAAA,CAAOuN,MAAP,EAApB,CAVkC;AAAA,iBArEd;AAAA,gBAiFtB,OAAOnY,OAAA,CAAQM,OAAR,EAAP,CAjFsB;AAAA,aA7BD;AAAA,YAiHvB,IAAI8X,WAAJ,EAAiB9O,UAAjB,EAA6BC,cAA7B,EAA6C3W,KAA7C,CAjHuB;AAAA,YAkHvB,SAASylB,QAAT,GAAoB;AAAA,gBAClB,IAAI,CAACzlB,KAAD,KAAW,CAACwK,OAAA,CAAQjB,MAAT,IAAmBmN,UAAnB,CAAf,EAA+C;AAAA,oBAC7C,IAAI5sB,OAAA,CAAQykB,UAAR,IAAsB,CAACpD,WAA3B,EAAwC;AAAA,wBACtC,MAAMoD,UAAA,GAAauW,KAAA,CAAch7B,OAAA,CAAQykB,UAAtB,CAAnB,CADsC;AAAA,wBAEtC,MAAMmX,KAAA,GAAQnX,UAAA,CAAWoX,QAAX,EAAd,CAFsC;AAAA,wBAGtC,IAAID,KAAA,KAAU,GAAd,EAAmB;AAAA,4BACjBva,WAAA,GAAcD,kBAAA,CAAmBjoB,GAAnB,CACX8oB,UAAD,IAAgBA,UAAA,GAAa6Z,eAAA,CAAgBF,KAAhB,CADjB,CAAd,CADiB;AAAA,yBAHmB;AAAA,qBADK;AAAA,oBAU7C1lB,KAAA,GAAQ6lB,aAAA,CACNvf,KADM,EAENkE,OAFM,EAGNiM,cAHM,EAINtL,WAJM,EAKNuL,UALM,EAMNC,cANM,EAON,CAAC7O,KAAD,EAAQ8L,WAAA,GAAc9pB,OAAA,CAAQg8B,QAA9B,KACEnS,QAAA,CAAS7L,KAAT,EAAgB8L,WAAhB,CARI,EASN9pB,OAAA,CAAQolB,QATF,CAAR,CAV6C;AAAA,oBAqB7C,IAAI,CAAC5I,KAAA,CAAMyf,QAAN,EAAL,EAAuB;AAAA,wBACrB1Y,MAAA,CAAO,IAAIpoB,KAAJ,CAAU,CAAC,4BAAD,GAA+Bw+B,QAA/B,EAAwC,CAAxC,CAAV,CAAP,CADqB,CAAA;AAAA,qBAAvB,MAEO;AAAA,wBACLK,YAAA,GAAejX,IAAf,CAAoBa,OAApB,CAA6BJ,CAAAA,KAA7B,CAAmCD,MAAnC,CADK,CAAA;AAAA,qBAvBsC;AAAA,iBAA/C,MA0BO,IAAIrN,KAAJ,EAAW;AAAA,oBAChBsG,KAAA,CAAM6Z,QAAN,CAAengB,KAAf,CADgB,CAAA;AAAA,oBAEhB8jB,YAAA,GAAejX,IAAf,CAAoBa,OAApB,CAA6BJ,CAAAA,KAA7B,CAAmCD,MAAnC,CAFgB,CAAA;AAAA,iBAAX,MAGA;AAAA,oBACLA,MAAA,CAAO,IAAIpoB,KAAJ,CAAU,6CAAV,CAAP,CADK,CAAA;AAAA,iBA9BW;AAAA,aAlHG;AAAA,YAqJvB,IAAIulB,OAAA,CAAQjB,MAAZ,EAAoB;AAAA,gBAClB,MAAMA,MAAA,GAAS,IAAIF,GAAJ,CACbL,kBAAA,CACEwB,OAAA,CAAQjB,MADV,EAEEzf,OAAA,CAAQ6jB,WAFV,EAGEzE,QAAA,IAAYO,QAAA,CAASH,IAHvB,CADa,CAAf,CADkB;AAAA,gBAQlBkc,WAAA,GAAcvb,MAAA,CAAOC,gBAAP,IAA2B,GAA3B,GAAiC,GAAjC,GAAuC,CAArD,CARkB;AAAA,gBASlB,MAAMF,UAAA,GAAawb,WAAA,IAAe,GAAf,GAAqB,KAArB,GAA6B,EAAhD,CATkB;AAAA,gBAUlB,IAAIQ,SAAA,GACFzc,MAAA,CAAO0c,MAAP,GACA1c,MAAA,CAAO2c,QADP,GAEAlc,UAFA,GAGA,OAHA,GAIAT,MAAA,CAAO4c,MALT,CAVkB;AAAA,gBAiBlB,IAAI/Y,OAAJ,CAAY,UAAUM,OAAV,EAAmBL,MAAnB,EAA2B;AAAA,oBACrChB,aAAA,CAAc,QAAd,EAAwB2Z,SAAxB,EAAmCl8B,OAAnC,CAAA,CACG+iB,IADH,CACQa,OADR,CAEGJ,CAAAA,KAFH,CAES,UAAU1iB,KAAV,EAAiB;AAAA,wBACtBo7B,SAAA,GACEzc,MAAA,CAAO0c,MAAP,GAAgB1c,MAAA,CAAO2c,QAAvB,GAAkC,OAAlC,GAA4C3c,MAAA,CAAO4c,MADrD,CADsB;AAAA,wBAGtB9Z,aAAA,CAAc,QAAd,EAAwB2Z,SAAxB,EAAmCl8B,OAAnC,CACG+iB,CAAAA,IADH,CACQa,OADR,CAAA,CAEGJ,KAFH,CAESD,MAFT,CAHsB,CAAA;AAAA,qBAF1B,CADqC,CAAA;AAAA,iBAAvC,CAWGR,CAAAA,IAXH,CAWQ,UAAUuZ,WAAV,EAAuB;AAAA,oBAC3B,IAAIA,WAAA,KAAgBzkC,SAApB,EAA+B;AAAA,wBAC7B0rB,MAAA,CAAO,IAAIpoB,KAAJ,CAAU,mBAAV,CAAP,CAD6B,CAAA;AAAA,qBADJ;AAAA,oBAI3ByxB,UAAA,GAAa0P,WAAb,CAJ2B;AAAA,oBAK3BzP,cAAA,GACEpN,MAAA,CAAO0c,MAAP,GACA1c,MAAA,CAAO2c,QADP,GAEAlc,UAFA,GAGA,MAHA,GAIAT,MAAA,CAAO4c,MALT,CAL2B;AAAA,oBAW3B,IAAIr8B,OAAA,CAAQ4iB,gBAAZ,EAA8B;AAAA,wBAC5B,MAAM2Z,WAAA,GACJv8B,OAAA,CAAQ4iB,gBAAR,CAAyBiK,cAAzB,EAAyC,aAAzC,CACAA,IAAAA,cAFF,CAD4B;AAAA,wBAI5B,IACE0P,WAAA,YAAuBvZ,OAAvB,IACAuZ,WAAA,YAAuBjZ,OAFzB,EAGE;AAAA,4BACAuJ,cAAA,GAAiB0P,WAAjB,CADA;AAAA,yBAP0B;AAAA,qBAXH;AAAA,oBAsB3BZ,QAAA,EAtB2B,CAAA;AAAA,iBAX/B,CAmCGnY,CAAAA,KAnCH,CAmCS,UAAUzI,GAAV,EAAe;AAAA,oBACpBwI,MAAA,CACE,IAAIpoB,KAAJ,CACE,CAAC,0BAAD,GAA6B+gC,SAA7B,EAAuC,EAAvC,GAA2CnhB,GAAA,CAAI/e,OAA/C,EAAA,CADF,CADF,CADoB,CAAA;AAAA,iBAnCxB,CAjBkB,CAAA;AAAA,aAApB,MA2DO;AAAA,gBACL2/B,QAAA,EADK,CAAA;AAAA,aAhNgB;AAAA,SAD3B,CAqNGnY,CAAAA,KArNH,CAqNSD,MArNT,CAJ4C,CAAA;AAAA,KAAvC,CAAP,CA3CA;AAAA,CA9LF;AAscA,MAAMyH,QAAA,GAAW,EAAjB,CAtcA;AAwcA,SAASwR,kBAAT,CAA4BC,UAA5B,EAAwC/b,OAAxC,EAAiD1gB,OAAjD,EAA0D;AAAA,IACxD0gB,OAAA,CAAQ/D,MAAR,CAAe7e,IAAf,CAAoB,UAAU0e,KAAV,EAAiB;AAAA,QACnC,IAAIA,KAAA,CAAM5iB,IAAN,KAAe,YAAnB,EAAiC;AAAA,YAC/B,IAAI6iC,UAAA,YAAsBC,KAA1B,EAAiC;AAAA,gBAC/BD,UAAA,CAAWE,aAAX,CAAyB,UAAU1a,UAAV,EAAsB;AAAA,oBAC7C,OAAO2a,kBAAA,CAAmBpgB,KAAnB,EAA0ByF,UAA1B,EAAsCjiB,OAAtC,EAA+C,EAA/C,CAAP,CAD6C;AAAA,iBAA/C,CAD+B,CAAA;AAAA,gBAI/B,OAAO,IAAP,CAJ+B;AAAA,aADF;AAAA,YAO/B,IAAIy8B,UAAA,YAAsBI,GAAtB,IAA6BJ,UAAA,YAAsBK,UAAvD,EAAmE;AAAA,gBACjEL,UAAA,CACGM,SADH,EAEGC,CAAAA,QAFH,CAEY,CAFZ,EAEeC,oBAAA,CAAqBzgB,KAArB,EAA4Bxc,OAA5B,EAAqC,EAArC,CAFf,CADiE,CAAA;AAAA,gBAIjE,OAAO,IAAP,CAJiE;AAAA,aAPpC;AAAA,SADE;AAAA,KAArC,CADwD,CAAA;AAAA,CAxc1D;AA4eA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASk9B,eAAT,CAAyBT,UAAzB,EAAqC/b,OAArC,EAA8C1gB,OAAA,GAAU,EAAxD,EAA4D;AAAA,IACjE,OAAOyjB,UAAA,CAAW/C,OAAX,EAAoB1gB,OAApB,CAAA,CAA6B+iB,IAA7B,CAAkC,UAAUrC,OAAV,EAAmB;AAAA,QAC1D8b,kBAAA,CAAmBC,UAAnB,EAA+B/b,OAA/B,EAAwC1gB,OAAxC,CAD0D,CAAA;AAAA,KAArD,CAAP,CADiE;AAAA,CA5enE;AAkfA,SAASm9B,gBAAT,CAA0BxgB,MAA1B,EAAkCE,GAAlC,EAAuC;AAAA,IACrC,IAAI8c,QAAJ,CADqC;AAAA,IAErChd,MAAA,CAAO7e,IAAP,CAAY,UAAU0e,KAAV,EAAiB;AAAA,QAC3B,IAAIA,KAAA,CAAMxY,EAAN,IAAY6Y,GAAhB,EAAqB;AAAA,YACnB8c,QAAA,GAAWnd,KAAA,CAAM0R,MAAjB,CADmB;AAAA,YAEnB,OAAO,IAAP,CAFmB;AAAA,SADM;AAAA,KAA7B,CAFqC,CAAA;AAAA,IAQrC,OAAOyL,QAAP,CARqC;AAAA,CAlfvC;AA6fA,SAASyD,kBAAT,CAA4BC,QAA5B,EAAsC5Y,UAAtC,EAAkD;AAAA,IAChD,MAAM6Y,MAAA,GAASD,QAAA,CAASC,MAAxB,CADgD;AAAA,IAEhD,IAAIA,MAAJ,EAAY;AAAA,QACV,MAAMxV,EAAA,GAAKyV,UAAA,CAAW;AAAA,YAACD,MAAA,CAAO,CAAP,CAAD;AAAA,YAAYA,MAAA,CAAO,CAAP,CAAZ;AAAA,SAAX,EAAmC7Y,UAAnC,CAAX,CADU;AAAA,QAEV,MAAM+Y,EAAA,GAAKD,UAAA,CAAW;AAAA,YAACD,MAAA,CAAO,CAAP,CAAD;AAAA,YAAYA,MAAA,CAAO,CAAP,CAAZ;AAAA,SAAX,EAAmC7Y,UAAnC,CAAX,CAFU;AAAA,QAGV,OAAO;AAAA,YAACqD,EAAA,CAAG,CAAH,CAAD;AAAA,YAAQA,EAAA,CAAG,CAAH,CAAR;AAAA,YAAe0V,EAAA,CAAG,CAAH,CAAf;AAAA,YAAsBA,EAAA,CAAG,CAAH,CAAtB;AAAA,SAAP,CAHU;AAAA,KAFoC;AAAA,IAOhD,OAAOxC,KAAA,CAAcvW,UAAd,CAA0B4M,CAAAA,SAA1B,EAAP,CAPgD;AAAA,CA7flD;AAugBA,SAASoM,yBAAT,CAAmCzZ,QAAnC,EAA6CqZ,QAA7C,EAAuDr9B,OAAvD,EAAgE;AAAA,IAC9D,MAAM09B,cAAA,GAAiB,IAAIC,QAAJ,CAAa;AAAA,QAClCN,QAAA,EAAUA,QADwB;AAAA,QAElClE,QAAA,EAAUnV,QAAA,CAASmV,QAAT,IAAqBkE,QAAA,CAASlE,QAA9B,IAA0C,GAFlB;AAAA,KAAb,CAAvB,CAD8D;AAAA,IAK9D,MAAMyE,WAAA,GAAcF,cAAA,CAAeG,WAAf,EAApB,CAL8D;AAAA,IAM9D,MAAM5C,QAAA,GAAWyC,cAAA,CAAexC,WAAf,EAAjB,CAN8D;AAAA,IAO9D,MAAMzW,UAAA,GAAauW,KAAA,CAAch7B,OAAA,CAAQykB,UAAR,IAAsB,WAApC,CAAnB,CAP8D;AAAA,IAQ9D,MAAMD,MAAA,GAAS4Y,kBAAA,CAAmBQ,WAAnB,EAAgCnZ,UAAhC,CAAf,CAR8D;AAAA,IAS9D,MAAMqZ,gBAAA,GAAmBrZ,UAAA,CAAW4M,SAAX,EAAzB,CAT8D;AAAA,IAU9D,MAAM0M,OAAA,GAAUH,WAAA,CAAYvO,OAAZ,IAAuB,CAAvC,CAV8D;AAAA,IAW9D,MAAMgK,OAAA,GAAUuE,WAAA,CAAYtO,OAAZ,IAAuB,EAAvC,CAX8D;AAAA;AAa9D,IAAA,MAAM0O,aAAA,GAAgB;AAAA,QACpBC,YAAA,EAAcP,cAAA,CAAehD,eAAf,EADM;AAAA,QAEpBjW,UAAA,EAAYA,UAFQ;AAAA,QAGpBwW,QAAA,EAAU,IAAIiD,QAAJ,CAAa;AAAA,YACrB/B,MAAA,EAAQ2B,gBAAA,GACJK,UAAA,CAAWL,gBAAX,CADI,GAEJ7C,QAAA,CAASmD,SAAT,CAAmB,CAAnB,CAHiB;AAAA,YAIrB5Z,MAAA,EAAQA,MAAA,IAAUyW,QAAA,CAAS5J,SAAT,EAJG;AAAA,YAKrB0M,OAAA,EAASA,OALY;AAAA,YAMrB1c,WAAA,EAAa6X,kBAAA,CAAmBzU,UAAnB,EAA+B4Y,QAAA,CAASlE,QAAxC,CAAA,CAAkD7iC,KAAlD,CACX,CADW,EAEX+iC,OAAA,GAAU,CAFC,CANQ;AAAA,YAUrBF,QAAA,EAAU8B,QAAA,CAASoD,WAAT,CAAqB,CAArB,CAVW;AAAA,SAAb,CAHU;AAAA,KAAtB,CAb8D;AAAA,IA6B9D,IAAIrgC,KAAA,CAAMC,OAAN,CAAc2/B,WAAA,CAAYnY,KAA1B,CAAJ,EAAsC;AAAA,QACpCuY,aAAA,CAAcM,IAAd,GAAqBV,WAAA,CAAYnY,KAAjC,CADoC;AAAA,KAAtC,MAEO;AAAA,QACLuY,aAAA,CAAc/e,GAAd,GAAoB2e,WAAA,CAAYnY,KAAhC,CADK;AAAA,KA/BuD;AAAA,IAkC9D,OAAOuY,aAAP,CAlC8D;AAAA,CAvgBhE;AA4iBA,SAASpB,kBAAT,CAA4B2B,OAA5B,EAAqCtc,UAArC,EAAiDjiB,OAAjD,EAA0D+gB,aAA1D,EAAyE;AAAA,IACvE,MAAMyd,UAAA,GAAa;AAAA,QACjBx6B,EAAA,EAAIu6B,OAAA,CAAQv6B,EADK;AAAA,QAEjBpK,IAAA,EAAM2kC,OAAA,CAAQ3kC,IAFG;AAAA,KAAnB,CADuE;AAAA,IAKvE,MAAMs1B,MAAA,GAASqP,OAAA,CAAQrP,MAAR,IAAkB,EAAjC,CALuE;AAAA,IAMvE,MAAMC,KAAA,GAAQoP,OAAA,CAAQpP,KAAR,IAAiB,EAA/B,CANuE;AAAA,IAOvEqP,UAAA,CAAW,OAAX,CAAA,GAAsBrP,KAAtB,CAPuE;AAAA,IAQvE,MAAM50B,IAAA,GAAOynB,oBAAA,CACXC,UADW,EAEXjiB,OAAA,CAAQqhB,WAAR,IAAuBD,kBAFZ,CAAb,CARuE;AAAA,IAYvE,IAAI+K,OAAJ,CAZuE;AAAA,IAavE,MAAMsS,EAAA,GAAKrT,QAAA,CACToT,UADS,EAET,OAFS,EAGT,kBAHS,EAITjkC,IAJS,EAKTywB,QALS,EAMTjK,aANS,CAAX,CAbuE;AAAA,IAqBvE,IAAIoO,KAAA,CAAM,oBAAN,CAAA,KAAgCt3B,SAApC,EAA+C;AAAA,QAC7Cs0B,OAAA,GAAUf,QAAA,CACRoT,UADQ,EAER,OAFQ,EAGR,oBAHQ,EAIRjkC,IAJQ,EAKRywB,QALQ,EAMRjK,aANQ,CAAV,CAD6C;AAAA,KArBwB;AAAA,IA+BvE,OAAOmO,MAAA,CAAOE,UAAP,IAAqB,MAArB,GACHv3B,SADG,GAEH6mC,gBAAA,CAAkBD,EAAlB,EAAsBtS,OAAtB,CAFJ,CA/BuE;AAAA,CA5iBzE;AAslBA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAAS8Q,oBAAT,CAA8BsB,OAA9B,EAAuCv+B,OAAvC,EAAgD+gB,aAAhD,EAA+D;AAAA,IAC7D,MAAM4d,GAAA,GAAM7c,QAAA,CAASC,aAAT,CAAuB,KAAvB,CAAZ,CAD6D;AAAA,IAE7D4c,GAAA,CAAIC,SAAJ,GAAgB,4BAAhB,CAF6D;AAAA,IAG7DD,GAAA,CAAIzoB,KAAJ,CAAU2oB,QAAV,GAAqB,UAArB,CAH6D;AAAA,IAI7DF,GAAA,CAAIzoB,KAAJ,CAAUsL,KAAV,GAAkB,MAAlB,CAJ6D;AAAA,IAK7Dmd,GAAA,CAAIzoB,KAAJ,CAAUuL,MAAV,GAAmB,MAAnB,CAL6D;AAAA,IAM7D,OAAO,IAAIib,KAAJ,CAAU;AAAA,QACfxO,MAAA,EAAQ,IAAI4Q,MAAJ,CAAW,EAAX,CADO;AAAA,QAEfC,MAAA,CAAOC,UAAP,EAAmB;AAAA,YACjB,MAAM5vB,KAAA,GAAQwtB,kBAAA,CACZ2B,OADY,EAEZS,UAAA,CAAWC,SAAX,CAAqBhd,UAFT,EAGZjiB,OAHY,EAIZ+gB,aAJY,CAAd,CADiB;AAAA,YAOjB4d,GAAA,CAAIzoB,KAAJ,CAAUgpB,eAAV,GAA4B9vB,KAA5B,CAPiB;AAAA,YAQjB,OAAOuvB,GAAP,CARiB;AAAA,SAFJ;AAAA,KAAV,CAAP,CAN6D;AAAA,CAtlB/D;AAonBA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAAS1E,iBAAT,CAA2BjW,QAA3B,EAAqC5E,QAArC,EAA+Cpf,OAA/C,EAAwD;AAAA,IAC7D,OAAO,IAAIsjB,OAAJ,CAAY,UAAUM,OAAV,EAAmBL,MAAnB,EAA2B;AAAA,QAC5CQ,WAAA,CAAYC,QAAZ,EAAsB5E,QAAtB,EAAgCpf,OAAhC,CAAA,CACG+iB,IADH,CACQ,UAAU,CAAC6C,QAAD,EAAWzB,gBAAX,CAAV,EAAwC;AAAA,YAC5C,MAAM6Z,aAAA,GAAgBP,yBAAA,CACpBzZ,QADoB,EAEpB4B,QAFoB,EAGpB5lB,OAHoB,CAAtB,CAD4C;AAAA,YAM5Cg+B,aAAA,CAAc7Z,gBAAd,GAAiCA,gBAAjC,CAN4C;AAAA,YAO5C6Z,aAAA,CAAc3nB,MAAd,GAAuB,IAAI8oB,GAAJ,EAAvB,CAP4C;AAAA,YAQ5Cvb,OAAA,CAAQ,IAAIwb,gBAAJ,CAAqBpB,aAArB,CAAR,CAR4C,CAAA;AAAA,SADhD,CAWGxa,CAAAA,KAXH,CAWSD,MAXT,CAD4C,CAAA;AAAA,KAAvC,CAAP,CAD6D;AAAA,CApnB/D;AAqoBA,SAAS8b,gBAAT,CAA0Brb,QAA1B,EAAoC5E,QAApC,EAA8Cpf,OAA9C,EAAuD;AAAA,IACrD,MAAMwc,KAAA,GAAQ,IAAIsd,eAAJ,CAAoB;AAAA,QAChCwF,SAAA,EAAW,IADqB;AAAA,QAEhCC,OAAA,EAAS,KAFuB;AAAA,KAApB,CAAd,CADqD;AAAA,IAKrDtF,iBAAA,CAAkBjW,QAAlB,EAA4B5E,QAA5B,EAAsCpf,OAAtC,CAAA,CACG+iB,IADH,CACQ,UAAUmL,MAAV,EAAkB;AAAA,QACtBA,MAAA,CAAOjO,GAAP,CAAW,eAAX,EAA4B+D,QAA5B,CADsB,CAAA;AAAA,QAEtBxH,KAAA,CAAM4d,SAAN,CAAgBlM,MAAhB,CAFsB,CAAA;AAAA,KAD1B,CAKG1K,CAAAA,KALH,CAKS,UAAU1iB,KAAV,EAAiB;AAAA,QACtB0b,KAAA,CAAM4d,SAAN,CAAgBviC,SAAhB,CADsB,CAAA;AAAA,KAL1B,CALqD,CAAA;AAAA,IAarD,OAAO2kB,KAAP,CAbqD;AAAA,CAroBvD;AAqpBA,SAASgjB,eAAT,CAAyB/a,UAAzB,EAAqC;AAAA,IACnC,MAAMgb,QAAA,GAAWhb,UAAA,GAAaA,UAAA,CAAWib,OAAX,EAAb,GAAoC,WAArD,CADmC;AAAA,IAEnC,OAAO,CAAC,MAAD,GAASD,QAAA,CAASppC,WAAT,EAAA,CAAuBD,OAAvB,CAA+B,YAA/B,EAA6C,GAA7C,CAAT,EAA2D,CAA3D,CAAP,CAFmC;AAAA,CArpBrC;AA0pBA,SAASupC,iBAAT,CAA2B3b,QAA3B,EAAqC5E,QAArC,EAA+Cpf,OAA/C,EAAwD;AAAA,IACtD,OAAO,IAAIsjB,OAAJ,CAAY,UAAUM,OAAV,EAAmBL,MAAnB,EAA2B;AAAA,QAC5CQ,WAAA,CAAYC,QAAZ,EAAsB5E,QAAtB,EAAgCpf,OAAhC,CAAA,CACG+iB,IADH,CACQ,UAAU,CAAC6C,QAAD,EAAWzB,gBAAX,CAAV,EAAwC;AAAA,YAC5C,MAAM+J,MAAA,GAAS,IAAIyP,QAAJ,CAAa;AAAA,gBAC1BxsB,WAAA,EACEnR,OAAA,CAAQmR,WAAR,KAAwBtZ,SAAxB,GAAoC,IAApC,GAA2CmI,OAAA,CAAQmR,WAF3B;AAAA,gBAG1ByuB,UAAA,EAAY,CAHc;AAAA,gBAI1BxS,WAAA,EAAa,WAJa;AAAA,gBAK1BiQ,QAAA,EAAUzX,QALgB;AAAA,aAAb,CAAf,CAD4C;AAAA,YAQ5CsI,MAAA,CAAO+M,QAAP,GAAkBwC,yBAAA,CAChBzZ,QADgB,EAEhB4B,QAFgB,EAGhB5lB,OAHgB,CAAA,CAIhBi7B,QAJF,CAR4C;AAAA,YAa5C,IAAIj7B,OAAA,CAAQykB,UAAZ,EAAwB;AAAA;AAEtB,gBAAAyJ,MAAA,CAAOzJ,UAAP,GAAoBuW,KAAA,CAAch7B,OAAA,CAAQykB,UAAtB,CAApB,CAFsB;AAAA,aAboB;AAAA,YAiB5C,MAAMob,UAAA,GAAa3R,MAAA,CAAOoM,kBAAP,EAAnB,CAjB4C;AAAA,YAkB5C,IAAInW,gBAAJ,EAAsB;AAAA,gBACpB+J,MAAA,CAAO4M,mBAAP,CAA2B3W,gBAA3B,CADoB,CAAA;AAAA,aAlBsB;AAAA,YAqB5C+J,MAAA,CAAOmM,kBAAP,CAA0B,UAAUyF,SAAV,EAAqBxZ,UAArB,EAAiC7B,UAAjC,EAA6C;AAAA,gBACrE,MAAMsb,YAAA,GAAeP,eAAA,CAAgB/a,UAAhB,CAArB,CADqE;AAAA,gBAErE,IAAIJ,GAAA,GAAMwb,UAAA,CAAWC,SAAX,EAAsBxZ,UAAtB,EAAkC7B,UAAlC,CAAV,CAFqE;AAAA,gBAGrE,IAAIJ,GAAA,CAAI3tB,OAAJ,CAAYqpC,YAAZ,CAAA,IAA6B,CAAC,CAAlC,EAAqC;AAAA,oBACnC,MAAMx5B,IAAA,GAAO2nB,MAAA,CAAOgN,WAAP,EAAA,CAAqB8E,kBAArB,CAAwCF,SAAxC,CAAb,CADmC;AAAA,oBAEnCzb,GAAA,GAAMA,GAAA,CAAIjuB,OAAJ,CAAY2pC,YAAZ,EAA0Bx5B,IAAA,CAAKxO,QAAL,EAA1B,CAAN,CAFmC;AAAA,iBAHgC;AAAA,gBAOrE,OAAOssB,GAAP,CAPqE;AAAA,aAAvE,CArB4C,CAAA;AAAA,YA8B5C6J,MAAA,CAAOjO,GAAP,CAAW,eAAX,EAA4B+D,QAA5B,CA9B4C,CAAA;AAAA,YA+B5CJ,OAAA,CAAQsK,MAAR,CA/B4C,CAAA;AAAA,SADhD,CAkCG1K,CAAAA,KAlCH,CAkCS,UAAU1iB,KAAV,EAAiB;AAAA,YACtByiB,MAAA,CAAOziB,KAAP,CADsB,CAAA;AAAA,SAlC1B,CAD4C,CAAA;AAAA,KAAvC,CAAP,CADsD;AAAA,CA1pBxD;AAosBA,SAASm/B,gBAAT,CAA0Bjc,QAA1B,EAAoC5E,QAApC,EAA8Cpf,OAA9C,EAAuD;AAAA,IACrD,MAAMwc,KAAA,GAAQ,IAAI0jB,SAAJ,EAAd,CADqD;AAAA,IAErDP,iBAAA,CAAkB3b,QAAlB,EAA4B5E,QAA5B,EAAsCpf,OAAtC,CAAA,CACG+iB,IADH,CACQ,UAAUmL,MAAV,EAAkB;AAAA,QACtB1R,KAAA,CAAM4d,SAAN,CAAgBlM,MAAhB,CADsB,CAAA;AAAA,KAD1B,CAAA,CAIG1K,KAJH,CAIS,YAAY;AAAA,QACjBhH,KAAA,CAAM4d,SAAN,CAAgBviC,SAAhB,CADiB,CAAA;AAAA,KAJrB,CAFqD,CAAA;AAAA,IASrD,OAAO2kB,KAAP,CATqD;AAAA,CApsBvD;AAutBA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAAS2jB,mBAAT,CAA6Bnc,QAA7B,EAAuC5E,QAAvC,EAAiDpf,OAAjD,EAA0D;AAAA,IACxD,MAAMogC,SAAA,GAAYH,gBAAA,CAAiBjc,QAAjB,EAA2B5E,QAA3B,EAAqCpf,OAArC,CAAlB,CADwD;AAAA;AAGxD,IAAA,MAAMwc,KAAA,GAAQ,IAAI6jB,UAAJ,CAAe;AAAA,QAC3BnS,MAAA,EAAQ,IAAIoS,MAAJ,CAAW;AAAA,YACjBC,aAAA,EAAe,OADE;AAAA,YAEjBC,SAAA,EAAW/J,SAFM;AAAA,YAGjBrI,OAAA,EAAS,CAACgS,SAAD,CAHQ;AAAA,SAAX,CADmB;AAAA,KAAf,CAAd,CAHwD;AAAA,IAUxD,OAAO5jB,KAAP,CAVwD;AAAA,CAvtB1D;AA0uBA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAAS+e,kBAAT,CAA4BvX,QAA5B,EAAsC5E,QAAtC,EAAgDpf,OAAhD,EAAyD;AAAA,IACvD,MAAMygC,aAAA,GAAgBzgC,OAAA,CAAQykB,UAAR,GAClB,IAAIic,OAAJ,CAAY,EAACC,cAAA,EAAgB3gC,OAAA,CAAQykB,UAAzB,EAAZ,CADkB,GAElB,IAAIic,OAAJ,EAFJ,CADuD;AAAA,IAIvD,MAAM/b,IAAA,GAAOX,QAAA,CAASW,IAAtB,CAJuD;AAAA,IAKvD,MAAMqZ,aAAA,GAAgB,EAAtB,CALuD;AAAA,IAMvD,IAAI,OAAOrZ,IAAP,IAAe,QAAnB,EAA6B;AAAA,QAC3B,MAAM,CAACic,UAAD,CAAe/gB,GAAAA,kBAAA,CACnB8E,IADmB,EAEnB3kB,OAAA,CAAQ6jB,WAFW,EAGnB7jB,OAAA,CAAQ2lB,gBAAR,IAA4B,cAHT,EAInBvG,QAAA,IAAYO,QAAA,CAASH,IAJF,CAArB,CAD2B;AAAA,QAO3B,IAAI,qBAAsB7T,CAAAA,IAAtB,CAA2Bi1B,UAA3B,CAAJ,EAA4C;AAAA,YAC1C,MAAMC,SAAA,GAAY,CAACrc,MAAD,EAASvC,UAAT,EAAqBwC,UAArB,KAAoC;AAAA,gBACpD,MAAMsb,YAAA,GAAeP,eAAA,CAAgB/a,UAAhB,CAArB,CADoD;AAAA,gBAEpD,OAAOmc,UAAA,CAAWxqC,OAAX,CAAmB2pC,YAAnB,EAAiC,CAAA,GAAGvb,MAAA,CAAO3kB,IAAP,CAAY,GAAZ,CAAH,EAAA,CAAjC,CAAP,CAFoD;AAAA,aAAtD,CAD0C;AAAA,YAK1C,MAAMquB,MAAA,GAAS,IAAI4S,YAAJ,CAAiB;AAAA,gBAC9B7C,YAAA,EAAcja,QAAA,CAAS+c,WADO;AAAA,gBAE9B1qB,MAAA,EAAQoqB,aAFsB;AAAA,gBAG9BO,MAAA,EAAQ,CAACxc,MAAD,EAASvC,UAAT,EAAqBwC,UAArB,EAAiC5M,OAAjC,EAA0CopB,OAA1C,KAAsD;AAAA,oBAC5D,MAAMhiB,GAAA,GACJ,OAAO4hB,SAAP,KAAqB,UAArB,GACIA,SAAA,CAAUrc,MAAV,EAAkBvC,UAAlB,EAA8BwC,UAA9B,CADJ,GAEIoc,SAHN,CAD4D;AAAA,oBAK5Dte,aAAA,CAAc,SAAd,EAAyBtD,GAAzB,EAA8Bjf,OAA9B,CACG+iB,CAAAA,IADH,CACSM,IAAD,IAAU;AAAA,wBACd,MAAM5X,QAAA,GACJyiB,MAAA,CACGtJ,SADH,EAEGC,CAAAA,YAFH,CAEgBxB,IAFhB,EAEsB,EAACyB,iBAAA,EAAmBL,UAApB,EAFtB,CADF,CADc;AAAA,wBAMdyJ,MAAA,CAAOgT,WAAP,CAAmBz1B,QAAnB,CANc,CAAA;AAAA,wBAOdoM,OAAA,CAAQpM,QAAR,CAPc,CAAA;AAAA,qBADlB,CAUG+X,CAAAA,KAVH,CAUUL,QAAD,IAAc;AAAA,wBACnB+K,MAAA,CAAOiT,kBAAP,CAA0B3c,MAA1B,CADmB,CAAA;AAAA,wBAEnByc,OAAA,EAFmB,CAAA;AAAA,qBAVvB,CAL4D,CAAA;AAAA,iBAHhC;AAAA,gBAuB9BG,QAAA,EAAUC,IAvBoB;AAAA,aAAjB,CAAf,CAL0C;AAAA,YA8B1CnT,MAAA,CAAOjO,GAAP,CAAW,eAAX,EAA4B+D,QAA5B,CA9B0C,CAAA;AAAA,YA+B1C,OAAOkK,MAAP,CA/B0C;AAAA,SAPjB;AAAA,QAwC3B,MAAMA,MAAA,GAAS,IAAI4S,YAAJ,CAAiB;AAAA,YAC9B7C,YAAA,EAAcja,QAAA,CAAS+c,WADO;AAAA,YAE9B1qB,MAAA,EAAQoqB,aAFsB;AAAA,YAG9BxhB,GAAA,EAAK2hB,UAHyB;AAAA,YAI9BI,MAAA,EAAQ,CAACxc,MAAD,EAASvC,UAAT,EAAqBwC,UAArB,EAAiC5M,OAAjC,EAA0CopB,OAA1C,KAAsD;AAAA,gBAC5D1e,aAAA,CAAc,SAAd,EAAyBqe,UAAzB,EAAqC5gC,OAArC,CACG+iB,CAAAA,IADH,CACSM,IAAD,IAAU;AAAA,oBACd,MAAM5X,QAAA,GACJyiB,MAAA,CACGtJ,SADH,EAEGC,CAAAA,YAFH,CAEgBxB,IAFhB,EAEsB,EAACyB,iBAAA,EAAmBL,UAApB,EAFtB,CADF,CADc;AAAA,oBAMdyJ,MAAA,CAAOgT,WAAP,CAAmBz1B,QAAnB,CANc,CAAA;AAAA,oBAOdoM,OAAA,CAAQpM,QAAR,CAPc,CAAA;AAAA,iBADlB,CAUG+X,CAAAA,KAVH,CAUUL,QAAD,IAAc;AAAA,oBACnB+K,MAAA,CAAOiT,kBAAP,CAA0B3c,MAA1B,CADmB,CAAA;AAAA,oBAEnByc,OAAA,EAFmB,CAAA;AAAA,iBAVvB,CAD4D,CAAA;AAAA,aAJhC;AAAA,SAAjB,CAAf,CAxC2B;AAAA,QA6D3B,OAAO/S,MAAP,CA7D2B;AAAA,KAN0B;AAAA,IAqEvD8P,aAAA,CAAcvyB,QAAd,GAAyBg1B,aAAA,CAAc5b,YAAd,CAA2BF,IAA3B,EAAiC,EACxDG,iBAAA,EAAmBwc,iBAAA,MAAuB,WADc,EAAjC,CAAzB,CArEuD;AAAA,IAyEvD,MAAMpT,MAAA,GAAS,IAAI4S,YAAJ,CACbjnC,MAAA,CAAOgsB,MAAP,CACE;AAAA,QACEoY,YAAA,EAAcja,QAAA,CAAS+c,WADzB;AAAA,QAEE1qB,MAAA,EAAQoqB,aAFV;AAAA,KADF,EAKEzC,aALF,CADa,CAAf,CAzEuD;AAAA,IAkFvD9P,MAAA,CAAOjO,GAAP,CAAW,eAAX,EAA4B+D,QAA5B,CAlFuD,CAAA;AAAA,IAmFvD,OAAoCkK,MAApC,CAnFuD;AAAA,CA1uBzD;AAg0BA,SAASqT,iBAAT,CAA2Bvd,QAA3B,EAAqC5E,QAArC,EAA+Cpf,OAA/C,EAAwD;AAAA,IACtD,OAAO,IAAI65B,WAAJ,CAAgB;AAAA,QACrByF,SAAA,EAAW,IADU;AAAA,QAErBpR,MAAA,EAAQqN,kBAAA,CAAmBvX,QAAnB,EAA6B5E,QAA7B,EAAuCpf,OAAvC,CAFa;AAAA,QAGrBu/B,OAAA,EAAS,KAHY;AAAA,KAAhB,CAAP,CADsD;AAAA,CAh0BxD;AAw0BA,SAASiC,oBAAT,CAA8BjD,OAA9B,EAAuC/hB,KAAvC,EAA8CuE,aAA9C,EAA6D;AAAA,IAC3D,IAAIxmB,IAAA,GAAO,IAAX,CAD2D;AAAA,IAE3D,OAAO,UAAUozB,KAAV,EAAiB;AAAA,QACtB,IACE4Q,OAAA,CAAQpP,KAAR,IACA,gBAAA,IAAoBoP,OAAA,CAAQpP,KAD5B,IAEAxB,KAAA,CAAMqR,UAAN,CAAiBC,SAAjB,CAA2B1kC,IAA3B,KAAoCA,IAHtC,EAIE;AAAA,YACAA,IAAA,GAAOozB,KAAA,CAAMqR,UAAN,CAAiBC,SAAjB,CAA2B1kC,IAAlC,CADA;AAAA,YAEA,OAAOwmB,aAAA,CAAcwd,OAAA,CAAQv6B,EAAtB,CAAP,CAFA;AAAA,YAGAy9B,2BAAA,CAA4BlD,OAA5B,EAAqC/hB,KAArC,EAA4CjiB,IAA5C,EAAkDwmB,aAAlD,CAHA,CAAA;AAAA,SALoB;AAAA,KAAxB,CAF2D;AAAA,CAx0B7D;AAu1BA,SAAS0gB,2BAAT,CAAqClD,OAArC,EAA8C/hB,KAA9C,EAAqDjiB,IAArD,EAA2DwmB,aAA3D,EAA0E;AAAA,IACxE,MAAMoL,OAAA,GAAUf,QAAA,CACdmT,OADc,EAEd,OAFc,EAGd,gBAHc,EAIdhkC,IAJc,EAKdywB,QALc,EAMdjK,aANc,CAAhB,CADwE;AAAA,IASxEvE,KAAA,CAAMsW,UAAN,CAAiB3G,OAAjB,CATwE,CAAA;AAAA,CAv1B1E;AAm2BA,SAASuV,gBAAT,CAA0BllB,KAA1B,EAAiCmlB,UAAjC,EAA6C;AAAA,IAC3C,SAAShG,QAAT,GAAoB;AAAA,QAClB,MAAMjb,OAAA,GAAUihB,UAAA,CAAWjoC,GAAX,CAAe,cAAf,CAAhB,CADkB;AAAA,QAElB,IAAI,CAACgnB,OAAL,EAAc;AAAA,YACZ,OADY;AAAA,SAFI;AAAA,QAKlB,MAAMoN,YAAA,GAAepR,WAAA,CAAYgE,OAAA,CAAQ/D,MAApB,CAArB,CALkB;AAAA,QAMlB,MAAMilB,mBAAA,GAAsBplB,KAAA,CAAM9iB,GAAN,CAAU,eAAV,CAA5B,CANkB;AAAA,QAOlB,MAAM6lC,OAAA,GAAUzR,YAAA,CACbxoB,MADa,CACN,UAAUu8B,WAAV,EAAuB;AAAA,YAC7B,OAAOD,mBAAA,CAAoB9N,QAApB,CAA6B+N,WAAA,CAAY79B,EAAzC,CAAP,CAD6B;AAAA,SADjB,CAIblG,CAAAA,IAJa,CAIR,UAAU+jC,WAAV,EAAuB;AAAA,YAC3B,OACE,CAACA,WAAA,CAAY3S,MAAb,IACA,CAAC2S,WAAA,CAAY3S,MAAZ,CAAmBE,UADpB,IAEAyS,WAAA,CAAY3S,MAAZ,CAAmBE,UAAnB,KAAkC,SAHpC,CAD2B;AAAA,SAJf,CAAhB,CAPkB;AAAA,QAkBlB,IAAI5S,KAAA,CAAM9iB,GAAN,CAAU,SAAV,CAAA,KAAyB6lC,OAA7B,EAAsC;AAAA,YACpC/iB,KAAA,CAAMslB,UAAN,CAAiBvC,OAAjB,CADoC,CAAA;AAAA,SAlBpB;AAAA,KADuB;AAAA,IAuB3C/iB,KAAA,CAAMulB,EAAN,CAAS,QAAT,EAAmBpG,QAAnB,CAvB2C,CAAA;AAAA,IAwB3CA,QAAA,EAxB2C,CAAA;AAAA,CAn2B7C;AA83BO,SAASqG,UAAT,CAAoBthB,OAApB,EAA6BtB,QAA7B,EAAuCmf,OAAvC,EAAgDv+B,OAAhD,EAAyD;AAAA,IAC9D,MAAM+gB,aAAA,GAAgBD,gBAAA,CAAiBJ,OAAjB,CAAtB,CAD8D;AAAA,IAE9D,MAAMuhB,QAAA,GAAWvhB,OAAA,CAAQ/D,MAAzB,CAF8D;AAAA,IAG9D,MAAM/iB,IAAA,GAAO2kC,OAAA,CAAQ3kC,IAArB,CAH8D;AAAA,IAK9D,MAAMoK,EAAA,GAAKu6B,OAAA,CAAQrQ,MAAR,IAAkBiP,gBAAA,CAAiB8E,QAAjB,EAA2B1D,OAAA,CAAQ1hB,GAAnC,CAA7B,CAL8D;AAAA,IAM9D,MAAMmH,QAAA,GAAWtD,OAAA,CAAQ0N,OAAR,CAAgBpqB,EAAhB,CAAjB,CAN8D;AAAA,IAO9D,IAAIwY,KAAJ,CAP8D;AAAA,IAQ9D,IAAI5iB,IAAA,IAAQ,YAAZ,EAA0B;AAAA,QACxB4iB,KAAA,GAAQygB,oBAAA,CAAqBsB,OAArB,EAA8Bv+B,OAA9B,EAAuC+gB,aAAvC,CAAR,CADwB;AAAA,KAA1B,MAEO,IAAIiD,QAAA,CAASpqB,IAAT,IAAiB,QAArB,EAA+B;AAAA,QACpC4iB,KAAA,GAAQ6iB,gBAAA,CAAiBrb,QAAjB,EAA2B5E,QAA3B,EAAqCpf,OAArC,CAAR,CADoC;AAAA,KAA/B,MAEA,IAAIgkB,QAAA,CAASpqB,IAAT,IAAiB,QAArB,EAA+B;AAAA,QACpC4iB,KAAA,GAAQyjB,gBAAA,CAAiBjc,QAAjB,EAA2B5E,QAA3B,EAAqCpf,OAArC,CAAR,CADoC;AAAA,QAEpCwc,KAAA,CAAMslB,UAAN,CACEvD,OAAA,CAAQrP,MAAR,GAAiBqP,OAAA,CAAQrP,MAAR,CAAeE,UAAf,KAA8B,MAA/C,GAAwD,IAD1D,CAFoC,CAAA;AAAA,QAKpC5S,KAAA,CAAMulB,EAAN,CAAS,WAAT,EAAsBP,oBAAA,CAAqBjD,OAArB,EAA8B/hB,KAA9B,EAAqCuE,aAArC,CAAtB,CALoC,CAAA;AAAA,KAA/B,MAMA,IAAIiD,QAAA,CAASpqB,IAAT,IAAiB,SAArB,EAAgC;AAAA,QACrC4iB,KAAA,GAAQ+kB,iBAAA,CAAkBvd,QAAlB,EAA4B5E,QAA5B,EAAsCpf,OAAtC,CAAR,CADqC;AAAA,KAAhC,MAEA,IAAIgkB,QAAA,CAASpqB,IAAT,IAAiB,YAAjB,IAAiC2kC,OAAA,CAAQ3kC,IAAR,IAAgB,WAArD,EAAkE;AAAA,QACvE,MAAMsoC,cAAA,GAAiB/B,mBAAA,CAAoBnc,QAApB,EAA8B5E,QAA9B,EAAwCpf,OAAxC,CAAvB,CADuE;AAAA,QAEvEwc,KAAA,GAAQ0lB,cAAR,CAFuE;AAAA,QAGvEA,cAAA,CAAe/H,SAAf,EAA2B4H,CAAAA,EAA3B,CAA8B,kBAA9B,EAAkD,UAAUpU,KAAV,EAAiB;AAAA,YACjE,MAAMhJ,IAAA,GAAOgJ,KAAA,CAAMhJ,IAAnB,CADiE;AAAA,YAEjEA,IAAA,CAAK1C,UAAL,GAAkBkgB,kBAAA,CAChBniC,OAAA,CAAQykB,UAAR,IAAsB,WADN,EAEhBkJ,KAAA,CAAM1L,UAFU,EAGhBmgB,SAAA,CAAUzU,KAAA,CAAMnJ,MAAhB,CAHgB,EAIhB,GAJgB,CAAlB,CAFiE;AAAA,YAQjE,MAAMjqB,IAAA,GAAOynB,oBAAA,CACX2L,KAAA,CAAM1L,UADK,EAEXjiB,OAAA,CAAQqhB,WAAR,IAAuBD,kBAFZ,CAAb,CARiE;AAAA,YAYjEuD,IAAA,CAAKgT,QAAL,GAAgB3T,QAAA,CAAS2T,QAAzB,CAZiE;AAAA,YAajEhT,IAAA,CAAKqU,IAAL,GACE,CACA5N,GAAAA,QAAA,CACEmT,OADF,EAEE,OAFF,EAGE,wBAHF,EAIEhkC,IAJF,EAKEywB,QALF,EAMEjK,aANF,CAFF,CAbiE;AAAA,YAuBjE4D,IAAA,CAAK0S,KAAL,GAAajM,QAAA,CACXmT,OADW,EAEX,OAFW,EAGX,kCAHW,EAIXhkC,IAJW,EAKXywB,QALW,EAMXjK,aANW,CAAb,CAvBiE;AAAA,YA+BjE4D,IAAA,CAAKyS,KAAL,GAAa,EAAb,CA/BiE;AAAA,YAgCjEzS,IAAA,CAAKwH,OAAL,GAAe,GAAf,CAhCiE;AAAA,YAiCjExH,IAAA,CAAK6S,cAAL,GAAsBpM,QAAA,CACpBmT,OADoB,EAEpB,OAFoB,EAGpB,2BAHoB,EAIpBhkC,IAJoB,EAKpBywB,QALoB,EAMpBjK,aANoB,CAAtB,CAjCiE;AAAA,YAyCjE4D,IAAA,CAAK8S,WAAL,GAAmBrM,QAAA,CACjBmT,OADiB,EAEjB,OAFiB,EAGjB,wBAHiB,EAIjBhkC,IAJiB,EAKjBywB,QALiB,EAMjBjK,aANiB,CAAnB,CAzCiE;AAAA,YAiDjE4D,IAAA,CAAK+S,WAAL,GAAmBtM,QAAA,CACjBmT,OADiB,EAEjB,OAFiB,EAGjB,wBAHiB,EAIjBhkC,IAJiB,EAKjBywB,QALiB,EAMjBjK,aANiB,CAAnB,CAjDiE;AAAA,SAAnE,CAHuE,CAAA;AAAA,QA6DvEvE,KAAA,CAAMslB,UAAN,CACEvD,OAAA,CAAQrP,MAAR,GAAiBqP,OAAA,CAAQrP,MAAR,CAAeE,UAAf,KAA8B,MAA/C,GAAwD,IAD1D,CA7DuE,CAAA;AAAA,KApBX;AAAA,IAqF9D,MAAMiT,UAAA,GAAar+B,EAAnB,CArF8D;AAAA,IAsF9D,IAAIwY,KAAJ,EAAW;AAAA,QACTA,KAAA,CAAMyD,GAAN,CAAU,eAAV,EAA2BoiB,UAA3B,CADS,CAAA;AAAA,KAtFmD;AAAA,IAyF9D,OAAO7lB,KAAP,CAzF8D;AAAA,CA93BhE;AAi+BA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,SAAS8lB,YAAT,CAAsB5hB,OAAtB,EAA+BihB,UAA/B,EAA2CviB,QAA3C,EAAqDpf,OAArD,EAA8D;AAAA,IAC5D,MAAMuiC,QAAA,GAAW,EAAjB,CAD4D;AAAA,IAG5D,IAAIC,IAAA,GAAO,IAAX,CAH4D;AAAA,IAI5D,IAAIb,UAAA,YAAsB9E,GAA1B,EAA+B;AAAA,QAC7B2F,IAAA,GAAOb,UAAA,CAAWc,OAAX,EAAP,CAD6B;AAAA,QAE7B,IAAI,CAACD,IAAA,CAAKE,KAAL,EAAD,IAAiB,CAACF,IAAA,CAAKG,WAAL,EAAlB,IAAwC,CAACH,IAAA,CAAKlJ,cAAL,EAA7C,EAAoE;AAAA,YAClE,MAAM7U,UAAA,GAAazkB,OAAA,CAAQykB,UAAR,GACfuW,KAAA,CAAch7B,OAAA,CAAQykB,UAAtB,CADe,GAEf+d,IAAA,CAAKxH,aAAL,EAFJ,CADkE;AAAA,YAIlEwH,IAAA,GAAO,IAAII,IAAJ,CACL/oC,MAAA,CAAOgsB,MAAP,CAAc2c,IAAA,CAAK7T,aAAL,EAAd,EAAoC;AAAA,gBAClCkU,aAAA,EACEzhB,kBAAA,CAAmB,CAAnB,CAAA,GAAwB0a,eAAA,CAAgBrX,UAAA,CAAWoX,QAAX,EAAhB,CAFQ;AAAA,gBAGlCpX,UAAA,EAAYzkB,OAAA,CAAQykB,UAAR,IAAsB+d,IAAA,CAAKxH,aAAL,EAHA;AAAA,aAApC,CADK,CAAP,CAJkE;AAAA,YAWlE2G,UAAA,CAAWmB,OAAX,CAAmBN,IAAnB,CAXkE,CAAA;AAAA,SAFvC;AAAA,QAgB7B,IAAI,YAAY9hB,OAAZ,IAAuB,CAAC8hB,IAAA,CAAKJ,SAAL,EAA5B,EAA8C;AAAA,YAC5CI,IAAA,CAAKO,SAAL,CAAexF,UAAA,CAAW7c,OAAA,CAAQpc,MAAnB,EAA2Bk+B,IAAA,CAAKxH,aAAL,EAA3B,CAAf,CAD4C,CAAA;AAAA,SAhBjB;AAAA,QAmB7B,IAAI,UAAUta,OAAV,IAAqB8hB,IAAA,CAAKQ,OAAL,EAAmBnrC,KAAAA,SAA5C,EAAuD;AAAA,YACrD2qC,IAAA,CAAKS,aAAL,CACE7hB,kBAAA,CAAmB,CAAnB,CAAA,GACE0a,eAAA,CAAgB0G,IAAA,CAAKxH,aAAL,EAAA,CAAqBa,QAArB,EAAhB,CADF,GAEEzmC,IAAA,CAAKoS,GAAL,CAAS,CAAT,EAAYkZ,OAAA,CAAQnmB,IAApB,CAHJ,CADqD,CAAA;AAAA,SAnB1B;AAAA,QA0B7B,IAAI,CAACioC,IAAA,CAAKJ,SAAL,EAAD,IAAqBI,IAAA,CAAKQ,OAAL,EAAmBnrC,KAAAA,SAA5C,EAAuD;AAAA,YACrD2qC,IAAA,CAAKU,GAAL,CAASV,IAAA,CAAKxH,aAAL,EAAA,CAAqB3J,SAArB,EAAT,EAA2C;AAAA,gBACzC8R,OAAA,EAAS,IADgC;AAAA,gBAEzCllB,IAAA,EAAM0jB,UAAA,CAAWyB,OAAX,EAFmC;AAAA,aAA3C,CADqD,CAAA;AAAA,SA1B1B;AAAA,KAJ6B;AAAA,IAqC5DzB,UAAA,CAAW1hB,GAAX,CAAe,cAAf,EAA+BS,OAA/B,CArC4D,CAAA;AAAA,IAsC5DihB,UAAA,CAAW1hB,GAAX,CAAe,iBAAf,EAAkC;AAAA,QAACb,QAAD;AAAA,QAAWpf,OAAX;AAAA,KAAlC,CAtC4D,CAAA;AAAA,IAwC5D,MAAMiiC,QAAA,GAAWvhB,OAAA,CAAQ/D,MAAzB,CAxC4D;AAAA,IAyC5D,IAAI0mB,QAAA,GAAW,EAAf,CAzC4D;AAAA,IA2C5D,IAAI7mB,KAAJ,EAAW6lB,UAAX,EAAuBr+B,EAAvB,CA3C4D;AAAA,IA4C5D,KAAK,IAAI7O,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAKyjB,QAAA,CAASvsC,MAAzB,EAAiCP,CAAA,GAAIqpB,EAA1C,EAA8C,EAAErpB,CAAhD,EAAmD;AAAA,QACjD,MAAMopC,OAAA,GAAU0D,QAAA,CAAS9sC,CAAT,CAAhB,CADiD;AAAA,QAEjD,MAAMyE,IAAA,GAAO2kC,OAAA,CAAQ3kC,IAArB,CAFiD;AAAA,QAGjD,IAAIA,IAAA,IAAQ,SAAZ,EAAuB;AAAA;AAGrB;AAAA,YAAA+e,OAAA,CAAQ2qB,KAAR,CAAc,CAAC,OAAD,GAAUnuC,CAAV,EAAY,QAAZ,GAAsByE,IAAtB,EAA2B,eAA3B,CAAd,CAHqB,CAAA;AAAA,YAIrB,SAJqB;AAAA,SAAvB,MAKO;AAAA,YACLoK,EAAA,GAAKu6B,OAAA,CAAQrQ,MAAR,IAAkBiP,gBAAA,CAAiB8E,QAAjB,EAA2B1D,OAAA,CAAQ1hB,GAAnC,CAAvB,CADK;AAAA;AAGL,YAAA,IAAI,CAAC7Y,EAAD,IAAOA,EAAA,IAAMq+B,UAAjB,EAA6B;AAAA,gBAC3B,IAAIgB,QAAA,CAAS3tC,MAAb,EAAqB;AAAA,oBACnB6sC,QAAA,CAAS/nC,IAAT,CACE+oC,aAAA,CACE/mB,KADF,EAEE6mB,QAFF,EAGE3iB,OAHF,EAIEtB,QAJF,EAKEuiB,UALF,EAME3hC,OANF,CADF,CADmB,CAAA;AAAA,oBAWnBqjC,QAAA,GAAW,EAAX,CAXmB;AAAA,iBADM;AAAA,gBAe3B7mB,KAAA,GAAQwlB,UAAA,CAAWthB,OAAX,EAAoBtB,QAApB,EAA8Bmf,OAA9B,EAAuCv+B,OAAvC,CAAR,CAf2B;AAAA,gBAgB3B,IACE,EAAEwc,KAAA,YAAiBqd,WAAjB,IAAgCrd,KAAA,YAAiBsd,eAAjD,CADJ,EAEE;AAAA,oBACAuJ,QAAA,GAAW,EAAX,CADA;AAAA,iBAlByB;AAAA,gBAqB3BhB,UAAA,GAAa7lB,KAAA,CAAM9iB,GAAN,CAAU,eAAV,CAAb,CArB2B;AAAA,aAHxB;AAAA,YA0BL2pC,QAAA,CAAS7oC,IAAT,CAAc+jC,OAAA,CAAQv6B,EAAtB,CA1BK,CAAA;AAAA,SAR0C;AAAA,KA5CS;AAAA,IAiF5Du+B,QAAA,CAAS/nC,IAAT,CACE+oC,aAAA,CAAc/mB,KAAd,EAAqB6mB,QAArB,EAA+B3iB,OAA/B,EAAwCtB,QAAxC,EAAkDuiB,UAAlD,EAA8D3hC,OAA9D,CADF,CAjF4D,CAAA;AAAA,IAoF5D,OAAOsjB,OAAA,CAAQkgB,GAAR,CAAYjB,QAAZ,CAAP,CApF4D;AAAA,CAj+B9D;AAymCA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASkB,KAAT,CAAeC,mBAAf,EAAoCxtB,KAApC,EAA2ClW,OAAA,GAAU,EAArD,EAAyD;AAAA,IAC9D,IAAIkkB,OAAJ,CAD8D;AAAA;AAG9D,IAAA,IAAIyd,UAAJ,CAH8D;AAAA,IAI9D,IACE,OAAO+B,mBAAP,KAA+B,QAA/B,IACAA,mBAAA,YAA+BC,WAFjC,EAGE;AAAA,QACAhC,UAAA,GAAa,IAAI9E,GAAJ,CAAQ,EACnB+G,MAAA,EAAQF,mBADW,EAAR,CAAb,CADA;AAAA,KAHF,MAOO;AAAA,QACL/B,UAAA,GAAa+B,mBAAb,CADK;AAAA,KAXuD;AAAA,IAe9D,IAAI,OAAOxtB,KAAP,KAAiB,QAArB,EAA+B;AAAA,QAC7B,MAAMkJ,QAAA,GAAWlJ,KAAA,CAAM2I,UAAN,CAAiB,OAAjB,CACbc,GAAAA,QAAA,CAASH,IADI,GAEbE,iBAAA,CAAkBxJ,KAAlB,EAAyBlW,OAAA,CAAQ6jB,WAAjC,CAFJ,CAD6B;AAAA,QAI7B7jB,OAAA,GAAUu5B,eAAA,CAAgBna,QAAhB,EAA0Bpf,OAA1B,CAAV,CAJ6B;AAAA,QAM7BkkB,OAAA,GAAU,IAAIZ,OAAJ,CAAY,UAAUM,OAAV,EAAmBL,MAAnB,EAA2B;AAAA,YAC/CE,UAAA,CAAWvN,KAAX,EAAkBlW,OAAlB,EACG+iB,IADH,CACQ,UAAUrC,OAAV,EAAmB;AAAA,gBACvB4hB,YAAA,CAAa5hB,OAAb,EAAsBihB,UAAtB,EAAkCviB,QAAlC,EAA4Cpf,OAA5C,CAAA,CACG+iB,IADH,CACQ,YAAY;AAAA,oBAChBa,OAAA,CAAQ+d,UAAR,CADgB,CAAA;AAAA,iBADpB,CAIGne,CAAAA,KAJH,CAISD,MAJT,CADuB,CAAA;AAAA,aAD3B,CAQGC,CAAAA,KARH,CAQS,UAAUzI,GAAV,EAAe;AAAA,gBACpBwI,MAAA,CAAO,IAAIpoB,KAAJ,CAAU,CAAC,eAAD,GAAkB+a,KAAlB,EAAwB,EAAxB,GAA4B6E,GAAA,CAAI/e,OAAhC,EAAA,CAAV,CAAP,CADoB,CAAA;AAAA,aARxB,CAD+C,CAAA;AAAA,SAAvC,CAAV,CAN6B;AAAA,KAA/B,MAmBO;AAAA,QACLkoB,OAAA,GAAU,IAAIZ,OAAJ,CAAY,UAAUM,OAAV,EAAmBL,MAAnB,EAA2B;AAAA,YAC/C+e,YAAA,CACEpsB,KADF,EAEEyrB,UAFF,EAGE,CAAC3hC,OAAA,CAAQof,QAAT,IAAqBpf,OAAA,CAAQof,QAAR,CAAiBP,UAAjB,CAA4B,OAA5B,CAArB,GACIc,QAAA,CAASH,IADb,GAEIE,iBAAA,CAAkB1f,OAAA,CAAQof,QAA1B,EAAoCpf,OAAA,CAAQ6jB,WAA5C,CALN,EAME7jB,OANF,CAQG+iB,CAAAA,IARH,CAQQ,YAAY;AAAA,gBAChBa,OAAA,CAAQ+d,UAAR,CADgB,CAAA;AAAA,aARpB,CAWGne,CAAAA,KAXH,CAWSD,MAXT,CAD+C,CAAA;AAAA,SAAvC,CAAV,CADK;AAAA,KAlCuD;AAAA,IAmD9D,OAAOW,OAAP,CAnD8D;AAAA,CAzmChE;AAgrCA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASqf,aAAT,CACL/mB,KADK,EAEL6mB,QAFK,EAGL3iB,OAHK,EAILtB,QAJK,EAKLuiB,UALK,EAML3hC,OAAA,GAAU,EANL,EAOL;AAAA,IACA,IAAI+9B,OAAA,GAAU,EAAd,CADA;AAAA,IAEA,IAAI1E,OAAA,GAAU,CAAd,CAFA;AAAA,IAGA,MAAM4I,QAAA,GAAWvhB,OAAA,CAAQ/D,MAAzB,CAHA;AAAA,IAIA,KAAK,IAAIxnB,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAKyjB,QAAA,CAASvsC,MAAzB,EAAiCP,CAAA,GAAIqpB,EAA1C,EAA8C,EAAErpB,CAAhD,EAAmD;AAAA,QACjD,MAAMopC,OAAA,GAAU0D,QAAA,CAAS9sC,CAAT,CAAhB,CADiD;AAAA,QAEjD,IAAIkuC,QAAA,CAAS3sC,OAAT,CAAiB6nC,OAAA,CAAQv6B,EAAzB,CAAA,KAAiC,CAAC,CAAtC,EAAyC;AAAA,YACvC+5B,OAAA,GAAU3oC,IAAA,CAAKqR,GAAL,CAAS,SAAa83B,IAAAA,OAAb,GAAuBA,OAAA,CAAQlP,OAA/B,GAAyC,CAAlD,EAAqD0O,OAArD,CAAV,CADuC;AAAA,YAEvC1E,OAAA,GAAUjkC,IAAA,CAAKsR,GAAL,CAAS,SAAa63B,IAAAA,OAAb,GAAuBA,OAAA,CAAQjP,OAA/B,GAAyC,EAAlD,EAAsD+J,OAAtD,CAAV,CAFuC;AAAA,SAFQ;AAAA,KAJnD;AAAA,IAWA,OAAO,IAAI/V,OAAJ,CAAY,UAAUM,OAAV,EAAmBL,MAAnB,EAA2B;AAAA,QAC5C,MAAM8S,QAAA,GAAW,YAAY;AAAA,YAC3B,MAAMnI,MAAA,GAAS1R,KAAA,CAAM2d,SAAN,EAAf,CAD2B;AAAA,YAE3B,IAAI,CAACjM,MAAD,IAAWA,MAAA,CAAO2V,QAAP,EAAsB,KAAA,OAArC,EAA8C;AAAA,gBAC5CtgB,MAAA,CACE,IAAIpoB,KAAJ,CACE,kCAAA,GAAqCqhB,KAAA,CAAM9iB,GAAN,CAAU,eAAV,CADvC,CADF,CAD4C,CAAA;AAAA,gBAM5C,OAN4C;AAAA,aAFnB;AAAA,YAU3B,IAAI,aAAiBw0B,IAAAA,MAArB,EAA6B;AAAA,gBAC3B,MAAM+M,QAAA;AACyF,gBAC3F/M,MAD2F,CAE3FgN,WAF2F,EAD/F,CAD2B;AAAA,gBAK3B,IAAID,QAAJ,EAAc;AAAA,oBACZ,MAAM6I,aAAA,GAAgB7I,QAAA,CAASI,UAAT,EAAtB,CADY;AAAA,oBAEZ,IAAI0C,OAAA,GAAU,CAAV,IAAe+F,aAAA,GAAgB,CAAnC,EAAsC;AAAA,wBACpCtnB,KAAA,CAAM8e,gBAAN,CACElmC,IAAA,CAAKqR,GAAL,CACE2b,oBAAA,CACEhtB,IAAA,CAAKsR,GAAL,CAAS,CAAT,EAAYq3B,OAAA,GAAU,KAAtB,CADF,EAEE3c,kBAFF,CADF,EAKEgB,oBAAA,CACEhtB,IAAA,CAAKsR,GAAL,CAAS,CAAT,EAAYo9B,aAAA,GAAgB,KAA5B,CADF,EAEE7I,QAAA,CAAS3B,cAAT,EAFF,CALF,CADF,CADoC,CAAA;AAAA,qBAF1B;AAAA,oBAgBZ,IAAID,OAAA,GAAU,EAAd,EAAkB;AAAA,wBAChB7c,KAAA,CAAMunB,gBAAN,CACE3hB,oBAAA,CAAqBiX,OAArB,EAA8BjY,kBAA9B,CADF,CADgB,CAAA;AAAA,qBAhBN;AAAA,iBALa;AAAA,aAA7B,MA2BO;AAAA,gBACL,IAAI2c,OAAA,GAAU,CAAd,EAAiB;AAAA,oBACfvhB,KAAA,CAAM8e,gBAAN,CACElZ,oBAAA,CACEhtB,IAAA,CAAKsR,GAAL,CAAS,CAAT,EAAYq3B,OAAA,GAAU,KAAtB,CADF,EAEE3c,kBAFF,CADF,CADe,CAAA;AAAA,iBADZ;AAAA,aArCoB;AAAA,YA+C3B,IACE8M,MAAA,YAAkB4S,YAAlB,IACA5S,MAAA,YAAkBkR,gBAFpB,EAGE;AAAA,gBACA5F,UAAA,CAEIhd,KAFJ,EAIEkE,OAJF,EAKE2iB,QALF,EAMExpC,MAAA,CAAOgsB,MAAP,CAAc,EAACzG,QAAA,EAAUA,QAAX,EAAd,EAAoCpf,OAApC,CANF,CAAA,CAQG+iB,IARH,CAQQ,YAAY;AAAA,oBAChB2e,gBAAA,CAAiBllB,KAAjB,EAAwBmlB,UAAxB,CADgB,CAAA;AAAA,oBAEhB/d,OAAA,EAFgB,CAAA;AAAA,iBARpB,CAYGJ,CAAAA,KAZH,CAYSD,MAZT,CADA,CAAA;AAAA,aAHF,MAiBO;AAAA,gBACLK,OAAA,EADK,CAAA;AAAA,aAhEoB;AAAA,SAA7B,CAD4C;AAAA,QAsE5CpH,KAAA,CAAMyD,GAAN,CAAU,eAAV,EAA2BojB,QAA3B,CAtE4C,CAAA;AAAA,QAuE5C,MAAM1mB,MAAA,GAASglB,UAAA,CAAW5E,SAAX,EAAf,CAvE4C;AAAA,QAwE5C,IAAIpgB,MAAA,CAAOqnB,QAAP,EAAA,CAAkBttC,OAAlB,CAA0B8lB,KAA1B,CAAA,KAAqC,CAAC,CAA1C,EAA6C;AAAA,YAC3CG,MAAA,CAAOniB,IAAP,CAAYgiB,KAAZ,CAD2C,CAAA;AAAA,SAxED;AAAA,QA4E5C,IAAIA,KAAA,CAAM2d,SAAN,EAAJ,EAAuB;AAAA,YACrB9D,QAAA,EADqB,CAAA;AAAA,SAAvB,MAEO;AAAA,YACL7Z,KAAA,CAAMynB,IAAN,CAAW,eAAX,EAA4B5N,QAA5B,CADK,CAAA;AAAA,SA9EqC;AAAA,KAAvC,CAAP,CAXA;AAAA,CAvrCF;AA4xCA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAAS6N,cAAT,CAAwBvC,UAAxB,EAAoCrW,OAApC,EAA6C;AAAA,IAClD,MAAMpV,KAAA,GAAQyrB,UAAA,CAAWjoC,GAAX,CAAe,cAAf,CAAd,CADkD;AAAA,IAElD,MAAMyqC,UAAA,GAAajuB,KAAA,CAAMyG,MAAN,CAAaod,IAAb,CAAkB,UAAUvd,KAAV,EAAiB;AAAA,QACpD,OAAOA,KAAA,CAAMxY,EAAN,KAAasnB,OAApB,CADoD;AAAA,KAAnC,CAAnB,CAFkD;AAAA,IAKlD,OAAO6Y,UAAP,CALkD;AAAA,CA5xCpD;AA2yCA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASC,cAAT,CAAwBzC,UAAxB,EAAoCE,WAApC,EAAiDwC,aAAjD,EAAgE;AAAA,IACrE,MAAM3jB,OAAA,GAAUihB,UAAA,CAAWjoC,GAAX,CAAe,cAAf,CAAhB,CADqE;AAAA,IAErE,MAAMo0B,YAAA,GAAepN,OAAA,CAAQ/D,MAA7B,CAFqE;AAAA,IAGrE,IAAI2nB,WAAJ,CAHqE;AAAA,IAIrE,IAAIC,WAAA,GAAc,CAAC,CAAnB,CAJqE;AAAA,IAKrE,IAAIF,aAAA,KAAkBxsC,SAAtB,EAAiC;AAAA,QAC/B,MAAM2sC,iBAAA,GAAoBN,cAAA,CAAevC,UAAf,EAA2B0C,aAA3B,CAA1B,CAD+B;AAAA,QAE/B,IAAIG,iBAAA,KAAsB3sC,SAA1B,EAAqC;AAAA,YACnC,MAAM,IAAIsD,KAAJ,CAAU,CAAC,eAAD,GAAkBkpC,aAAlB,EAAgC,YAAhC,CAAV,CAAN,CADmC;AAAA,SAFN;AAAA,QAK/BC,WAAA,GAAcxW,YAAA,CAAap3B,OAAb,CAAqB8tC,iBAArB,CAAd,CAL+B;AAAA,KAAjC,MAMO;AAAA,QACLF,WAAA,GAAcxW,YAAA,CAAap4B,MAA3B,CADK;AAAA,KAX8D;AAAA,IAcrE,IAAI+uC,YAAJ,CAdqE;AAAA,IAerE,IACEH,WAAA,GAAc,CAAd,IACAxW,YAAA,CAAawW,WAAA,GAAc,CAA3B,EAA8BpW,MAA9B,KAAyC2T,WAAA,CAAY3T,MAFvD,EAGE;AAAA,QACAqW,WAAA,GAAcD,WAAA,GAAc,CAA5B,CADA;AAAA,QAEAG,YAAA,GAAe,CAAC,CAAhB,CAFA;AAAA,KAHF,MAMO,IACLH,WAAA,GAAcxW,YAAA,CAAap4B,MAA3B,IACAo4B,YAAA,CAAawW,WAAb,CAA0BpW,CAAAA,MAA1B,KAAqC2T,WAAA,CAAY3T,MAF5C,EAGL;AAAA,QACAqW,WAAA,GAAcD,WAAd,CADA;AAAA,QAEAG,YAAA,GAAe,CAAf,CAFA;AAAA,KAxBmE;AAAA,IA4BrE,IAAIF,WAAA,KAAgB,CAAC,CAArB,EAAwB;AAAA,QACtB,MAAM,CAACvkC,OAAD,EAAUof,QAAV,CAAA,GAAsBuiB,UAAA,CAAWjoC,GAAX,CAAe,iBAAf,CAA5B,CADsB;AAAA,QAEtB,MAAM8iB,KAAA,GAAQwlB,UAAA,CAAWthB,OAAX,EAAoBtB,QAApB,EAA8ByiB,WAA9B,EAA2C7hC,OAA3C,CAAd,CAFsB;AAAA,QAGtB,IAAIqkC,aAAJ,EAAmB;AAAA,YACjB,MAAMK,WAAA,GAAcC,QAAA,CAAShD,UAAT,EAAqB0C,aAArB,CAApB,CADiB;AAAA,YAEjB,MAAMO,gBAAA,GAAmBjD,UAAA,CACtB5E,SADsB,EAEtBiH,CAAAA,QAFsB,EAGtBttC,CAAAA,OAHsB,CAGdguC,WAHc,CAAzB,CAFiB;AAAA,YAMjB/C,UAAA,CAAW5E,SAAX,EAAA,CAAuBC,QAAvB,CAAgC4H,gBAAhC,EAAkDpoB,KAAlD,CANiB,CAAA;AAAA,SAHG;AAAA,QAWtBsR,YAAA,CAAa7zB,MAAb,CAAoBqqC,WAApB,EAAiC,CAAjC,EAAoCzC,WAApC,CAXsB,CAAA;AAAA,QAYtB,OAAO0B,aAAA,CACL/mB,KADK,EAEL,CAACqlB,WAAA,CAAY79B,EAAb,CAFK,EAGL0c,OAHK,EAILtB,QAJK,EAKLuiB,UALK,EAML3hC,OANK,CAAP,CAZsB;AAAA,KA5B6C;AAAA,IAkDrE,IAAI8tB,YAAA,CAAahwB,IAAb,CAAmB0e,KAAD,IAAWA,KAAA,CAAMxY,EAAN,KAAa69B,WAAA,CAAY79B,EAAtD,CAAJ,EAA+D;AAAA,QAC7D,MAAM,IAAI7I,KAAJ,CAAU,CAAC,eAAD,GAAkB0mC,WAAA,CAAY79B,EAA9B,EAAiC,iBAAjC,CAAV,CAAN,CAD6D;AAAA,KAlDM;AAAA,IAqDrE,MAAM6gC,aAAA,GAAgB/W,YAAA,CAAayW,WAAb,CAAA,CAA0BvgC,EAAhD,CArDqE;AAAA,IAsDrE,MAAMpD,IAAA,GACJ6rB,iBAAA,CACE9L,mBAAA,CACEghB,UAAA,CAAWjoC,GAAX,CAAe,cAAf,CADF,EAEEirC,QAAA,CAAShD,UAAT,EAAqBkD,aAArB,CAFF,CADF,CADF,CAtDqE;AAAA,IA6DrE/W,YAAA,CAAa7zB,MAAb,CAAoBqqC,WAApB,EAAiC,CAAjC,EAAoCzC,WAApC,CA7DqE,CAAA;AAAA,IA8DrE,IAAIjhC,IAAJ,EAAU;AAAA,QACR,MAAM,CACJggB,OADI,EAEJF,OAFI,EAGJiM,cAHI,EAIJtL,WAJI,EAKJuL,UALI,EAMJC,cANI,EAOJhD,QAPI,EAQJzE,QARI,CAAA,GASFxkB,IATJ,CADQ;AAAA,QAWR,IAAI5C,KAAA,CAAMC,OAAN,CAAc0uB,cAAd,CAAJ,EAAmC;AAAA,YACjC,MAAMmY,UAAA,GAAanY,cAAA,CAAej2B,OAAf,CAAuBmuC,aAAvB,CAAwCJ,GAAAA,YAA3D,CADiC;AAAA,YAEjC9X,cAAA,CAAe1yB,MAAf,CAAsB6qC,UAAtB,EAAkC,CAAlC,EAAqCjD,WAAA,CAAY79B,EAAjD,CAFiC,CAAA;AAAA,SAX3B;AAAA,QAeR+3B,aAAA,CACEnb,OADF,EAEEF,OAFF,EAGEiM,cAHF,EAIEtL,WAJF,EAKEuL,UALF,EAMEC,cANF,EAOEhD,QAPF,EAQEzE,QARF,CAfQ,CAAA;AAAA,KAAV,MAyBO;AAAA,QACLuf,QAAA,CAAShD,UAAT,EAAqB7T,YAAA,CAAayW,WAAb,CAA0BvgC,CAAAA,EAA/C,CAAmDspB,CAAAA,OAAnD,EADK,CAAA;AAAA,KAvF8D;AAAA,IA0FrE,OAAOhK,OAAA,CAAQM,OAAR,EAAP,CA1FqE;AAAA,CA3yCvE;AA64CA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASmhB,iBAAT,CAA2BpD,UAA3B,EAAuCE,WAAvC,EAAoD;AAAA,IACzD,MAAMnhB,OAAA,GAAUihB,UAAA,CAAWjoC,GAAX,CAAe,cAAf,CAAhB,CADyD;AAAA,IAEzD,MAAMo0B,YAAA,GAAepN,OAAA,CAAQ/D,MAA7B,CAFyD;AAAA,IAGzD,MAAMzQ,KAAA,GAAQ4hB,YAAA,CAAakX,SAAb,CAAuB,UAAUxoB,KAAV,EAAiB;AAAA,QACpD,OAAOA,KAAA,CAAMxY,EAAN,KAAa69B,WAAA,CAAY79B,EAAhC,CADoD;AAAA,KAAxC,CAAd,CAHyD;AAAA,IAMzD,IAAIkI,KAAA,KAAU,CAAC,CAAf,EAAkB;AAAA,QAChB,MAAM,IAAI/Q,KAAJ,CAAU,CAAC,eAAD,GAAkB0mC,WAAA,CAAY79B,EAA9B,EAAiC,YAAjC,CAAV,CAAN,CADgB;AAAA,KANuC;AAAA,IASzD,MAAMihC,QAAA,GAAWnX,YAAA,CAAa5hB,KAAb,CAAjB,CATyD;AAAA,IAUzD,IAAI+4B,QAAA,CAAS/W,MAAT,KAAoB2T,WAAA,CAAY3T,MAApC,EAA4C;AAAA,QAC1C,MAAM,IAAI/yB,KAAJ,CACJ,8DADI,CAAN,CAD0C;AAAA,KAVa;AAAA,IAezD,OAAO2lB,gBAAA,CAAiBJ,OAAjB,EAA0BmhB,WAAA,CAAY79B,EAAtC,CAAP,CAfyD;AAAA,IAgBzD,OAAOid,cAAA,CAAeP,OAAf,EAAwBmhB,WAAA,CAAY79B,EAApC,CAAP,CAhByD;AAAA,IAiBzD8pB,YAAA,CAAa5hB,KAAb,CAAA,GAAsB21B,WAAtB,CAjByD;AAAA,IAkBzD,MAAMjhC,IAAA,GACJ6rB,iBAAA,CACE9L,mBAAA,CACEghB,UAAA,CAAWjoC,GAAX,CAAe,cAAf,CADF,EAEEirC,QAAA,CAAShD,UAAT,EAAqBE,WAAA,CAAY79B,EAAjC,CAFF,CADF,CADF,CAlByD;AAAA,IAyBzD,IAAIpD,IAAJ,EAAU;AAAA,QACRm7B,aAAA,CAAmB0H,KAAnB,CAAyB5rC,SAAzB,EAAoC+I,IAApC,CADQ,CAAA;AAAA,KAAV,MAEO;AAAA,QACL+jC,QAAA,CAAShD,UAAT,EAAqBE,WAAA,CAAY79B,EAAjC,CAAqCspB,CAAAA,OAArC,EADK,CAAA;AAAA,KA3BkD;AAAA,CA74C3D;AAq7CA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAAS4X,kBAAT,CAA4BvD,UAA5B,EAAwC39B,EAAxC,EAA4CiqB,YAA5C,EAA0D;AAAA,IAC/D,MAAMkX,aAAA,GAAgBhL,SAAA,CAAUwH,UAAV,EAAsB39B,EAAtB,CAAtB,CAD+D;AAAA,IAE/D,MAAM2Y,MAAA,GACJglB,UAAA,CACG5E,SADH,EAEGiH,CAAAA,QAFH,EAGG1+B,CAAAA,MAHH,CAGU,UAAUkX,KAAV,EAAiB;AAAA,QACvB,OACG,CAAAA,KAAA,YAAiBqd,WAAjB,IACCrd,KAAA,YAAiB0jB,SADlB,IAEC1jB,KAAA,YAAiBsd,eAFlB,KAGDtd,KAAA,CAAM2d,SAAN,EAAA,KAAsBgL,aAJxB,CADuB;AAAA,KAH3B,CADF,CAF+D;AAAA,IAe/D,MAAM1iB,QAAA,GAAWkf,UAAA,CAAWjoC,GAAX,CAAe,iBAAf,CAAjB,CAf+D;AAAA,IAgB/D,IAAI0rC,gBAAJ,CAhB+D;AAAA,IAiB/D,QAAQnX,YAAA,CAAar0B,IAArB;AAAA,IACE,KAAK,QAAL;AAAA,QACEwrC,gBAAA,GAAmBnL,iBAAA,CACjBhM,YADiB,EAEjBxL,QAAA,CAASrD,QAFQ,EAGjBqD,QAAA,CAASziB,OAHQ,CAAnB,CADF;AAAA,QAME,MAPJ;AAAA,IAQE,KAAK,SAAL;AAAA,QACEolC,gBAAA,GAAmB9hB,OAAA,CAAQM,OAAR,CACjB2X,kBAAA,CAAmBtN,YAAnB,EAAiCxL,QAAA,CAASrD,QAA1C,EAAoDqD,QAAA,CAASziB,OAA7D,CADiB,CAAnB,CADF;AAAA,QAIE,MAZJ;AAAA,IAaE,KAAK,QAAL,CAbF;AAAA,IAcE,KAAK,YAAL;AAAA,QACEolC,gBAAA,GAAmBzF,iBAAA,CACjB1R,YADiB,EAEjBxL,QAAA,CAASrD,QAFQ,EAGjBqD,QAAA,CAASziB,OAHQ,CAAnB,CADF;AAAA,QAME,MApBJ;AAAA,IAqBE;AAAA,QACE,OAAOsjB,OAAA,CAAQC,MAAR,CACL,IAAIpoB,KAAJ,CAAU,0BAAA,GAA6B8yB,YAAA,CAAar0B,IAApD,CADK,CAAP,CAtBJ;AAAA,KAjB+D;AAAA,IA2C/DwrC,gBAAA,CAAiBriB,IAAjB,CAAsB,UAAUsiB,SAAV,EAAqB;AAAA,QACzC1oB,MAAA,CAAO5a,OAAP,CAAe,UAAUya,KAAV,EAAiB;AAAA,YAC9BA,KAAA,CAAM4d,SAAN,CAAgBiL,SAAhB,CAD8B,CAAA;AAAA,SAAhC,CADyC,CAAA;AAAA,KAA3C,CA3C+D,CAAA;AAAA,IAgD/D,OAAOD,gBAAP,CAhD+D;AAAA,CAr7CjE;AA6+CA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASE,iBAAT,CAA2B3D,UAA3B,EAAuC4D,oBAAvC,EAA6D;AAAA,IAClE,MAAMC,aAAA,GACJ,OAAOD,oBAAP,KAAgC,QAAhC,GACIA,oBADJ,GAEIA,oBAAA,CAAqBvhC,EAH3B,CADkE;AAAA,IAKlE,MAAMwY,KAAA,GAAQmoB,QAAA,CAAShD,UAAT,EAAqB6D,aAArB,CAAd,CALkE;AAAA;AAOlE,IAAMC,MAAAA,iBAAA,GAAoBjpB,KAAA,CAAM9iB,GAAN,CAAU,eAAV,CAA1B,CAPkE;AAAA,IAQlE,IAAI+rC,iBAAA,CAAkB/vC,MAAlB,KAA6B,CAAjC,EAAoC;AAAA,QAClC,MAAM,IAAIyF,KAAJ,CACJ,2DADI,CAAN,CADkC;AAAA,KAR8B;AAAA,IAalEsqC,iBAAA,CAAkBxrC,MAAlB,CAAyBwrC,iBAAA,CAAkB/uC,OAAlB,CAA0B8uC,aAA1B,CAAzB,EAAmE,CAAnE,CAbkE,CAAA;AAAA,IAclE,MAAM9kB,OAAA,GAAUihB,UAAA,CAAWjoC,GAAX,CAAe,cAAf,CAAhB,CAdkE;AAAA,IAelE,MAAMijB,MAAA,GAAS+D,OAAA,CAAQ/D,MAAvB,CAfkE;AAAA,IAgBlEA,MAAA,CAAO1iB,MAAP,CACE0iB,MAAA,CAAOqoB,SAAP,CAAkBxoB,KAAD,IAAWA,KAAA,CAAMxY,EAAN,KAAawhC,aAAzC,CADF,EAEE,CAFF,CAhBkE,CAAA;AAAA,IAoBlE,MAAM5kC,IAAA,GAAO6rB,iBAAA,CAAkB9L,mBAAA,CAAoBD,OAApB,EAA6BlE,KAA7B,CAAlB,CAAb,CApBkE;AAAA,IAqBlE,IAAI5b,IAAJ,EAAU;AAAA,QACR,MAAM,CACJggB,OADI,EAEJF,OAFI,EAGJiM,cAHI,EAIJtL,WAJI,EAKJuL,UALI,EAMJC,cANI,EAOJhD,QAPI,EAQJzE,QARI,CAAA,GASFxkB,IATJ,CADQ;AAAA,QAWR,IAAI5C,KAAA,CAAMC,OAAN,CAAc0uB,cAAd,CAAJ,EAAmC;AAAA,YACjCA,cAAA,CAAe1yB,MAAf,CACE0yB,cAAA,CAAeqY,SAAf,CAA0BxoB,KAAD,IAAWA,KAAA,KAAUgpB,aAA9C,CADF,EAEE,CAFF,CADiC,CAAA;AAAA,SAX3B;AAAA,QAiBRzJ,aAAA,CACEnb,OADF,EAEEF,OAFF,EAGEiM,cAHF,EAIEtL,WAJF,EAKEuL,UALF,EAMEC,cANF,EAOEhD,QAPF,EAQEzE,QARF,CAjBQ,CAAA;AAAA,KAAV,MA2BO;AAAA,QACLuf,QAAA,CAAShD,UAAT,EAAqB6D,aAArB,CAAA,CAAoClY,OAApC,EADK,CAAA;AAAA,KAhD2D;AAAA,CA7+CpE;AA0iDA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASqX,QAAT,CAAkBxrC,GAAlB,EAAuBmyB,OAAvB,EAAgC;AAAA,IACrC,MAAM3O,MAAA,GAASxjB,GAAA,CAAI4jC,SAAJ,EAAA,CAAgBiH,QAAhB,EAAf,CADqC;AAAA,IAErC,KAAK,IAAI7uC,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAK7B,MAAA,CAAOjnB,MAAvB,EAA+BP,CAAA,GAAIqpB,EAAxC,EAA4C,EAAErpB,CAA9C,EAAiD;AAAA,QAC/C,MAAM24B,YAAA,GAAenR,MAAA,CAAOxnB,CAAP,CAAA,CAAUuE,GAAV,CAAc,eAAd,CAArB,CAD+C;AAAA,QAE/C,IAAIo0B,YAAA,IAAgBA,YAAA,CAAap3B,OAAb,CAAqB40B,OAArB,CAAA,KAAkC,CAAC,CAAvD,EAA0D;AAAA,YACxD,OAA6B3O,MAAA,CAAOxnB,CAAP,CAA7B,CADwD;AAAA,SAFX;AAAA,KAFZ;AAAA,IAQrC,OAAO0C,SAAP,CARqC;AAAA,CA1iDvC;AA2jDA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAASklC,SAAT,CAAmB5jC,GAAnB,EAAwBwgC,QAAxB,EAAkC;AAAA,IACvC,MAAMp+B,MAAA,GAAS,EAAf,CADuC;AAAA,IAEvC,MAAMohB,MAAA,GAASxjB,GAAA,CAAI4jC,SAAJ,EAAA,CAAgBiH,QAAhB,EAAf,CAFuC;AAAA,IAGvC,KAAK,IAAI7uC,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAK7B,MAAA,CAAOjnB,MAAvB,EAA+BP,CAAA,GAAIqpB,EAAxC,EAA4C,EAAErpB,CAA9C,EAAiD;AAAA,QAC/C,IAAIwnB,MAAA,CAAOxnB,CAAP,CAAA,CAAUuE,GAAV,CAAc,eAAd,CAAmCigC,KAAAA,QAAvC,EAAiD;AAAA,YAC/Cp+B,MAAA,CAAOf,IAAP,CAAkCmiB,MAAA,CAAOxnB,CAAP,CAAlC,CAD+C,CAAA;AAAA,SADF;AAAA,KAHV;AAAA,IAQvC,OAAOoG,MAAP,CARuC;AAAA,CA3jDzC;AA4kDA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAAS4+B,SAAT,CAAmBhhC,GAAnB,EAAwBwgC,QAAxB,EAAkC;AAAA,IACvC,MAAMhd,MAAA,GAASxjB,GAAA,CAAI4jC,SAAJ,EAAA,CAAgBiH,QAAhB,EAAf,CADuC;AAAA,IAEvC,KAAK,IAAI7uC,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAK7B,MAAA,CAAOjnB,MAAvB,EAA+BP,CAAA,GAAIqpB,EAAxC,EAA4C,EAAErpB,CAA9C,EAAiD;AAAA,QAC/C,MAAM+4B,MAAA;AAA8B,QAACvR,MAAA,CAAOxnB,CAAP,CAAD,CAAYglC,SAAZ,EAApC,CAD+C;AAAA,QAE/C,IAAIxd,MAAA,CAAOxnB,CAAP,CAAA,CAAUuE,GAAV,CAAc,eAAd,CAAmCigC,KAAAA,QAAvC,EAAiD;AAAA,YAC/C,OAAOzL,MAAP,CAD+C;AAAA,SAFF;AAAA,KAFV;AAAA,IAQvC,OAAOr2B,SAAP,CARuC;AAAA,CA5kDzC;AAmmDA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAAS6tC,eAAT,CAAyBjJ,UAAzB,EAAqCh5B,OAArC,EAA8CkiC,KAA9C,EAAqD;AAAA,IAC1D,MAAMhpB,MAAA,GACJ,eAAe8f,UAAf,GACIM,SAAA,CAAUN,UAAV,EAAsBh5B,OAAA,CAAQyqB,MAA9B,CADJ,GAEI,CAACuO,UAAD,CAHN,CAD0D;AAAA,IAK1D,KAAK,IAAItnC,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAK7B,MAAA,CAAOjnB,MAAvB,EAA+BP,CAAA,GAAIqpB,EAAxC,EAA4C,EAAErpB,CAA9C,EAAiD;AAAA,QAC/C,MAAMuO,YAAA,GAAeiZ,MAAA,CAAOxnB,CAAP,CAAA,CAAUuE,GAAV,CAAc,qBAAd,CAArB,CAD+C;AAAA,QAE/C,IAAIgK,YAAJ,EAAkB;AAAA,YAChB,IAAIiiC,KAAJ,EAAW;AAAA,gBACTjiC,YAAA,CAAaD,OAAA,CAAQO,EAArB,CAAA,GAA2B2hC,KAA3B,CADS;AAAA,aAAX,MAEO;AAAA,gBACL,OAAOjiC,YAAA,CAAaD,OAAA,CAAQO,EAArB,CAAP,CADK;AAAA,aAHS;AAAA,YAMhB2Y,MAAA,CAAOxnB,CAAP,CAAA,CAAUm4B,OAAV,EANgB,CAAA;AAAA,SAAlB,MAOO;AAAA,YACL,MAAM,IAAInyB,KAAJ,CAAU,CAAC,yBAAD,GAA4BsI,OAAA,CAAQyqB,MAApC,EAA2C,YAA3C,CAAV,CAAN,CADK;AAAA,SATwC;AAAA,KALS;AAAA,CAnmD5D;AAgoDA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAO,SAAS0X,eAAT,CAAyBnJ,UAAzB,EAAqCh5B,OAArC,EAA8C;AAAA,IACnD,MAAMkZ,MAAA,GACJ,eAAe8f,UAAf,GACIM,SAAA,CAAUN,UAAV,EAAsBh5B,OAAA,CAAQyqB,MAA9B,CADJ,GAEI,CAACuO,UAAD,CAHN,CADmD;AAAA,IAKnD,KAAK,IAAItnC,CAAA,GAAI,CAAR,EAAWqpB,EAAA,GAAK7B,MAAA,CAAOjnB,MAAvB,EAA+BP,CAAA,GAAIqpB,EAAxC,EAA4C,EAAErpB,CAA9C,EAAiD;AAAA,QAC/C,MAAMuO,YAAA,GAAeiZ,MAAA,CAAOxnB,CAAP,CAAA,CAAUuE,GAAV,CAAc,qBAAd,CAArB,CAD+C;AAAA,QAE/C,IAAIgK,YAAA,IAAgBA,YAAA,CAAaD,OAAA,CAAQO,EAArB,CAApB,EAA8C;AAAA,YAC5C,OAAON,YAAA,CAAaD,OAAA,CAAQO,EAArB,CAAP,CAD4C;AAAA,SAFC;AAAA,KALE;AAAA,IAWnD,OAAOnM,SAAP,CAXmD;AAAA;;ACnnDrD;AAAA;AAAA;AAAA;AAAA;AAAA,MAAMguC,UAAN,SAAyBC,SAAzB,CAAmC;AAAA;AAIjC;AAAA;AAAA,IAAAxuC,WAAA,CAAYwJ,KAAZ,EAAmB;AAAA,QACjB,KAAMilC,CAAAA,SAAA,CAAU7gB,KAAhB,CADiB,CAAA;AAAA;AAMjB;AAAA;AAAA,QAAKpkB,IAAAA,CAAAA,KAAL,GAAaA,KAAb,CANiB;AAAA,KAJc;AAAA,CAbnC;AA8IA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAe,MAAMklC,iBAAN,SAAgClM,eAAhC,CAAgD;AAAA;AAK7D;AAAA;AAAA;AAAA,IAAAxiC,WAAA,CAAY0I,OAAZ,EAAqB;AAAA,QACnB,MAAMs/B,SAAA,GAAY,WAAet/B,IAAAA,OAAf,GAAyBA,OAAA,CAAQs/B,SAAjC,GAA6C,IAA/D,CADmB;AAAA,QAEnB,MAAMpR,MAAA,GAAS,IAAIkR,gBAAJ,CAAqB;AAAA,YAClCuG,KAAA,EAAO,SAD2B;AAAA,YAElCtvB,MAAA,EAAQ,IAAI8oB,GAAJ,EAF0B;AAAA,SAArB,CAAf,CAFmB;AAAA,QAOnB,KAAM,CAAA;AAAA,YACJjR,MAAA,EAAQA,MADJ;AAAA,YAEJsQ,UAAA,EAAYx+B,OAAA,CAAQw+B,UAAR,KAAuB,KAAvB,GAA+B,IAA/B,GAAsCx+B,OAAA,CAAQw+B,UAFtD;AAAA,YAGJc,SAAA,EAAWA,SAHP;AAAA,YAIJV,SAAA,EAAW5+B,OAAA,CAAQ4+B,SAJf;AAAA,YAKJzS,OAAA,EAASnsB,OAAA,CAAQmsB,OALb;AAAA,YAMJoT,OAAA,EAASv/B,OAAA,CAAQu/B,OANb;AAAA,YAOJ0G,MAAA,EAAQjmC,OAAA,CAAQimC,MAPZ;AAAA,YAQJC,aAAA,EAAelmC,OAAA,CAAQkmC,aARnB;AAAA,YASJrD,aAAA,EAAe7iC,OAAA,CAAQ6iC,aATnB;AAAA,YAUJ9E,OAAA,EAAS/9B,OAAA,CAAQ+9B,OAVb;AAAA,YAWJ1E,OAAA,EAASr5B,OAAA,CAAQq5B,OAXb;AAAA,YAYJ8M,WAAA,EAAanmC,OAAA,CAAQmmC,WAZjB;AAAA,YAaJC,YAAA,EAAcpmC,OAAA,CAAQomC,YAblB;AAAA,YAcJC,UAAA,EAAYrmC,OAAA,CAAQqmC,UAdhB;AAAA,YAeJltC,GAAA,EAAK6G,OAAA,CAAQ7G,GAfT;AAAA,YAgBJmtC,oBAAA,EAAsBtmC,OAAA,CAAQsmC,oBAhB1B;AAAA,YAiBJC,sBAAA,EAAwBvmC,OAAA,CAAQumC,sBAjB5B;AAAA,YAkBJC,OAAA,EAASxmC,OAAA,CAAQwmC,OAlBb;AAAA,YAmBJC,sBAAA,EAAwBzmC,OAAA,CAAQymC,sBAnB5B;AAAA,YAoBJriC,UAAA,EAAYpE,OAAA,CAAQoE,UApBhB;AAAA,SAAN,CAPmB,CAAA;AAAA,QA8BnB,IAAIpE,OAAA,CAAQ6jB,WAAZ,EAAyB;AAAA,YACvB,KAAKA,WAAL,GAAmB7jB,OAAA,CAAQ6jB,WAA3B,CADuB;AAAA,SA9BN;AAAA,QAiCnB,MAAM5E,GAAA,GAAMjf,OAAA,CAAQof,QAApB,CAjCmB;AAAA,QAkCnB,MAAMmjB,QAAA,GAAW,CACf/I,UAAA,CAAW,IAAX,EAAiBva,GAAjB,EAAsBjf,OAAA,CAAQ2c,MAAR,IAAkB3c,OAAA,CAAQkuB,MAAhD,EAAwD,EACtDrK,WAAA,EAAa,IAAA,CAAKA,WADoC,EAAxD,CADe,CAAjB,CAlCmB;AAAA,QAuCnB,IAAI,IAAA,CAAK6iB,aAAL,EAAA,KAAyB7uC,SAA7B,EAAwC;AAAA,YACtC0qC,QAAA,CAAS/nC,IAAT,CACE0iC,eAAA,CAAgB,IAAhB,EAAsBl9B,OAAA,CAAQof,QAA9B,EAAwC,EACtCyE,WAAA,EAAa,KAAKA,WADoB,EAAxC,CADF,CADsC,CAAA;AAAA,SAvCrB;AAAA,QA8CnBP,OAAA,CAAQkgB,GAAR,CAAYjB,QAAZ,CACGxf,CAAAA,IADH,CACQ,MAAM;AAAA,YACVmL,MAAA,CAAOlJ,QAAP,CAAgB,OAAhB,CADU,CAAA;AAAA,SADd,CAIGxB,CAAAA,KAJH,CAIU1iB,KAAD,IAAW;AAAA,YAChB,IAAA,CAAK6lC,aAAL,CAAmB,IAAId,UAAJ,CAAe/kC,KAAf,CAAnB,CADgB,CAAA;AAAA,YAEhB,MAAMotB,MAAA,GAAS,IAAKiM,CAAAA,SAAL,EAAf,CAFgB;AAAA,YAGhBjM,MAAA,CAAOlJ,QAAP,CAAgB,OAAhB,CAHgB,CAAA;AAAA,SAJpB,CA9CmB,CAAA;AAAA,KALwC;AAAA;;;;"} \ No newline at end of file diff --git a/dist/mapbox.d.ts b/dist/mapbox.d.ts new file mode 100644 index 00000000..6d4d9c06 --- /dev/null +++ b/dist/mapbox.d.ts @@ -0,0 +1,34 @@ +/** + * Gets the path from a mapbox:// URL. + * @param {string} url The Mapbox URL. + * @return {string} The path. + * @private + */ +export function getMapboxPath(url: string): string; +/** + * Turns mapbox:// sprite URLs into resolvable URLs. + * @param {string} url The sprite URL. + * @param {string} token The access token. + * @param {string} styleUrl The style URL. + * @return {string} A resolvable URL. + * @private + */ +export function normalizeSpriteUrl(url: string, token: string, styleUrl: string): string; +/** + * Turns mapbox:// style URLs into resolvable URLs. + * @param {string} url The style URL. + * @param {string} token The access token. + * @return {string} A resolvable URL. + * @private + */ +export function normalizeStyleUrl(url: string, token: string): string; +/** + * Turns mapbox:// source URLs into vector tile URL templates. + * @param {string} url The source URL. + * @param {string} token The access token. + * @param {string} tokenParam The access token key. + * @param {string} styleUrl The style URL. + * @return {Array} A vector tile template. + * @private + */ +export function normalizeSourceUrl(url: string, token: string, tokenParam: string, styleUrl: string): Array; diff --git a/dist/olms.js b/dist/olms.js new file mode 100644 index 00000000..43462608 --- /dev/null +++ b/dist/olms.js @@ -0,0 +1,2 @@ +!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("ol/style/Circle.js"),require("ol/style/Fill.js"),require("ol/style/Icon.js"),require("ol/render/Feature.js"),require("ol/style/Stroke.js"),require("ol/style/Style.js"),require("ol/style/Text.js"),require("ol/functions.js"),require("ol/render/canvas.js"),require("ol/TileState.js"),require("ol"),require("ol/util.js"),require("ol/format/GeoJSON.js"),require("ol/layer/Image.js"),require("ol/layer/Layer.js"),require("ol/layer/Group.js"),require("ol/format/MVT.js"),require("ol/Map.js"),require("ol/source/Raster.js"),require("ol/source/Source.js"),require("ol/tilegrid/TileGrid.js"),require("ol/source/TileJSON.js"),require("ol/layer/Tile.js"),require("ol/layer/Vector.js"),require("ol/source/Vector.js"),require("ol/layer/VectorTile.js"),require("ol/source/VectorTile.js"),require("ol/View.js"),require("ol/proj/Units.js"),require("ol/loadingstrategy.js"),require("ol/tilegrid.js"),require("ol/proj.js"),require("ol/extent.js"),require("ol/events/Event.js"),require("ol/events/EventType.js")):"function"==typeof define&&define.amd?define(["exports","ol/style/Circle.js","ol/style/Fill.js","ol/style/Icon.js","ol/render/Feature.js","ol/style/Stroke.js","ol/style/Style.js","ol/style/Text.js","ol/functions.js","ol/render/canvas.js","ol/TileState.js","ol","ol/util.js","ol/format/GeoJSON.js","ol/layer/Image.js","ol/layer/Layer.js","ol/layer/Group.js","ol/format/MVT.js","ol/Map.js","ol/source/Raster.js","ol/source/Source.js","ol/tilegrid/TileGrid.js","ol/source/TileJSON.js","ol/layer/Tile.js","ol/layer/Vector.js","ol/source/Vector.js","ol/layer/VectorTile.js","ol/source/VectorTile.js","ol/View.js","ol/proj/Units.js","ol/loadingstrategy.js","ol/tilegrid.js","ol/proj.js","ol/extent.js","ol/events/Event.js","ol/events/EventType.js"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).olms={},e.ol.style.Circle,e.ol.style.Fill,e.ol.style.Icon,e.ol.render.Feature,e.ol.style.Stroke,e.ol.style.Style,e.ol.style.Text,e.ol.functions,e.ol.render.canvas,e.ol.TileState,e.ol,e.ol.util,e.ol.format.GeoJSON,e.ol.layer.Image,e.ol.layer.Layer,e.ol.layer.Group,e.ol.format.MVT,e.ol.Map,e.ol.source.Raster,e.ol.source.Source,e.ol.tilegrid.TileGrid,e.ol.source.TileJSON,e.ol.layer.Tile,e.ol.layer.Vector,e.ol.source.Vector,e.ol.layer.VectorTile,e.ol.source.VectorTile,e.ol.View,e.ol.proj.Units,e.ol.loadingstrategy,e.ol.tilegrid,e.ol.proj,e.ol.extent,e.ol.events.Event,e.ol.events.EventType)}(this,(function(e,t,r,n,o,a,i,s,l,u,p,c,f,d,m,y,h,g,v,b,x,w,k,z,M,j,S,q,T,E,$,_,C,A,I,F){"use strict";function P(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var L=P(t),O=P(r),D=P(n),R=P(o),U=P(a),N=P(i),V=P(s),G=P(p),J=P(d),W=P(m),Z=P(y),B=P(h),X=P(g),H=P(v),Y=P(b),K=P(x),Q=P(w),ee=P(k),te=P(z),re=P(M),ne=P(j),oe=P(S),ae=P(q),ie=P(T),se=P(I),le=P(F);function ue(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var pe,ce={transparent:[0,0,0,0],aliceblue:[240,248,255,1],antiquewhite:[250,235,215,1],aqua:[0,255,255,1],aquamarine:[127,255,212,1],azure:[240,255,255,1],beige:[245,245,220,1],bisque:[255,228,196,1],black:[0,0,0,1],blanchedalmond:[255,235,205,1],blue:[0,0,255,1],blueviolet:[138,43,226,1],brown:[165,42,42,1],burlywood:[222,184,135,1],cadetblue:[95,158,160,1],chartreuse:[127,255,0,1],chocolate:[210,105,30,1],coral:[255,127,80,1],cornflowerblue:[100,149,237,1],cornsilk:[255,248,220,1],crimson:[220,20,60,1],cyan:[0,255,255,1],darkblue:[0,0,139,1],darkcyan:[0,139,139,1],darkgoldenrod:[184,134,11,1],darkgray:[169,169,169,1],darkgreen:[0,100,0,1],darkgrey:[169,169,169,1],darkkhaki:[189,183,107,1],darkmagenta:[139,0,139,1],darkolivegreen:[85,107,47,1],darkorange:[255,140,0,1],darkorchid:[153,50,204,1],darkred:[139,0,0,1],darksalmon:[233,150,122,1],darkseagreen:[143,188,143,1],darkslateblue:[72,61,139,1],darkslategray:[47,79,79,1],darkslategrey:[47,79,79,1],darkturquoise:[0,206,209,1],darkviolet:[148,0,211,1],deeppink:[255,20,147,1],deepskyblue:[0,191,255,1],dimgray:[105,105,105,1],dimgrey:[105,105,105,1],dodgerblue:[30,144,255,1],firebrick:[178,34,34,1],floralwhite:[255,250,240,1],forestgreen:[34,139,34,1],fuchsia:[255,0,255,1],gainsboro:[220,220,220,1],ghostwhite:[248,248,255,1],gold:[255,215,0,1],goldenrod:[218,165,32,1],gray:[128,128,128,1],green:[0,128,0,1],greenyellow:[173,255,47,1],grey:[128,128,128,1],honeydew:[240,255,240,1],hotpink:[255,105,180,1],indianred:[205,92,92,1],indigo:[75,0,130,1],ivory:[255,255,240,1],khaki:[240,230,140,1],lavender:[230,230,250,1],lavenderblush:[255,240,245,1],lawngreen:[124,252,0,1],lemonchiffon:[255,250,205,1],lightblue:[173,216,230,1],lightcoral:[240,128,128,1],lightcyan:[224,255,255,1],lightgoldenrodyellow:[250,250,210,1],lightgray:[211,211,211,1],lightgreen:[144,238,144,1],lightgrey:[211,211,211,1],lightpink:[255,182,193,1],lightsalmon:[255,160,122,1],lightseagreen:[32,178,170,1],lightskyblue:[135,206,250,1],lightslategray:[119,136,153,1],lightslategrey:[119,136,153,1],lightsteelblue:[176,196,222,1],lightyellow:[255,255,224,1],lime:[0,255,0,1],limegreen:[50,205,50,1],linen:[250,240,230,1],magenta:[255,0,255,1],maroon:[128,0,0,1],mediumaquamarine:[102,205,170,1],mediumblue:[0,0,205,1],mediumorchid:[186,85,211,1],mediumpurple:[147,112,219,1],mediumseagreen:[60,179,113,1],mediumslateblue:[123,104,238,1],mediumspringgreen:[0,250,154,1],mediumturquoise:[72,209,204,1],mediumvioletred:[199,21,133,1],midnightblue:[25,25,112,1],mintcream:[245,255,250,1],mistyrose:[255,228,225,1],moccasin:[255,228,181,1],navajowhite:[255,222,173,1],navy:[0,0,128,1],oldlace:[253,245,230,1],olive:[128,128,0,1],olivedrab:[107,142,35,1],orange:[255,165,0,1],orangered:[255,69,0,1],orchid:[218,112,214,1],palegoldenrod:[238,232,170,1],palegreen:[152,251,152,1],paleturquoise:[175,238,238,1],palevioletred:[219,112,147,1],papayawhip:[255,239,213,1],peachpuff:[255,218,185,1],peru:[205,133,63,1],pink:[255,192,203,1],plum:[221,160,221,1],powderblue:[176,224,230,1],purple:[128,0,128,1],rebeccapurple:[102,51,153,1],red:[255,0,0,1],rosybrown:[188,143,143,1],royalblue:[65,105,225,1],saddlebrown:[139,69,19,1],salmon:[250,128,114,1],sandybrown:[244,164,96,1],seagreen:[46,139,87,1],seashell:[255,245,238,1],sienna:[160,82,45,1],silver:[192,192,192,1],skyblue:[135,206,235,1],slateblue:[106,90,205,1],slategray:[112,128,144,1],slategrey:[112,128,144,1],snow:[255,250,250,1],springgreen:[0,255,127,1],steelblue:[70,130,180,1],tan:[210,180,140,1],teal:[0,128,128,1],thistle:[216,191,216,1],tomato:[255,99,71,1],turquoise:[64,224,208,1],violet:[238,130,238,1],wheat:[245,222,179,1],white:[255,255,255,1],whitesmoke:[245,245,245,1],yellow:[255,255,0,1],yellowgreen:[154,205,50,1]};function fe(e){return(e=Math.round(e))<0?0:e>255?255:e}function de(e){return e<0?0:e>1?1:e}function me(e){return"%"===e[e.length-1]?fe(parseFloat(e)/100*255):fe(parseInt(e))}function ye(e){return"%"===e[e.length-1]?de(parseFloat(e)/100):de(parseFloat(e))}function he(e,t,r){return r<0?r+=1:r>1&&(r-=1),6*r<1?e+(t-e)*r*6:2*r<1?t:3*r<2?e+(t-e)*(2/3-r)*6:e}try{pe={}.parseCSSColor=function(e){var t,r=e.replace(/ /g,"").toLowerCase();if(r in ce)return ce[r].slice();if("#"===r[0])return 4===r.length?(t=parseInt(r.substr(1),16))>=0&&t<=4095?[(3840&t)>>4|(3840&t)>>8,240&t|(240&t)>>4,15&t|(15&t)<<4,1]:null:7===r.length&&(t=parseInt(r.substr(1),16))>=0&&t<=16777215?[(16711680&t)>>16,(65280&t)>>8,255&t,1]:null;var n=r.indexOf("("),o=r.indexOf(")");if(-1!==n&&o+1===r.length){var a=r.substr(0,n),i=r.substr(n+1,o-(n+1)).split(","),s=1;switch(a){case"rgba":if(4!==i.length)return null;s=ye(i.pop());case"rgb":return 3!==i.length?null:[me(i[0]),me(i[1]),me(i[2]),s];case"hsla":if(4!==i.length)return null;s=ye(i.pop());case"hsl":if(3!==i.length)return null;var l=(parseFloat(i[0])%360+360)%360/360,u=ye(i[1]),p=ye(i[2]),c=p<=.5?p*(u+1):p+u-p*u,f=2*p-c;return[fe(255*he(f,c,l+1/3)),fe(255*he(f,c,l)),fe(255*he(f,c,l-1/3)),s];default:return null}}return null}}catch(e){}class ge{constructor(e,t,r,n=1){this.r=e,this.g=t,this.b=r,this.a=n}static parse(e){if(!e)return;if(e instanceof ge)return e;if("string"!=typeof e)return;const t=pe(e);return t?new ge(t[0]/255*t[3],t[1]/255*t[3],t[2]/255*t[3],t[3]):void 0}toString(){const[e,t,r,n]=this.toArray();return`rgba(${Math.round(e)},${Math.round(t)},${Math.round(r)},${n})`}toArray(){const{r:e,g:t,b:r,a:n}=this;return 0===n?[0,0,0,0]:[255*e/n,255*t/n,255*r/n,n]}toArray01(){const{r:e,g:t,b:r,a:n}=this;return 0===n?[0,0,0,0]:[e/n,t/n,r/n,n]}toArray01PremultipliedAlpha(){const{r:e,g:t,b:r,a:n}=this;return[e,t,r,n]}}ge.black=new ge(0,0,0,1),ge.white=new ge(1,1,1,1),ge.transparent=new ge(0,0,0,0),ge.red=new ge(1,0,0,1),ge.blue=new ge(0,0,1,1);var ve=ge;function be(e){return"object"==typeof e?["literal",e]:e}function xe(e,t){let r=e.stops;if(!r)return function(e,t){const r=["get",e.property];if(void 0===e.default)return"string"===t.type?["string",r]:r;if("enum"===t.type)return["match",r,Object.keys(t.values),r,e.default];{const n=["color"===t.type?"to-color":t.type,r,be(e.default)];return"array"===t.type&&n.splice(1,0,t.value,t.length||null),n}}(e,t);const n=r&&"object"==typeof r[0][0],o=n||void 0!==e.property,a=n||!o;return r=r.map((e=>!o&&t.tokens&&"string"==typeof e[1]?[e[0],qe(e[1])]:[e[0],be(e[1])])),n?function(e,t,r){const n={},o={},a=[];for(let t=0;t3&&t===e[e.length-2]||(n&&2===e.length||e.push(t),e.push(r))}function Se(e,t){return e.type?e.type:t.expression.interpolated?"exponential":"interval"}function qe(e){const t=["concat"],r=/{([^{}]+)}/g;let n=0;for(let o=r.exec(e);null!==o;o=r.exec(e)){const a=e.slice(n,r.lastIndex-o[0].length);n=r.lastIndex,a.length>0&&t.push(a),t.push(["get",o[1]])}if(1===t.length)return e;if(n`:"value"===e.itemType.kind?"array":`array<${t}>`}return e.kind}const Ge=[Ce,Ae,Ie,Fe,Pe,Re,Le,Ne(Oe),Ue];function Je(e,t){if("error"===t.kind)return null;if("array"===e.kind){if("array"===t.kind&&(0===t.N&&"value"===t.itemType.kind||!Je(e.itemType,t.itemType))&&("number"!=typeof e.N||e.N===t.N))return null}else{if(e.kind===t.kind)return null;if("value"===e.kind)for(const e of Ge)if(!Je(e,t))return null}return`Expected ${Ve(e)} but found ${Ve(t)} instead.`}function We(e,t){return t.some((t=>t.kind===e.kind))}function Ze(e,t){return t.some((t=>"null"===t?null===e:"array"===t?Array.isArray(e):"object"===t?e&&!Array.isArray(e)&&"object"==typeof e:t===typeof e))}class Be{constructor(e,t,r){this.sensitivity=e?t?"variant":"case":t?"accent":"base",this.locale=r,this.collator=new Intl.Collator(this.locale?this.locale:[],{sensitivity:this.sensitivity,usage:"search"})}compare(e,t){return this.collator.compare(e,t)}resolvedLocale(){return new Intl.Collator(this.locale?this.locale:[]).resolvedOptions().locale}}class Xe{constructor(e,t,r,n,o){this.text=e.normalize?e.normalize():e,this.image=t,this.scale=r,this.fontStack=n,this.textColor=o}}class He{constructor(e){this.sections=e}static fromString(e){return new He([new Xe(e,null,null,null,null)])}isEmpty(){return 0===this.sections.length||!this.sections.some((e=>0!==e.text.length||e.image&&0!==e.image.name.length))}static factory(e){return e instanceof He?e:He.fromString(e)}toString(){return 0===this.sections.length?"":this.sections.map((e=>e.text)).join("")}serialize(){const e=["format"];for(const t of this.sections){if(t.image){e.push(["image",t.image.name]);continue}e.push(t.text);const r={};t.fontStack&&(r["text-font"]=["literal",t.fontStack.split(",")]),t.scale&&(r["font-scale"]=t.scale),t.textColor&&(r["text-color"]=["rgba"].concat(t.textColor.toArray())),e.push(r)}return e}}class Ye{constructor(e){this.name=e.name,this.available=e.available}toString(){return this.name}static fromString(e){return e?new Ye({name:e,available:!1}):null}serialize(){return["image",this.name]}}function Ke(e,t,r,n){if(!("number"==typeof e&&e>=0&&e<=255&&"number"==typeof t&&t>=0&&t<=255&&"number"==typeof r&&r>=0&&r<=255)){return`Invalid rgba value [${("number"==typeof n?[e,t,r,n]:[e,t,r]).join(", ")}]: 'r', 'g', and 'b' must be between 0 and 255.`}return void 0===n||"number"==typeof n&&n>=0&&n<=1?null:`Invalid rgba value [${[e,t,r,n].join(", ")}]: 'a' must be between 0 and 1.`}function Qe(e){if(null===e)return!0;if("string"==typeof e)return!0;if("boolean"==typeof e)return!0;if("number"==typeof e)return!0;if(e instanceof ve)return!0;if(e instanceof Be)return!0;if(e instanceof He)return!0;if(e instanceof Ye)return!0;if(Array.isArray(e)){for(const t of e)if(!Qe(t))return!1;return!0}if("object"==typeof e){for(const t in e)if(!Qe(e[t]))return!1;return!0}return!1}function et(e){if(null===e)return Ce;if("string"==typeof e)return Ie;if("boolean"==typeof e)return Fe;if("number"==typeof e)return Ae;if(e instanceof ve)return Pe;if(e instanceof Be)return De;if(e instanceof He)return Re;if(e instanceof Ye)return Ue;if(Array.isArray(e)){const t=e.length;let r;for(const t of e){const e=et(t);if(r){if(r===e)continue;r=Oe;break}r=e}return Ne(r||Oe,t)}return Le}function tt(e){const t=typeof e;return null===e?"":"string"===t||"number"===t||"boolean"===t?String(e):e instanceof ve||e instanceof He||e instanceof Ye?e.toString():JSON.stringify(e)}class rt{constructor(e,t){this.type=e,this.value=t}static parse(e,t){if(2!==e.length)return t.error(`'literal' expression requires exactly one argument, but found ${e.length-1} instead.`);if(!Qe(e[1]))return t.error("invalid value");const r=e[1];let n=et(r);const o=t.expectedType;return"array"!==n.kind||0!==n.N||!o||"array"!==o.kind||"number"==typeof o.N&&0!==o.N||(n=o),new rt(n,r)}evaluate(){return this.value}eachChild(){}outputDefined(){return!0}serialize(){return"array"===this.type.kind||"object"===this.type.kind?["literal",this.value]:this.value instanceof ve?["rgba"].concat(this.value.toArray()):this.value instanceof He?this.value.serialize():this.value}}var nt=rt;var ot=class{constructor(e){this.name="ExpressionEvaluationError",this.message=e}toJSON(){return this.message}};const at={string:Ie,number:Ae,boolean:Fe,object:Le};class it{constructor(e,t){this.type=e,this.args=t}static parse(e,t){if(e.length<2)return t.error("Expected at least one argument.");let r,n=1;const o=e[0];if("array"===o){let o,a;if(e.length>2){const r=e[1];if("string"!=typeof r||!(r in at)||"object"===r)return t.error('The item type argument of "array" must be one of string, number, boolean',1);o=at[r],n++}else o=Oe;if(e.length>3){if(null!==e[2]&&("number"!=typeof e[2]||e[2]<0||e[2]!==Math.floor(e[2])))return t.error('The length argument to "array" must be a positive integer literal',2);a=e[2],n++}r=Ne(o,a)}else r=at[o];const a=[];for(;ne.outputDefined()))}serialize(){const e=this.type,t=[e.kind];if("array"===e.kind){const r=e.itemType;if("string"===r.kind||"number"===r.kind||"boolean"===r.kind){t.push(r.kind);const n=e.N;("number"==typeof n||this.args.length>1)&&t.push(n)}}return t.concat(this.args.map((e=>e.serialize())))}}var st=it;class lt{constructor(e){this.type=Re,this.sections=e}static parse(e,t){if(e.length<2)return t.error("Expected at least one argument.");const r=e[1];if(!Array.isArray(r)&&"object"==typeof r)return t.error("First argument must be an image or text section.");const n=[];let o=!1;for(let r=1;r<=e.length-1;++r){const a=e[r];if(o&&"object"==typeof a&&!Array.isArray(a)){o=!1;let e=null;if(a["font-scale"]&&(e=t.parse(a["font-scale"],1,Ae),!e))return null;let r=null;if(a["text-font"]&&(r=t.parse(a["text-font"],1,Ne(Ie)),!r))return null;let i=null;if(a["text-color"]&&(i=t.parse(a["text-color"],1,Pe),!i))return null;const s=n[n.length-1];s.scale=e,s.font=r,s.textColor=i}else{const a=t.parse(e[r],1,Oe);if(!a)return null;const i=a.type.kind;if("string"!==i&&"value"!==i&&"null"!==i&&"resolvedImage"!==i)return t.error("Formatted text type must be 'string', 'value', 'image' or 'null'.");o=!0,n.push({content:a,scale:null,font:null,textColor:null})}}return new lt(n)}evaluate(e){return new He(this.sections.map((t=>{const r=t.content.evaluate(e);return et(r)===Ue?new Xe("",r,null,null,null):new Xe(tt(r),null,t.scale?t.scale.evaluate(e):null,t.font?t.font.evaluate(e).join(","):null,t.textColor?t.textColor.evaluate(e):null)})))}eachChild(e){for(const t of this.sections)e(t.content),t.scale&&e(t.scale),t.font&&e(t.font),t.textColor&&e(t.textColor)}outputDefined(){return!1}serialize(){const e=["format"];for(const t of this.sections){e.push(t.content.serialize());const r={};t.scale&&(r["font-scale"]=t.scale.serialize()),t.font&&(r["text-font"]=t.font.serialize()),t.textColor&&(r["text-color"]=t.textColor.serialize()),e.push(r)}return e}}class ut{constructor(e){this.type=Ue,this.input=e}static parse(e,t){if(2!==e.length)return t.error("Expected two arguments.");const r=t.parse(e[1],1,Ie);return r?new ut(r):t.error("No image name provided.")}evaluate(e){const t=this.input.evaluate(e),r=Ye.fromString(t);return r&&e.availableImages&&(r.available=e.availableImages.indexOf(t)>-1),r}eachChild(e){e(this.input)}outputDefined(){return!1}serialize(){return["image",this.input.serialize()]}}const pt={"to-boolean":Fe,"to-color":Pe,"to-number":Ae,"to-string":Ie};class ct{constructor(e,t){this.type=e,this.args=t}static parse(e,t){if(e.length<2)return t.error("Expected at least one argument.");const r=e[0];if(("to-boolean"===r||"to-string"===r)&&2!==e.length)return t.error("Expected one argument.");const n=pt[r],o=[];for(let r=1;r4?`Invalid rbga value ${JSON.stringify(t)}: expected an array containing either three or four numeric values.`:Ke(t[0],t[1],t[2],t[3]),!r))return new ve(t[0]/255,t[1]/255,t[2]/255,t[3])}throw new ot(r||`Could not parse color from value '${"string"==typeof t?t:String(JSON.stringify(t))}'`)}if("number"===this.type.kind){let t=null;for(const r of this.args){if(t=r.evaluate(e),null===t)return 0;const n=Number(t);if(!isNaN(n))return n}throw new ot(`Could not convert ${JSON.stringify(t)} to number.`)}return"formatted"===this.type.kind?He.fromString(tt(this.args[0].evaluate(e))):"resolvedImage"===this.type.kind?Ye.fromString(tt(this.args[0].evaluate(e))):tt(this.args[0].evaluate(e))}eachChild(e){this.args.forEach(e)}outputDefined(){return this.args.every((e=>e.outputDefined()))}serialize(){if("formatted"===this.type.kind)return new lt([{content:this.args[0],scale:null,font:null,textColor:null}]).serialize();if("resolvedImage"===this.type.kind)return new ut(this.args[0]).serialize();const e=[`to-${this.type.kind}`];return this.eachChild((t=>{e.push(t.serialize())})),e}}var ft=ct;const dt=["Unknown","Point","LineString","Polygon"];var mt=class{constructor(){this.globals=null,this.feature=null,this.featureState=null,this.formattedSection=null,this._parseColorCache={},this.availableImages=null,this.canonical=null,this.featureTileCoord=null,this.featureDistanceData=null}id(){return this.feature&&void 0!==this.feature.id?this.feature.id:null}geometryType(){return this.feature?"number"==typeof this.feature.type?dt[this.feature.type]:this.feature.type:null}geometry(){return this.feature&&"geometry"in this.feature?this.feature.geometry:null}canonicalID(){return this.canonical}properties(){return this.feature&&this.feature.properties||{}}distanceFromCenter(){if(this.featureTileCoord&&this.featureDistanceData){const e=this.featureDistanceData.center,t=this.featureDistanceData.scale,{x:r,y:n}=this.featureTileCoord,o=r*t-e[0],a=n*t-e[1];return this.featureDistanceData.bearing[0]*o+this.featureDistanceData.bearing[1]*a}return 0}parseColor(e){let t=this._parseColorCache[e];return t||(t=this._parseColorCache[e]=ve.parse(e)),t}};class yt{constructor(e,t,r,n){this.name=e,this.type=t,this._evaluate=r,this.args=n}evaluate(e){return this._evaluate(e,this.args)}eachChild(e){this.args.forEach(e)}outputDefined(){return!1}serialize(){return[this.name].concat(this.args.map((e=>e.serialize())))}static parse(e,t){const r=e[0],n=yt.definitions[r];if(!n)return t.error(`Unknown expression "${r}". If you wanted a literal array, use ["literal", [...]].`,0);const o=Array.isArray(n)?n[0]:n.type,a=Array.isArray(n)?[[n[1],n[2]]]:n.overloads,i=a.filter((([t])=>!Array.isArray(t)||t.length===e.length-1));let s=null;for(const[n,a]of i){s=new Vt(t.registry,t.path,null,t.scope);const i=[];let l=!1;for(let t=1;t{return t=e,Array.isArray(t)?`(${t.map(Ve).join(", ")})`:`(${Ve(t.type)}...)`;var t})).join(" | "),n=[];for(let r=1;r=t[2])&&(!(e[1]<=t[1])&&!(e[3]>=t[3])))}function wt(e,t){const r=(180+e[0])/360;const n=(o=e[1],(180-180/Math.PI*Math.log(Math.tan(Math.PI/4+o*Math.PI/360)))/360);var o;const a=Math.pow(2,t.z);return[Math.round(r*a*vt),Math.round(n*a*vt)]}function kt(e,t,r){const n=e[0]-t[0],o=e[1]-t[1],a=e[0]-r[0],i=e[1]-r[1];return n*i-a*o==0&&n*a<=0&&o*i<=0}function zt(e,t){let r=!1;for(let i=0,s=t.length;in[1]!=a[1]>n[1]&&n[0]<(a[0]-o[0])*(n[1]-o[1])/(a[1]-o[1])+o[0]&&(r=!r)}}var n,o,a;return r}function Mt(e,t){for(let r=0;r0&&c<0||p<0&&c>0}function St(e,t,r,n){const o=[t[0]-e[0],t[1]-e[1]],a=[n[0]-r[0],n[1]-r[1]];return 0!=(i=a)[0]*(s=o)[1]-i[1]*s[0]&&!(!jt(e,t,r,n)||!jt(r,n,e,t));var i,s}function qt(e,t,r){for(const n of r)for(let r=0;rr[2]){const t=.5*n;let o=e[0]-r[0]>t?-n:r[0]-e[0]>t?n:0;0===o&&(o=e[0]-r[2]>t?-n:r[2]-e[0]>t?n:0),e[0]+=o}bt(t,e)}function At(e,t,r,n){const o=Math.pow(2,n.z)*vt,a=[n.x*vt,n.y*vt],i=[];if(!e)return i;for(const n of e)for(const e of n){const n=[e.x+a[0],e.y+a[1]];Ct(n,t,r,o),i.push(n)}return i}function It(e,t,r,n){const o=Math.pow(2,n.z)*vt,a=[n.x*vt,n.y*vt],i=[];if(!e)return i;for(const r of e){const e=[];for(const n of r){const r=[n.x+a[0],n.y+a[1]];bt(t,r),e.push(r)}i.push(e)}if(t[2]-t[0]<=o/2){(s=t)[0]=s[1]=1/0,s[2]=s[3]=-1/0;for(const e of i)for(const n of e)Ct(n,t,r,o)}var s;return i}class Ft{constructor(e,t){this.type=Fe,this.geojson=e,this.geometries=t}static parse(e,t){if(2!==e.length)return t.error(`'within' expression requires exactly one argument, but found ${e.length-1} instead.`);if(Qe(e[1])){const t=e[1];if("FeatureCollection"===t.type)for(let e=0;e{t&&!Lt(e)&&(t=!1)})),t}function Ot(e){if(e instanceof ht&&"feature-state"===e.name)return!1;let t=!0;return e.eachChild((e=>{t&&!Ot(e)&&(t=!1)})),t}function Dt(e,t){if(e instanceof ht&&t.indexOf(e.name)>=0)return!1;let r=!0;return e.eachChild((e=>{r&&!Dt(e,t)&&(r=!1)})),r}class Rt{constructor(e,t){this.type=t.type,this.name=e,this.boundExpression=t}static parse(e,t){if(2!==e.length||"string"!=typeof e[1])return t.error("'var' expression requires exactly one string literal argument.");const r=e[1];return t.scope.has(r)?new Rt(r,t.scope.get(r)):t.error(`Unknown variable "${r}". Make sure "${r}" has been bound in an enclosing "let" expression before using it.`,1)}evaluate(e){return this.boundExpression.evaluate(e)}eachChild(){}outputDefined(){return!1}serialize(){return["var",this.name]}}var Ut=Rt;class Nt{constructor(e,t=[],r,n=new _e,o=[]){this.registry=e,this.path=t,this.key=t.map((e=>`[${e}]`)).join(""),this.scope=n,this.errors=o,this.expectedType=r}parse(e,t,r,n,o={}){return t?this.concat(t,r,n)._parse(e,o):this._parse(e,o)}_parse(e,t){function r(e,t,r){return"assert"===r?new st(t,[e]):"coerce"===r?new ft(t,[e]):e}if(null!==e&&"string"!=typeof e&&"boolean"!=typeof e&&"number"!=typeof e||(e=["literal",e]),Array.isArray(e)){if(0===e.length)return this.error('Expected an array with at least one element. If you wanted a literal array, use ["literal", []].');const n=e[0];if("string"!=typeof n)return this.error(`Expression name must be a string, but found ${typeof n} instead. If you wanted a literal array, use ["literal", [...]].`,0),null;const o=this.registry[n];if(o){let n=o.parse(e,this);if(!n)return null;if(this.expectedType){const e=this.expectedType,o=n.type;if("string"!==e.kind&&"number"!==e.kind&&"boolean"!==e.kind&&"object"!==e.kind&&"array"!==e.kind||"value"!==o.kind)if("color"!==e.kind&&"formatted"!==e.kind&&"resolvedImage"!==e.kind||"value"!==o.kind&&"string"!==o.kind){if(this.checkSubtype(e,o))return null}else n=r(n,e,t.typeAnnotation||"coerce");else n=r(n,e,t.typeAnnotation||"assert")}if(!(n instanceof nt)&&"resolvedImage"!==n.type.kind&&Gt(n)){const e=new mt;try{n=new nt(n.type,n.evaluate(e))}catch(e){return this.error(e.message),null}}return n}return this.error(`Unknown expression "${n}". If you wanted a literal array, use ["literal", [...]].`,0)}return void 0===e?this.error("'undefined' value invalid. Use null instead."):"object"==typeof e?this.error('Bare objects invalid. Use ["literal", {...}] instead.'):this.error(`Expected an array, but found ${typeof e} instead.`)}concat(e,t,r){const n="number"==typeof e?this.path.concat(e):this.path,o=r?this.scope.concat(r):this.scope;return new Nt(this.registry,n,t||null,o,this.errors)}error(e,...t){const r=`${this.key}${t.map((e=>`[${e}]`)).join("")}`;this.errors.push(new Ee(r,e))}checkSubtype(e,t){const r=Je(e,t);return r&&this.error(r),r}}var Vt=Nt;function Gt(e){if(e instanceof Ut)return Gt(e.boundExpression);if(e instanceof ht&&"error"===e.name)return!1;if(e instanceof gt)return!1;if(e instanceof Pt)return!1;const t=e instanceof ft||e instanceof st;let r=!0;return e.eachChild((e=>{r=t?r&&Gt(e):r&&e instanceof nt})),!!r&&(Lt(e)&&Dt(e,["zoom","heatmap-density","line-progress","sky-radial-progress","accumulated","is-supported-script","pitch","distance-from-center"]))}function Jt(e,t){const r=e.length-1;let n,o,a=0,i=r,s=0;for(;a<=i;)if(s=Math.floor((a+i)/2),n=e[s],o=e[s+1],n<=t){if(s===r||tt))throw new ot("Input is not a number.");i=s-1}return 0}class Wt{constructor(e,t,r){this.type=e,this.input=t,this.labels=[],this.outputs=[];for(const[e,t]of r)this.labels.push(e),this.outputs.push(t)}static parse(e,t){if(e.length-1<4)return t.error(`Expected at least 4 arguments, but found only ${e.length-1}.`);if((e.length-1)%2!=0)return t.error("Expected an even number of arguments.");const r=t.parse(e[1],1,Ae);if(!r)return null;const n=[];let o=null;t.expectedType&&"value"!==t.expectedType.kind&&(o=t.expectedType);for(let r=1;r=a)return t.error('Input/output pairs for "step" expressions must be arranged with input values in strictly ascending order.',s);const u=t.parse(i,l,o);if(!u)return null;o=o||u.type,n.push([a,u])}return new Wt(o,r,n)}evaluate(e){const t=this.labels,r=this.outputs;if(1===t.length)return r[0].evaluate(e);const n=this.input.evaluate(e);if(n<=t[0])return r[0].evaluate(e);const o=t.length;if(n>=t[o-1])return r[o-1].evaluate(e);return r[Jt(t,n)].evaluate(e)}eachChild(e){e(this.input);for(const t of this.outputs)e(t)}outputDefined(){return this.outputs.every((e=>e.outputDefined()))}serialize(){const e=["step",this.input.serialize()];for(let t=0;t0&&e.push(this.labels[t]),e.push(this.outputs[t].serialize());return e}}var Zt=Wt,Bt=Xt;function Xt(e,t,r,n){this.cx=3*e,this.bx=3*(r-e)-this.cx,this.ax=1-this.cx-this.bx,this.cy=3*t,this.by=3*(n-t)-this.cy,this.ay=1-this.cy-this.by,this.p1x=e,this.p1y=n,this.p2x=r,this.p2y=n}Xt.prototype.sampleCurveX=function(e){return((this.ax*e+this.bx)*e+this.cx)*e},Xt.prototype.sampleCurveY=function(e){return((this.ay*e+this.by)*e+this.cy)*e},Xt.prototype.sampleCurveDerivativeX=function(e){return(3*this.ax*e+2*this.bx)*e+this.cx},Xt.prototype.solveCurveX=function(e,t){var r,n,o,a,i;for(void 0===t&&(t=1e-6),o=e,i=0;i<8;i++){if(a=this.sampleCurveX(o)-e,Math.abs(a)(n=1))return n;for(;ra?r=o:n=o,o=.5*(n-r)+r}return o},Xt.prototype.solve=function(e,t){return this.sampleCurveY(this.solveCurveX(e,t))};var Ht=ue(Bt);function Yt(e,t,r){return e*(1-r)+t*r}var Kt=Object.freeze({__proto__:null,number:Yt,color:function(e,t,r){return new ve(Yt(e.r,t.r,r),Yt(e.g,t.g,r),Yt(e.b,t.b,r),Yt(e.a,t.a,r))},array:function(e,t,r){return e.map(((e,n)=>Yt(e,t[n],r)))}});const Qt=.95047,er=1,tr=1.08883,rr=4/29,nr=6/29,or=3*nr*nr,ar=nr*nr*nr,ir=Math.PI/180,sr=180/Math.PI;function lr(e){return e>ar?Math.pow(e,1/3):e/or+rr}function ur(e){return e>nr?e*e*e:or*(e-rr)}function pr(e){return 255*(e<=.0031308?12.92*e:1.055*Math.pow(e,1/2.4)-.055)}function cr(e){return(e/=255)<=.04045?e/12.92:Math.pow((e+.055)/1.055,2.4)}function fr(e){const t=cr(e.r),r=cr(e.g),n=cr(e.b),o=lr((.4124564*t+.3575761*r+.1804375*n)/Qt),a=lr((.2126729*t+.7151522*r+.072175*n)/er);return{l:116*a-16,a:500*(o-a),b:200*(a-lr((.0193339*t+.119192*r+.9503041*n)/tr)),alpha:e.a}}function dr(e){let t=(e.l+16)/116,r=isNaN(e.a)?t:t+e.a/500,n=isNaN(e.b)?t:t-e.b/200;return t=er*ur(t),r=Qt*ur(r),n=tr*ur(n),new ve(pr(3.2404542*r-1.5371385*t-.4985314*n),pr(-.969266*r+1.8760108*t+.041556*n),pr(.0556434*r-.2040259*t+1.0572252*n),e.alpha)}function mr(e,t,r){const n=t-e;return e+r*(n>180||n<-180?n-360*Math.round(n/360):n)}const yr={forward:fr,reverse:dr,interpolate:function(e,t,r){return{l:Yt(e.l,t.l,r),a:Yt(e.a,t.a,r),b:Yt(e.b,t.b,r),alpha:Yt(e.alpha,t.alpha,r)}}},hr={forward:function(e){const{l:t,a:r,b:n}=fr(e),o=Math.atan2(n,r)*sr;return{h:o<0?o+360:o,c:Math.sqrt(r*r+n*n),l:t,alpha:e.a}},reverse:function(e){const t=e.h*ir,r=e.c;return dr({l:e.l,a:Math.cos(t)*r,b:Math.sin(t)*r,alpha:e.alpha})},interpolate:function(e,t,r){return{h:mr(e.h,t.h,r),c:Yt(e.c,t.c,r),l:Yt(e.l,t.l,r),alpha:Yt(e.alpha,t.alpha,r)}}};class gr{constructor(e,t,r,n,o){this.type=e,this.operator=t,this.interpolation=r,this.input=n,this.labels=[],this.outputs=[];for(const[e,t]of o)this.labels.push(e),this.outputs.push(t)}static interpolationFactor(e,t,r,n){let o=0;if("exponential"===e.name)o=vr(t,e.base,r,n);else if("linear"===e.name)o=vr(t,1,r,n);else if("cubic-bezier"===e.name){const a=e.controlPoints;o=new Ht(a[0],a[1],a[2],a[3]).solve(vr(t,1,r,n))}return o}static parse(e,t){let[r,n,o,...a]=e;if(!Array.isArray(n)||0===n.length)return t.error("Expected an interpolation type expression.",1);if("linear"===n[0])n={name:"linear"};else if("exponential"===n[0]){const e=n[1];if("number"!=typeof e)return t.error("Exponential interpolation requires a numeric base.",1,1);n={name:"exponential",base:e}}else{if("cubic-bezier"!==n[0])return t.error(`Unknown interpolation type ${String(n[0])}`,1,0);{const e=n.slice(1);if(4!==e.length||e.some((e=>"number"!=typeof e||e<0||e>1)))return t.error("Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.",1);n={name:"cubic-bezier",controlPoints:e}}}if(e.length-1<4)return t.error(`Expected at least 4 arguments, but found only ${e.length-1}.`);if((e.length-1)%2!=0)return t.error("Expected an even number of arguments.");if(o=t.parse(o,2,Ae),!o)return null;const i=[];let s=null;"interpolate-hcl"===r||"interpolate-lab"===r?s=Pe:t.expectedType&&"value"!==t.expectedType.kind&&(s=t.expectedType);for(let e=0;e=r)return t.error('Input/output pairs for "interpolate" expressions must be arranged with input values in strictly ascending order.',o);const u=t.parse(n,l,s);if(!u)return null;s=s||u.type,i.push([r,u])}return"number"===s.kind||"color"===s.kind||"array"===s.kind&&"number"===s.itemType.kind&&"number"==typeof s.N?new gr(s,r,n,o,i):t.error(`Type ${Ve(s)} is not interpolatable.`)}evaluate(e){const t=this.labels,r=this.outputs;if(1===t.length)return r[0].evaluate(e);const n=this.input.evaluate(e);if(n<=t[0])return r[0].evaluate(e);const o=t.length;if(n>=t[o-1])return r[o-1].evaluate(e);const a=Jt(t,n),i=t[a],s=t[a+1],l=gr.interpolationFactor(this.interpolation,n,i,s),u=r[a].evaluate(e),p=r[a+1].evaluate(e);return"interpolate"===this.operator?Kt[this.type.kind.toLowerCase()](u,p,l):"interpolate-hcl"===this.operator?hr.reverse(hr.interpolate(hr.forward(u),hr.forward(p),l)):yr.reverse(yr.interpolate(yr.forward(u),yr.forward(p),l))}eachChild(e){e(this.input);for(const t of this.outputs)e(t)}outputDefined(){return this.outputs.every((e=>e.outputDefined()))}serialize(){let e;e="linear"===this.interpolation.name?["linear"]:"exponential"===this.interpolation.name?1===this.interpolation.base?["linear"]:["exponential",this.interpolation.base]:["cubic-bezier"].concat(this.interpolation.controlPoints);const t=[this.operator,e,this.input.serialize()];for(let e=0;eJe(n,e.type)));return new xr(a?Oe:r,o)}evaluate(e){let t,r=null,n=0;for(const o of this.args){if(n++,r=o.evaluate(e),r&&r instanceof Ye&&!r.available&&(t||(t=r),r=null,n===this.args.length))return t;if(null!==r)break}return r}eachChild(e){this.args.forEach(e)}outputDefined(){return this.args.every((e=>e.outputDefined()))}serialize(){const e=["coalesce"];return this.eachChild((t=>{e.push(t.serialize())})),e}}var wr=xr;class kr{constructor(e,t){this.type=t.type,this.bindings=[].concat(e),this.result=t}evaluate(e){return this.result.evaluate(e)}eachChild(e){for(const t of this.bindings)e(t[1]);e(this.result)}static parse(e,t){if(e.length<4)return t.error(`Expected at least 3 arguments, but found ${e.length-1} instead.`);const r=[];for(let n=1;n=r.length)throw new ot(`Array index out of bounds: ${t} > ${r.length-1}.`);if(t!==Math.floor(t))throw new ot(`Array index must be an integer, but found ${t} instead.`);return r[t]}eachChild(e){e(this.index),e(this.input)}outputDefined(){return!1}serialize(){return["at",this.index.serialize(),this.input.serialize()]}}var jr=Mr;class Sr{constructor(e,t){this.type=Fe,this.needle=e,this.haystack=t}static parse(e,t){if(3!==e.length)return t.error(`Expected 2 arguments, but found ${e.length-1} instead.`);const r=t.parse(e[1],1,Oe),n=t.parse(e[2],2,Oe);return r&&n?We(r.type,[Fe,Ie,Ae,Ce,Oe])?new Sr(r,n):t.error(`Expected first argument to be of type boolean, string, number or null, but found ${Ve(r.type)} instead`):null}evaluate(e){const t=this.needle.evaluate(e),r=this.haystack.evaluate(e);if(null==r)return!1;if(!Ze(t,["boolean","string","number","null"]))throw new ot(`Expected first argument to be of type boolean, string, number or null, but found ${Ve(et(t))} instead.`);if(!Ze(r,["string","array"]))throw new ot(`Expected second argument to be of type array or string, but found ${Ve(et(r))} instead.`);return r.indexOf(t)>=0}eachChild(e){e(this.needle),e(this.haystack)}outputDefined(){return!0}serialize(){return["in",this.needle.serialize(),this.haystack.serialize()]}}var qr=Sr;class Tr{constructor(e,t,r){this.type=Ae,this.needle=e,this.haystack=t,this.fromIndex=r}static parse(e,t){if(e.length<=2||e.length>=5)return t.error(`Expected 3 or 4 arguments, but found ${e.length-1} instead.`);const r=t.parse(e[1],1,Oe),n=t.parse(e[2],2,Oe);if(!r||!n)return null;if(!We(r.type,[Fe,Ie,Ae,Ce,Oe]))return t.error(`Expected first argument to be of type boolean, string, number or null, but found ${Ve(r.type)} instead`);if(4===e.length){const o=t.parse(e[3],3,Ae);return o?new Tr(r,n,o):null}return new Tr(r,n)}evaluate(e){const t=this.needle.evaluate(e),r=this.haystack.evaluate(e);if(!Ze(t,["boolean","string","number","null"]))throw new ot(`Expected first argument to be of type boolean, string, number or null, but found ${Ve(et(t))} instead.`);if(!Ze(r,["string","array"]))throw new ot(`Expected second argument to be of type array or string, but found ${Ve(et(r))} instead.`);if(this.fromIndex){const n=this.fromIndex.evaluate(e);return r.indexOf(t,n)}return r.indexOf(t)}eachChild(e){e(this.needle),e(this.haystack),this.fromIndex&&e(this.fromIndex)}outputDefined(){return!1}serialize(){if(null!=this.fromIndex&&void 0!==this.fromIndex){const e=this.fromIndex.serialize();return["index-of",this.needle.serialize(),this.haystack.serialize(),e]}return["index-of",this.needle.serialize(),this.haystack.serialize()]}}var Er=Tr;class $r{constructor(e,t,r,n,o,a){this.inputType=e,this.type=t,this.input=r,this.cases=n,this.outputs=o,this.otherwise=a}static parse(e,t){if(e.length<5)return t.error(`Expected at least 4 arguments, but found only ${e.length-1}.`);if(e.length%2!=1)return t.error("Expected an even number of arguments.");let r,n;t.expectedType&&"value"!==t.expectedType.kind&&(n=t.expectedType);const o={},a=[];for(let i=2;iNumber.MAX_SAFE_INTEGER)return u.error(`Branch labels must be integers no larger than ${Number.MAX_SAFE_INTEGER}.`);if("number"==typeof e&&Math.floor(e)!==e)return u.error("Numeric branch labels must be integer values.");if(r){if(u.checkSubtype(r,et(e)))return null}else r=et(e);if(void 0!==o[String(e)])return u.error("Branch labels must be unique.");o[String(e)]=a.length}const p=t.parse(l,i,n);if(!p)return null;n=n||p.type,a.push(p)}const i=t.parse(e[1],1,Oe);if(!i)return null;const s=t.parse(e[e.length-1],e.length-1,n);return s?"value"!==i.type.kind&&t.concat(1).checkSubtype(r,i.type)?null:new $r(r,n,i,o,a,s):null}evaluate(e){const t=this.input.evaluate(e);return(et(t)===this.inputType&&this.outputs[this.cases[t]]||this.otherwise).evaluate(e)}eachChild(e){e(this.input),this.outputs.forEach(e),e(this.otherwise)}outputDefined(){return this.outputs.every((e=>e.outputDefined()))&&this.otherwise.outputDefined()}serialize(){const e=["match",this.input.serialize()],t=Object.keys(this.cases).sort(),r=[],n={};for(const e of t){const t=n[this.cases[e]];void 0===t?(n[this.cases[e]]=r.length,r.push([this.cases[e],[e]])):r[t][1].push(e)}const o=e=>"number"===this.inputType.kind?Number(e):e;for(const[t,n]of r)1===n.length?e.push(o(n[0])):e.push(n.map(o)),e.push(this.outputs[t].serialize());return e.push(this.otherwise.serialize()),e}}var _r=$r;class Cr{constructor(e,t,r){this.type=e,this.branches=t,this.otherwise=r}static parse(e,t){if(e.length<4)return t.error(`Expected at least 3 arguments, but found only ${e.length-1}.`);if(e.length%2!=0)return t.error("Expected an odd number of arguments.");let r;t.expectedType&&"value"!==t.expectedType.kind&&(r=t.expectedType);const n=[];for(let o=1;ot.outputDefined()))&&this.otherwise.outputDefined()}serialize(){const e=["case"];return this.eachChild((t=>{e.push(t.serialize())})),e}}var Ar=Cr;class Ir{constructor(e,t,r,n){this.type=e,this.input=t,this.beginIndex=r,this.endIndex=n}static parse(e,t){if(e.length<=2||e.length>=5)return t.error(`Expected 3 or 4 arguments, but found ${e.length-1} instead.`);const r=t.parse(e[1],1,Oe),n=t.parse(e[2],2,Ae);if(!r||!n)return null;if(!We(r.type,[Ne(Oe),Ie,Oe]))return t.error(`Expected first argument to be of type array or string, but found ${Ve(r.type)} instead`);if(4===e.length){const o=t.parse(e[3],3,Ae);return o?new Ir(r.type,r,n,o):null}return new Ir(r.type,r,n)}evaluate(e){const t=this.input.evaluate(e),r=this.beginIndex.evaluate(e);if(!Ze(t,["string","array"]))throw new ot(`Expected first argument to be of type array or string, but found ${Ve(et(t))} instead.`);if(this.endIndex){const n=this.endIndex.evaluate(e);return t.slice(r,n)}return t.slice(r)}eachChild(e){e(this.input),e(this.beginIndex),this.endIndex&&e(this.endIndex)}outputDefined(){return!1}serialize(){if(null!=this.endIndex&&void 0!==this.endIndex){const e=this.endIndex.serialize();return["slice",this.input.serialize(),this.beginIndex.serialize(),e]}return["slice",this.input.serialize(),this.beginIndex.serialize()]}}var Fr=Ir;function Pr(e,t){return"=="===e||"!="===e?"boolean"===t.kind||"string"===t.kind||"number"===t.kind||"null"===t.kind||"value"===t.kind:"string"===t.kind||"number"===t.kind||"value"===t.kind}function Lr(e,t,r,n){return 0===n.compare(t,r)}function Or(e,t,r){const n="=="!==e&&"!="!==e;return class o{constructor(e,t,r){this.type=Fe,this.lhs=e,this.rhs=t,this.collator=r,this.hasUntypedArgument="value"===e.type.kind||"value"===t.type.kind}static parse(e,t){if(3!==e.length&&4!==e.length)return t.error("Expected two or three arguments.");const r=e[0];let a=t.parse(e[1],1,Oe);if(!a)return null;if(!Pr(r,a.type))return t.concat(1).error(`"${r}" comparisons are not supported for type '${Ve(a.type)}'.`);let i=t.parse(e[2],2,Oe);if(!i)return null;if(!Pr(r,i.type))return t.concat(2).error(`"${r}" comparisons are not supported for type '${Ve(i.type)}'.`);if(a.type.kind!==i.type.kind&&"value"!==a.type.kind&&"value"!==i.type.kind)return t.error(`Cannot compare types '${Ve(a.type)}' and '${Ve(i.type)}'.`);n&&("value"===a.type.kind&&"value"!==i.type.kind?a=new st(i.type,[a]):"value"!==a.type.kind&&"value"===i.type.kind&&(i=new st(a.type,[i])));let s=null;if(4===e.length){if("string"!==a.type.kind&&"string"!==i.type.kind&&"value"!==a.type.kind&&"value"!==i.type.kind)return t.error("Cannot use collator to compare non-string types.");if(s=t.parse(e[3],3,De),!s)return null}return new o(a,i,s)}evaluate(o){const a=this.lhs.evaluate(o),i=this.rhs.evaluate(o);if(n&&this.hasUntypedArgument){const t=et(a),r=et(i);if(t.kind!==r.kind||"string"!==t.kind&&"number"!==t.kind)throw new ot(`Expected arguments for "${e}" to be (string, string) or (number, number), but found (${t.kind}, ${r.kind}) instead.`)}if(this.collator&&!n&&this.hasUntypedArgument){const e=et(a),r=et(i);if("string"!==e.kind||"string"!==r.kind)return t(o,a,i)}return this.collator?r(o,a,i,this.collator.evaluate(o)):t(o,a,i)}eachChild(e){e(this.lhs),e(this.rhs),this.collator&&e(this.collator)}outputDefined(){return!0}serialize(){const t=[e];return this.eachChild((e=>{t.push(e.serialize())})),t}}}const Dr=Or("==",(function(e,t,r){return t===r}),Lr),Rr=Or("!=",(function(e,t,r){return t!==r}),(function(e,t,r,n){return!Lr(0,t,r,n)})),Ur=Or("<",(function(e,t,r){return t",(function(e,t,r){return t>r}),(function(e,t,r,n){return n.compare(t,r)>0})),Vr=Or("<=",(function(e,t,r){return t<=r}),(function(e,t,r,n){return n.compare(t,r)<=0})),Gr=Or(">=",(function(e,t,r){return t>=r}),(function(e,t,r,n){return n.compare(t,r)>=0}));class Jr{constructor(e,t,r,n,o,a){this.type=Ie,this.number=e,this.locale=t,this.currency=r,this.unit=n,this.minFractionDigits=o,this.maxFractionDigits=a}static parse(e,t){if(3!==e.length)return t.error("Expected two arguments.");const r=t.parse(e[1],1,Ae);if(!r)return null;const n=e[2];if("object"!=typeof n||Array.isArray(n))return t.error("NumberFormat options argument must be an object.");let o=null;if(n.locale&&(o=t.parse(n.locale,1,Ie),!o))return null;let a=null;if(n.currency&&(a=t.parse(n.currency,1,Ie),!a))return null;let i=null;if(n.unit&&(i=t.parse(n.unit,1,Ie),!i))return null;let s=null;if(n["min-fraction-digits"]&&(s=t.parse(n["min-fraction-digits"],1,Ae),!s))return null;let l=null;return n["max-fraction-digits"]&&(l=t.parse(n["max-fraction-digits"],1,Ae),!l)?null:new Jr(r,o,a,i,s,l)}evaluate(e){return new Intl.NumberFormat(this.locale?this.locale.evaluate(e):[],{style:(this.currency?"currency":this.unit&&"unit")||"decimal",currency:this.currency?this.currency.evaluate(e):void 0,unit:this.unit?this.unit.evaluate(e):void 0,minimumFractionDigits:this.minFractionDigits?this.minFractionDigits.evaluate(e):void 0,maximumFractionDigits:this.maxFractionDigits?this.maxFractionDigits.evaluate(e):void 0}).format(this.number.evaluate(e))}eachChild(e){e(this.number),this.locale&&e(this.locale),this.currency&&e(this.currency),this.unit&&e(this.unit),this.minFractionDigits&&e(this.minFractionDigits),this.maxFractionDigits&&e(this.maxFractionDigits)}outputDefined(){return!1}serialize(){const e={};return this.locale&&(e.locale=this.locale.serialize()),this.currency&&(e.currency=this.currency.serialize()),this.unit&&(e.unit=this.unit.serialize()),this.minFractionDigits&&(e["min-fraction-digits"]=this.minFractionDigits.serialize()),this.maxFractionDigits&&(e["max-fraction-digits"]=this.maxFractionDigits.serialize()),["number-format",this.number.serialize(),e]}}class Wr{constructor(e){this.type=Ae,this.input=e}static parse(e,t){if(2!==e.length)return t.error(`Expected 1 argument, but found ${e.length-1} instead.`);const r=t.parse(e[1],1);return r?"array"!==r.type.kind&&"string"!==r.type.kind&&"value"!==r.type.kind?t.error(`Expected argument of type string or array, but found ${Ve(r.type)} instead.`):new Wr(r):null}evaluate(e){const t=this.input.evaluate(e);if("string"==typeof t)return t.length;if(Array.isArray(t))return t.length;throw new ot(`Expected value to be of type string or array, but found ${Ve(et(t))} instead.`)}eachChild(e){e(this.input)}outputDefined(){return!1}serialize(){const e=["length"];return this.eachChild((t=>{e.push(t.serialize())})),e}}const Zr={"==":Dr,"!=":Rr,">":Nr,"<":Ur,">=":Gr,"<=":Vr,array:st,at:jr,boolean:st,case:Ar,coalesce:wr,collator:gt,format:lt,image:ut,in:qr,"index-of":Er,interpolate:br,"interpolate-hcl":br,"interpolate-lab":br,length:Wr,let:zr,literal:nt,match:_r,number:st,"number-format":Jr,object:st,slice:Fr,step:Zt,string:st,"to-boolean":ft,"to-color":ft,"to-number":ft,"to-string":ft,var:Ut,within:Pt};function Br(e,[t,r,n,o]){t=t.evaluate(e),r=r.evaluate(e),n=n.evaluate(e);const a=o?o.evaluate(e):1,i=Ke(t,r,n,a);if(i)throw new ot(i);return new ve(t/255*a,r/255*a,n/255*a,a)}function Xr(e,t){return e in t}function Hr(e,t){const r=t[e];return void 0===r?null:r}function Yr(e){return{type:e}}ht.register(Zr,{error:[{kind:"error"},[Ie],(e,[t])=>{throw new ot(t.evaluate(e))}],typeof:[Ie,[Oe],(e,[t])=>Ve(et(t.evaluate(e)))],"to-rgba":[Ne(Ae,4),[Pe],(e,[t])=>t.evaluate(e).toArray()],rgb:[Pe,[Ae,Ae,Ae],Br],rgba:[Pe,[Ae,Ae,Ae,Ae],Br],has:{type:Fe,overloads:[[[Ie],(e,[t])=>Xr(t.evaluate(e),e.properties())],[[Ie,Le],(e,[t,r])=>Xr(t.evaluate(e),r.evaluate(e))]]},get:{type:Oe,overloads:[[[Ie],(e,[t])=>Hr(t.evaluate(e),e.properties())],[[Ie,Le],(e,[t,r])=>Hr(t.evaluate(e),r.evaluate(e))]]},"feature-state":[Oe,[Ie],(e,[t])=>Hr(t.evaluate(e),e.featureState||{})],properties:[Le,[],e=>e.properties()],"geometry-type":[Ie,[],e=>e.geometryType()],id:[Oe,[],e=>e.id()],zoom:[Ae,[],e=>e.globals.zoom],pitch:[Ae,[],e=>e.globals.pitch||0],"distance-from-center":[Ae,[],e=>e.distanceFromCenter()],"heatmap-density":[Ae,[],e=>e.globals.heatmapDensity||0],"line-progress":[Ae,[],e=>e.globals.lineProgress||0],"sky-radial-progress":[Ae,[],e=>e.globals.skyRadialProgress||0],accumulated:[Oe,[],e=>void 0===e.globals.accumulated?null:e.globals.accumulated],"+":[Ae,Yr(Ae),(e,t)=>{let r=0;for(const n of t)r+=n.evaluate(e);return r}],"*":[Ae,Yr(Ae),(e,t)=>{let r=1;for(const n of t)r*=n.evaluate(e);return r}],"-":{type:Ae,overloads:[[[Ae,Ae],(e,[t,r])=>t.evaluate(e)-r.evaluate(e)],[[Ae],(e,[t])=>-t.evaluate(e)]]},"/":[Ae,[Ae,Ae],(e,[t,r])=>t.evaluate(e)/r.evaluate(e)],"%":[Ae,[Ae,Ae],(e,[t,r])=>t.evaluate(e)%r.evaluate(e)],ln2:[Ae,[],()=>Math.LN2],pi:[Ae,[],()=>Math.PI],e:[Ae,[],()=>Math.E],"^":[Ae,[Ae,Ae],(e,[t,r])=>Math.pow(t.evaluate(e),r.evaluate(e))],sqrt:[Ae,[Ae],(e,[t])=>Math.sqrt(t.evaluate(e))],log10:[Ae,[Ae],(e,[t])=>Math.log(t.evaluate(e))/Math.LN10],ln:[Ae,[Ae],(e,[t])=>Math.log(t.evaluate(e))],log2:[Ae,[Ae],(e,[t])=>Math.log(t.evaluate(e))/Math.LN2],sin:[Ae,[Ae],(e,[t])=>Math.sin(t.evaluate(e))],cos:[Ae,[Ae],(e,[t])=>Math.cos(t.evaluate(e))],tan:[Ae,[Ae],(e,[t])=>Math.tan(t.evaluate(e))],asin:[Ae,[Ae],(e,[t])=>Math.asin(t.evaluate(e))],acos:[Ae,[Ae],(e,[t])=>Math.acos(t.evaluate(e))],atan:[Ae,[Ae],(e,[t])=>Math.atan(t.evaluate(e))],min:[Ae,Yr(Ae),(e,t)=>Math.min(...t.map((t=>t.evaluate(e))))],max:[Ae,Yr(Ae),(e,t)=>Math.max(...t.map((t=>t.evaluate(e))))],abs:[Ae,[Ae],(e,[t])=>Math.abs(t.evaluate(e))],round:[Ae,[Ae],(e,[t])=>{const r=t.evaluate(e);return r<0?-Math.round(-r):Math.round(r)}],floor:[Ae,[Ae],(e,[t])=>Math.floor(t.evaluate(e))],ceil:[Ae,[Ae],(e,[t])=>Math.ceil(t.evaluate(e))],"filter-==":[Fe,[Ie,Oe],(e,[t,r])=>e.properties()[t.value]===r.value],"filter-id-==":[Fe,[Oe],(e,[t])=>e.id()===t.value],"filter-type-==":[Fe,[Ie],(e,[t])=>e.geometryType()===t.value],"filter-<":[Fe,[Ie,Oe],(e,[t,r])=>{const n=e.properties()[t.value],o=r.value;return typeof n==typeof o&&n{const r=e.id(),n=t.value;return typeof r==typeof n&&r":[Fe,[Ie,Oe],(e,[t,r])=>{const n=e.properties()[t.value],o=r.value;return typeof n==typeof o&&n>o}],"filter-id->":[Fe,[Oe],(e,[t])=>{const r=e.id(),n=t.value;return typeof r==typeof n&&r>n}],"filter-<=":[Fe,[Ie,Oe],(e,[t,r])=>{const n=e.properties()[t.value],o=r.value;return typeof n==typeof o&&n<=o}],"filter-id-<=":[Fe,[Oe],(e,[t])=>{const r=e.id(),n=t.value;return typeof r==typeof n&&r<=n}],"filter->=":[Fe,[Ie,Oe],(e,[t,r])=>{const n=e.properties()[t.value],o=r.value;return typeof n==typeof o&&n>=o}],"filter-id->=":[Fe,[Oe],(e,[t])=>{const r=e.id(),n=t.value;return typeof r==typeof n&&r>=n}],"filter-has":[Fe,[Oe],(e,[t])=>t.value in e.properties()],"filter-has-id":[Fe,[],e=>null!==e.id()&&void 0!==e.id()],"filter-type-in":[Fe,[Ne(Ie)],(e,[t])=>t.value.indexOf(e.geometryType())>=0],"filter-id-in":[Fe,[Ne(Oe)],(e,[t])=>t.value.indexOf(e.id())>=0],"filter-in-small":[Fe,[Ie,Ne(Oe)],(e,[t,r])=>r.value.indexOf(e.properties()[t.value])>=0],"filter-in-large":[Fe,[Ie,Ne(Oe)],(e,[t,r])=>function(e,t,r,n){for(;r<=n;){const o=r+n>>1;if(t[o]===e)return!0;t[o]>e?n=o-1:r=o+1}return!1}(e.properties()[t.value],r.value,0,r.value.length-1)],all:{type:Fe,overloads:[[[Fe,Fe],(e,[t,r])=>t.evaluate(e)&&r.evaluate(e)],[Yr(Fe),(e,t)=>{for(const r of t)if(!r.evaluate(e))return!1;return!0}]]},any:{type:Fe,overloads:[[[Fe,Fe],(e,[t,r])=>t.evaluate(e)||r.evaluate(e)],[Yr(Fe),(e,t)=>{for(const r of t)if(r.evaluate(e))return!0;return!1}]]},"!":[Fe,[Fe],(e,[t])=>!t.evaluate(e)],"is-supported-script":[Fe,[Ie],(e,[t])=>{const r=e.globals&&e.globals.isSupportedScript;return!r||r(t.evaluate(e))}],upcase:[Ie,[Ie],(e,[t])=>t.evaluate(e).toUpperCase()],downcase:[Ie,[Ie],(e,[t])=>t.evaluate(e).toLowerCase()],concat:[Ie,Yr(Oe),(e,t)=>t.map((t=>tt(t.evaluate(e)))).join("")],"resolved-locale":[Ie,[De],(e,[t])=>t.evaluate(e).resolvedLocale()]});var Kr=Zr;function Qr(e){return{result:"success",value:e}}function en(e){return{result:"error",value:e}}function tn(e){return"object"==typeof e&&null!==e&&!Array.isArray(e)}class rn{constructor(e,t){this.expression=e,this._warningHistory={},this._evaluator=new mt,this._defaultValue=t?function(e){return"color"===e.type&&(tn(e.default)||Array.isArray(e.default))?new ve(0,0,0,0):"color"===e.type?ve.parse(e.default)||null:void 0===e.default?null:e.default}(t):null,this._enumValues=t&&"enum"===t.type?t.values:null}evaluateWithoutErrorHandling(e,t,r,n,o,a,i,s){return this._evaluator.globals=e,this._evaluator.feature=t,this._evaluator.featureState=r,this._evaluator.canonical=n||null,this._evaluator.availableImages=o||null,this._evaluator.formattedSection=a,this._evaluator.featureTileCoord=i||null,this._evaluator.featureDistanceData=s||null,this.expression.evaluate(this._evaluator)}evaluate(e,t,r,n,o,a,i,s){this._evaluator.globals=e,this._evaluator.feature=t||null,this._evaluator.featureState=r||null,this._evaluator.canonical=n||null,this._evaluator.availableImages=o||null,this._evaluator.formattedSection=a||null,this._evaluator.featureTileCoord=i||null,this._evaluator.featureDistanceData=s||null;try{const e=this.expression.evaluate(this._evaluator);if(null==e||"number"==typeof e&&e!=e)return this._defaultValue;if(this._enumValues&&!(e in this._enumValues))throw new ot(`Expected value to be one of ${Object.keys(this._enumValues).map((e=>JSON.stringify(e))).join(", ")}, but found ${JSON.stringify(e)} instead.`);return e}catch(e){return this._warningHistory[e.message]||(this._warningHistory[e.message]=!0,"undefined"!=typeof console&&console.warn(e.message)),this._defaultValue}}}function nn(e,t){const r=new Vt(Kr,[],t?function(e){const t={color:Pe,string:Ie,number:Ae,enum:Ie,boolean:Fe,formatted:Re,resolvedImage:Ue};if("array"===e.type)return Ne(t[e.value]||Oe,e.length);return t[e.type]}(t):void 0),n=r.parse(e,void 0,void 0,void 0,t&&"string"===t.type?{typeAnnotation:"coerce"}:void 0);return n?Qr(new rn(n,t)):en(r.errors)}class on{constructor(e,t){this.kind=e,this._styleExpression=t,this.isStateDependent="constant"!==e&&!Ot(t.expression)}evaluateWithoutErrorHandling(e,t,r,n,o,a){return this._styleExpression.evaluateWithoutErrorHandling(e,t,r,n,o,a)}evaluate(e,t,r,n,o,a){return this._styleExpression.evaluate(e,t,r,n,o,a)}}class an{constructor(e,t,r,n){this.kind=e,this.zoomStops=r,this._styleExpression=t,this.isStateDependent="camera"!==e&&!Ot(t.expression),this.interpolationType=n}evaluateWithoutErrorHandling(e,t,r,n,o,a){return this._styleExpression.evaluateWithoutErrorHandling(e,t,r,n,o,a)}evaluate(e,t,r,n,o,a){return this._styleExpression.evaluate(e,t,r,n,o,a)}interpolationFactor(e,t,r){return this.interpolationType?br.interpolationFactor(this.interpolationType,e,t,r):0}}function sn(e,t){if("error"===(e=nn(e,t)).result)return e;const r=e.value.expression,n=Lt(r);if(!n&&!function(e){return"data-driven"===e["property-type"]}(t))return en([new Ee("","data expressions not supported")]);const o=Dt(r,["zoom","pitch","distance-from-center"]);if(!o&&!function(e){return!!e.expression&&e.expression.parameters.indexOf("zoom")>-1}(t))return en([new Ee("","zoom expressions not supported")]);const a=ln(r);if(!a&&!o)return en([new Ee("",'"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.')]);if(a instanceof Ee)return en([a]);if(a instanceof br&&!function(e){return!!e.expression&&e.expression.interpolated}(t))return en([new Ee("",'"interpolate" expressions cannot be used with this property')]);if(!a)return Qr(new on(n?"constant":"source",e.value));const i=a instanceof br?a.interpolation:void 0;return Qr(new an(n?"camera":"composite",e.value,a.labels,i))}function ln(e){let t=null;if(e instanceof zr)t=ln(e.result);else if(e instanceof wr){for(const r of e.args)if(t=ln(r),t)break}else(e instanceof Zt||e instanceof br)&&e.input instanceof ht&&"zoom"===e.input.name&&(t=e);return t instanceof Ee||e.eachChild((e=>{const r=ln(e);r instanceof Ee?t=r:!t&&r?t=new Ee("",'"zoom" expression may only be used as input to a top-level "step" or "interpolate" expression.'):t&&r&&t!==r&&(t=new Ee("",'Only one zoom-based "step" or "interpolate" subexpression may be used in an expression.'))})),t}function un(e){if(Array.isArray(e))return e.map(un);if(e instanceof Object&&!(e instanceof Number||e instanceof String||e instanceof Boolean)){const t={};for(const r in e)t[r]=un(e[r]);return t}return function(e){return e instanceof Number||e instanceof String||e instanceof Boolean?e.valueOf():e}(e)}var pn={$version:8,$root:{version:{required:!0,type:"enum",values:[8]},name:{type:"string"},metadata:{type:"*"},center:{type:"array",value:"number"},zoom:{type:"number"},bearing:{type:"number",default:0,period:360,units:"degrees"},pitch:{type:"number",default:0,units:"degrees"},light:{type:"light"},terrain:{type:"terrain"},fog:{type:"fog"},sources:{required:!0,type:"sources"},sprite:{type:"string"},glyphs:{type:"string"},transition:{type:"transition"},projection:{type:"projection"},layers:{required:!0,type:"array",value:"layer"}},sources:{"*":{type:"source"}},source:["source_vector","source_raster","source_raster_dem","source_geojson","source_video","source_image"],source_vector:{type:{required:!0,type:"enum",values:{vector:{}}},url:{type:"string"},tiles:{type:"array",value:"string"},bounds:{type:"array",value:"number",length:4,default:[-180,-85.051129,180,85.051129]},scheme:{type:"enum",values:{xyz:{},tms:{}},default:"xyz"},minzoom:{type:"number",default:0},maxzoom:{type:"number",default:22},attribution:{type:"string"},promoteId:{type:"promoteId"},volatile:{type:"boolean",default:!1},"*":{type:"*"}},source_raster:{type:{required:!0,type:"enum",values:{raster:{}}},url:{type:"string"},tiles:{type:"array",value:"string"},bounds:{type:"array",value:"number",length:4,default:[-180,-85.051129,180,85.051129]},minzoom:{type:"number",default:0},maxzoom:{type:"number",default:22},tileSize:{type:"number",default:512,units:"pixels"},scheme:{type:"enum",values:{xyz:{},tms:{}},default:"xyz"},attribution:{type:"string"},volatile:{type:"boolean",default:!1},"*":{type:"*"}},source_raster_dem:{type:{required:!0,type:"enum",values:{"raster-dem":{}}},url:{type:"string"},tiles:{type:"array",value:"string"},bounds:{type:"array",value:"number",length:4,default:[-180,-85.051129,180,85.051129]},minzoom:{type:"number",default:0},maxzoom:{type:"number",default:22},tileSize:{type:"number",default:512,units:"pixels"},attribution:{type:"string"},encoding:{type:"enum",values:{terrarium:{},mapbox:{}},default:"mapbox"},volatile:{type:"boolean",default:!1},"*":{type:"*"}},source_geojson:{type:{required:!0,type:"enum",values:{geojson:{}}},data:{type:"*"},maxzoom:{type:"number",default:18},attribution:{type:"string"},buffer:{type:"number",default:128,maximum:512,minimum:0},filter:{type:"*"},tolerance:{type:"number",default:.375},cluster:{type:"boolean",default:!1},clusterRadius:{type:"number",default:50,minimum:0},clusterMaxZoom:{type:"number"},clusterMinPoints:{type:"number"},clusterProperties:{type:"*"},lineMetrics:{type:"boolean",default:!1},generateId:{type:"boolean",default:!1},promoteId:{type:"promoteId"}},source_video:{type:{required:!0,type:"enum",values:{video:{}}},urls:{required:!0,type:"array",value:"string"},coordinates:{required:!0,type:"array",length:4,value:{type:"array",length:2,value:"number"}}},source_image:{type:{required:!0,type:"enum",values:{image:{}}},url:{required:!0,type:"string"},coordinates:{required:!0,type:"array",length:4,value:{type:"array",length:2,value:"number"}}},layer:{id:{type:"string",required:!0},type:{type:"enum",values:{fill:{},line:{},symbol:{},circle:{},heatmap:{},"fill-extrusion":{},raster:{},hillshade:{},background:{},sky:{}},required:!0},metadata:{type:"*"},source:{type:"string"},"source-layer":{type:"string"},minzoom:{type:"number",minimum:0,maximum:24},maxzoom:{type:"number",minimum:0,maximum:24},filter:{type:"filter"},layout:{type:"layout"},paint:{type:"paint"}},layout:["layout_fill","layout_line","layout_circle","layout_heatmap","layout_fill-extrusion","layout_symbol","layout_raster","layout_hillshade","layout_background","layout_sky"],layout_background:{visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},layout_sky:{visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},layout_fill:{"fill-sort-key":{type:"number",expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},layout_circle:{"circle-sort-key":{type:"number",expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},layout_heatmap:{visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},"layout_fill-extrusion":{visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"},"fill-extrusion-edge-radius":{type:"number",private:!0,default:0,minimum:0,maximum:1,"property-type":"constant"}},layout_line:{"line-cap":{type:"enum",values:{butt:{},round:{},square:{}},default:"butt",expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"line-join":{type:"enum",values:{bevel:{},round:{},miter:{}},default:"miter",expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"line-miter-limit":{type:"number",default:2,requires:[{"line-join":"miter"}],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"line-round-limit":{type:"number",default:1.05,requires:[{"line-join":"round"}],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"line-sort-key":{type:"number",expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},layout_symbol:{"symbol-placement":{type:"enum",values:{point:{},line:{},"line-center":{}},default:"point",expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"symbol-spacing":{type:"number",default:250,minimum:1,units:"pixels",requires:[{"symbol-placement":"line"}],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"symbol-avoid-edges":{type:"boolean",default:!1,expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"symbol-sort-key":{type:"number",expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"symbol-z-order":{type:"enum",values:{auto:{},"viewport-y":{},source:{}},default:"auto",expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-allow-overlap":{type:"boolean",default:!1,requires:["icon-image"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-ignore-placement":{type:"boolean",default:!1,requires:["icon-image"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-optional":{type:"boolean",default:!1,requires:["icon-image","text-field"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-rotation-alignment":{type:"enum",values:{map:{},viewport:{},auto:{}},default:"auto",requires:["icon-image"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-size":{type:"number",default:1,minimum:0,units:"factor of the original icon size",requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-text-fit":{type:"enum",values:{none:{},width:{},height:{},both:{}},default:"none",requires:["icon-image","text-field"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-text-fit-padding":{type:"array",value:"number",length:4,default:[0,0,0,0],units:"pixels",requires:["icon-image","text-field",{"icon-text-fit":["both","width","height"]}],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"icon-image":{type:"resolvedImage",tokens:!0,expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-rotate":{type:"number",default:0,period:360,units:"degrees",requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-padding":{type:"number",default:2,minimum:0,units:"pixels",requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"icon-keep-upright":{type:"boolean",default:!1,requires:["icon-image",{"icon-rotation-alignment":"map"},{"symbol-placement":["line","line-center"]}],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"icon-offset":{type:"array",value:"number",length:2,default:[0,0],requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-anchor":{type:"enum",values:{center:{},left:{},right:{},top:{},bottom:{},"top-left":{},"top-right":{},"bottom-left":{},"bottom-right":{}},default:"center",requires:["icon-image"],expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"icon-pitch-alignment":{type:"enum",values:{map:{},viewport:{},auto:{}},default:"auto",requires:["icon-image"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-pitch-alignment":{type:"enum",values:{map:{},viewport:{},auto:{}},default:"auto",requires:["text-field"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-rotation-alignment":{type:"enum",values:{map:{},viewport:{},auto:{}},default:"auto",requires:["text-field"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-field":{type:"formatted",default:"",tokens:!0,expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-font":{type:"array",value:"string",default:["Open Sans Regular","Arial Unicode MS Regular"],requires:["text-field"],expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-size":{type:"number",default:16,minimum:0,units:"pixels",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-max-width":{type:"number",default:10,minimum:0,units:"ems",requires:["text-field",{"symbol-placement":["point"]}],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-line-height":{type:"number",default:1.2,units:"ems",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-letter-spacing":{type:"number",default:0,units:"ems",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-justify":{type:"enum",values:{auto:{},left:{},center:{},right:{}},default:"center",requires:["text-field"],expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-radial-offset":{type:"number",units:"ems",default:0,requires:["text-field"],"property-type":"data-driven",expression:{interpolated:!0,parameters:["zoom","feature"]}},"text-variable-anchor":{type:"array",value:"enum",values:{center:{},left:{},right:{},top:{},bottom:{},"top-left":{},"top-right":{},"bottom-left":{},"bottom-right":{}},requires:["text-field",{"symbol-placement":["point"]}],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-anchor":{type:"enum",values:{center:{},left:{},right:{},top:{},bottom:{},"top-left":{},"top-right":{},"bottom-left":{},"bottom-right":{}},default:"center",requires:["text-field",{"!":"text-variable-anchor"}],expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-max-angle":{type:"number",default:45,units:"degrees",requires:["text-field",{"symbol-placement":["line","line-center"]}],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"text-writing-mode":{type:"array",value:"enum",values:{horizontal:{},vertical:{}},requires:["text-field"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-rotate":{type:"number",default:0,period:360,units:"degrees",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-padding":{type:"number",default:2,minimum:0,units:"pixels",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"text-keep-upright":{type:"boolean",default:!0,requires:["text-field",{"text-rotation-alignment":"map"},{"symbol-placement":["line","line-center"]}],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-transform":{type:"enum",values:{none:{},uppercase:{},lowercase:{}},default:"none",requires:["text-field"],expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-offset":{type:"array",value:"number",units:"ems",length:2,default:[0,0],requires:["text-field",{"!":"text-radial-offset"}],expression:{interpolated:!0,parameters:["zoom","feature"]},"property-type":"data-driven"},"text-allow-overlap":{type:"boolean",default:!1,requires:["text-field"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-ignore-placement":{type:"boolean",default:!1,requires:["text-field"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-optional":{type:"boolean",default:!1,requires:["text-field","icon-image"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},layout_raster:{visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},layout_hillshade:{visibility:{type:"enum",values:{visible:{},none:{}},default:"visible","property-type":"constant"}},filter:{type:"array",value:"*"},filter_symbol:{type:"boolean",default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature","pitch","distance-from-center"]}},filter_fill:{type:"boolean",default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},filter_line:{type:"boolean",default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},filter_circle:{type:"boolean",default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},"filter_fill-extrusion":{type:"boolean",default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},filter_heatmap:{type:"boolean",default:!1,transition:!1,"property-type":"data-driven",expression:{interpolated:!1,parameters:["zoom","feature"]}},filter_operator:{type:"enum",values:{"==":{},"!=":{},">":{},">=":{},"<":{},"<=":{},in:{},"!in":{},all:{},any:{},none:{},has:{},"!has":{},within:{}}},geometry_type:{type:"enum",values:{Point:{},LineString:{},Polygon:{}}},function:{expression:{type:"expression"},stops:{type:"array",value:"function_stop"},base:{type:"number",default:1,minimum:0},property:{type:"string",default:"$zoom"},type:{type:"enum",values:{identity:{},exponential:{},interval:{},categorical:{}},default:"exponential"},colorSpace:{type:"enum",values:{rgb:{},lab:{},hcl:{}},default:"rgb"},default:{type:"*",required:!1}},function_stop:{type:"array",minimum:0,maximum:24,value:["number","color"],length:2},expression:{type:"array",value:"*",minimum:1},expression_name:{type:"enum",values:{let:{group:"Variable binding"},var:{group:"Variable binding"},literal:{group:"Types"},array:{group:"Types"},at:{group:"Lookup"},in:{group:"Lookup"},"index-of":{group:"Lookup"},slice:{group:"Lookup"},case:{group:"Decision"},match:{group:"Decision"},coalesce:{group:"Decision"},step:{group:"Ramps, scales, curves"},interpolate:{group:"Ramps, scales, curves"},"interpolate-hcl":{group:"Ramps, scales, curves"},"interpolate-lab":{group:"Ramps, scales, curves"},ln2:{group:"Math"},pi:{group:"Math"},e:{group:"Math"},typeof:{group:"Types"},string:{group:"Types"},number:{group:"Types"},boolean:{group:"Types"},object:{group:"Types"},collator:{group:"Types"},format:{group:"Types"},image:{group:"Types"},"number-format":{group:"Types"},"to-string":{group:"Types"},"to-number":{group:"Types"},"to-boolean":{group:"Types"},"to-rgba":{group:"Color"},"to-color":{group:"Types"},rgb:{group:"Color"},rgba:{group:"Color"},get:{group:"Lookup"},has:{group:"Lookup"},length:{group:"Lookup"},properties:{group:"Feature data"},"feature-state":{group:"Feature data"},"geometry-type":{group:"Feature data"},id:{group:"Feature data"},zoom:{group:"Camera"},pitch:{group:"Camera"},"distance-from-center":{group:"Camera"},"heatmap-density":{group:"Heatmap"},"line-progress":{group:"Feature data"},"sky-radial-progress":{group:"sky"},accumulated:{group:"Feature data"},"+":{group:"Math"},"*":{group:"Math"},"-":{group:"Math"},"/":{group:"Math"},"%":{group:"Math"},"^":{group:"Math"},sqrt:{group:"Math"},log10:{group:"Math"},ln:{group:"Math"},log2:{group:"Math"},sin:{group:"Math"},cos:{group:"Math"},tan:{group:"Math"},asin:{group:"Math"},acos:{group:"Math"},atan:{group:"Math"},min:{group:"Math"},max:{group:"Math"},round:{group:"Math"},abs:{group:"Math"},ceil:{group:"Math"},floor:{group:"Math"},distance:{group:"Math"},"==":{group:"Decision"},"!=":{group:"Decision"},">":{group:"Decision"},"<":{group:"Decision"},">=":{group:"Decision"},"<=":{group:"Decision"},all:{group:"Decision"},any:{group:"Decision"},"!":{group:"Decision"},within:{group:"Decision"},"is-supported-script":{group:"String"},upcase:{group:"String"},downcase:{group:"String"},concat:{group:"String"},"resolved-locale":{group:"String"}}},fog:{range:{type:"array",default:[.5,10],minimum:-20,maximum:20,length:2,value:"number","property-type":"data-constant",transition:!0,expression:{interpolated:!0,parameters:["zoom"]}},color:{type:"color","property-type":"data-constant",default:"#ffffff",expression:{interpolated:!0,parameters:["zoom"]},transition:!0},"high-color":{type:"color","property-type":"data-constant",default:"#245cdf",expression:{interpolated:!0,parameters:["zoom"]},transition:!0},"space-color":{type:"color","property-type":"data-constant",default:["interpolate",["linear"],["zoom"],4,"#010b19",7,"#367ab9"],expression:{interpolated:!0,parameters:["zoom"]},transition:!0},"horizon-blend":{type:"number","property-type":"data-constant",default:["interpolate",["linear"],["zoom"],4,.2,7,.1],minimum:0,maximum:1,expression:{interpolated:!0,parameters:["zoom"]},transition:!0},"star-intensity":{type:"number","property-type":"data-constant",default:["interpolate",["linear"],["zoom"],5,.35,6,0],minimum:0,maximum:1,expression:{interpolated:!0,parameters:["zoom"]},transition:!0}},light:{anchor:{type:"enum",default:"viewport",values:{map:{},viewport:{}},"property-type":"data-constant",transition:!1,expression:{interpolated:!1,parameters:["zoom"]}},position:{type:"array",default:[1.15,210,30],length:3,value:"number","property-type":"data-constant",transition:!0,expression:{interpolated:!0,parameters:["zoom"]}},color:{type:"color","property-type":"data-constant",default:"#ffffff",expression:{interpolated:!0,parameters:["zoom"]},transition:!0},intensity:{type:"number","property-type":"data-constant",default:.5,minimum:0,maximum:1,expression:{interpolated:!0,parameters:["zoom"]},transition:!0}},projection:{name:{type:"enum",values:{albers:{},equalEarth:{},equirectangular:{},lambertConformalConic:{},mercator:{},naturalEarth:{},winkelTripel:{},globe:{}},default:"mercator",required:!0},center:{type:"array",length:2,value:"number","property-type":"data-constant",minimum:[-180,-90],maximum:[180,90],transition:!1,requires:[{name:["albers","lambertConformalConic"]}]},parallels:{type:"array",length:2,value:"number","property-type":"data-constant",minimum:[-90,-90],maximum:[90,90],transition:!1,requires:[{name:["albers","lambertConformalConic"]}]}},terrain:{source:{type:"string",required:!0},exaggeration:{type:"number","property-type":"data-constant",default:1,minimum:0,maximum:1e3,expression:{interpolated:!0,parameters:["zoom"]},transition:!0,requires:["source"]}},paint:["paint_fill","paint_line","paint_circle","paint_heatmap","paint_fill-extrusion","paint_symbol","paint_raster","paint_hillshade","paint_background","paint_sky"],paint_fill:{"fill-antialias":{type:"boolean",default:!0,expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"fill-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-color":{type:"color",default:"#000000",transition:!0,requires:[{"!":"fill-pattern"}],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-outline-color":{type:"color",transition:!0,requires:[{"!":"fill-pattern"},{"fill-antialias":!0}],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"fill-translate-anchor":{type:"enum",values:{map:{},viewport:{}},default:"map",requires:["fill-translate"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"fill-pattern":{type:"resolvedImage",transition:!1,expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"}},"paint_fill-extrusion":{"fill-extrusion-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"fill-extrusion-color":{type:"color",default:"#000000",transition:!0,requires:[{"!":"fill-extrusion-pattern"}],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"fill-extrusion-translate-anchor":{type:"enum",values:{map:{},viewport:{}},default:"map",requires:["fill-extrusion-translate"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"fill-extrusion-pattern":{type:"resolvedImage",transition:!1,expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"fill-extrusion-height":{type:"number",default:0,minimum:0,units:"meters",transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-base":{type:"number",default:0,minimum:0,units:"meters",transition:!0,requires:["fill-extrusion-height"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"fill-extrusion-vertical-gradient":{type:"boolean",default:!0,transition:!1,expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"fill-extrusion-ambient-occlusion-intensity":{"property-type":"data-constant",type:"number",private:!0,default:0,minimum:0,maximum:1,expression:{interpolated:!0,parameters:["zoom"]},transition:!0},"fill-extrusion-ambient-occlusion-radius":{"property-type":"data-constant",type:"number",private:!0,default:3,minimum:0,expression:{interpolated:!0,parameters:["zoom"]},transition:!0,requires:["fill-extrusion-edge-radius"]}},paint_line:{"line-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-color":{type:"color",default:"#000000",transition:!0,requires:[{"!":"line-pattern"}],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"line-translate-anchor":{type:"enum",values:{map:{},viewport:{}},default:"map",requires:["line-translate"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"line-width":{type:"number",default:1,minimum:0,transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-gap-width":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-offset":{type:"number",default:0,transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-blur":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"line-dasharray":{type:"array",value:"number",minimum:0,transition:!1,units:"line widths",requires:[{"!":"line-pattern"}],expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"line-pattern":{type:"resolvedImage",transition:!1,expression:{interpolated:!1,parameters:["zoom","feature"]},"property-type":"data-driven"},"line-gradient":{type:"color",transition:!1,requires:[{"!":"line-pattern"},{source:"geojson",has:{lineMetrics:!0}}],expression:{interpolated:!0,parameters:["line-progress"]},"property-type":"color-ramp"},"line-trim-offset":{type:"array",value:"number",length:2,default:[0,0],minimum:[0,0],maximum:[1,1],transition:!1,requires:[{source:"geojson",has:{lineMetrics:!0}}],"property-type":"constant"}},paint_circle:{"circle-radius":{type:"number",default:5,minimum:0,transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-color":{type:"color",default:"#000000",transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-blur":{type:"number",default:0,transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"circle-translate-anchor":{type:"enum",values:{map:{},viewport:{}},default:"map",requires:["circle-translate"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"circle-pitch-scale":{type:"enum",values:{map:{},viewport:{}},default:"map",expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"circle-pitch-alignment":{type:"enum",values:{map:{},viewport:{}},default:"viewport",expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"circle-stroke-width":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-stroke-color":{type:"color",default:"#000000",transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"circle-stroke-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"}},paint_heatmap:{"heatmap-radius":{type:"number",default:30,minimum:1,transition:!0,units:"pixels",expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"heatmap-weight":{type:"number",default:1,minimum:0,transition:!1,expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"heatmap-intensity":{type:"number",default:1,minimum:0,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"heatmap-color":{type:"color",default:["interpolate",["linear"],["heatmap-density"],0,"rgba(0, 0, 255, 0)",.1,"royalblue",.3,"cyan",.5,"lime",.7,"yellow",1,"red"],transition:!1,expression:{interpolated:!0,parameters:["heatmap-density"]},"property-type":"color-ramp"},"heatmap-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_symbol:{"icon-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-color":{type:"color",default:"#000000",transition:!0,requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-color":{type:"color",default:"rgba(0, 0, 0, 0)",transition:!0,requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-width":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-halo-blur":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"icon-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",requires:["icon-image"],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"icon-translate-anchor":{type:"enum",values:{map:{},viewport:{}},default:"map",requires:["icon-image","icon-translate"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"text-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-color":{type:"color",default:"#000000",transition:!0,overridable:!0,requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-color":{type:"color",default:"rgba(0, 0, 0, 0)",transition:!0,requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-width":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-halo-blur":{type:"number",default:0,minimum:0,transition:!0,units:"pixels",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom","feature","feature-state"]},"property-type":"data-driven"},"text-translate":{type:"array",value:"number",length:2,default:[0,0],transition:!0,units:"pixels",requires:["text-field"],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"text-translate-anchor":{type:"enum",values:{map:{},viewport:{}},default:"map",requires:["text-field","text-translate"],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"}},paint_raster:{"raster-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-hue-rotate":{type:"number",default:0,period:360,transition:!0,units:"degrees",expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-brightness-min":{type:"number",default:0,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-brightness-max":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-saturation":{type:"number",default:0,minimum:-1,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-contrast":{type:"number",default:0,minimum:-1,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"raster-resampling":{type:"enum",values:{linear:{},nearest:{}},default:"linear",expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"raster-fade-duration":{type:"number",default:300,minimum:0,transition:!1,units:"milliseconds",expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_hillshade:{"hillshade-illumination-direction":{type:"number",default:335,minimum:0,maximum:359,transition:!1,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-illumination-anchor":{type:"enum",values:{map:{},viewport:{}},default:"viewport",expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-exaggeration":{type:"number",default:.5,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-shadow-color":{type:"color",default:"#000000",transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-highlight-color":{type:"color",default:"#FFFFFF",transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"hillshade-accent-color":{type:"color",default:"#000000",transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_background:{"background-color":{type:"color",default:"#000000",transition:!0,requires:[{"!":"background-pattern"}],expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"},"background-pattern":{type:"resolvedImage",transition:!1,expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"background-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},paint_sky:{"sky-type":{type:"enum",values:{gradient:{},atmosphere:{}},default:"atmosphere",expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"sky-atmosphere-sun":{type:"array",value:"number",length:2,units:"degrees",minimum:[0,0],maximum:[360,180],transition:!1,requires:[{"sky-type":"atmosphere"}],expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"sky-atmosphere-sun-intensity":{type:"number",requires:[{"sky-type":"atmosphere"}],default:10,minimum:0,maximum:100,transition:!1,"property-type":"data-constant"},"sky-gradient-center":{type:"array",requires:[{"sky-type":"gradient"}],value:"number",default:[0,0],length:2,units:"degrees",minimum:[0,0],maximum:[360,180],transition:!1,expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"sky-gradient-radius":{type:"number",requires:[{"sky-type":"gradient"}],default:90,minimum:0,maximum:180,transition:!1,expression:{interpolated:!1,parameters:["zoom"]},"property-type":"data-constant"},"sky-gradient":{type:"color",default:["interpolate",["linear"],["sky-radial-progress"],.8,"#87ceeb",1,"white"],transition:!1,requires:[{"sky-type":"gradient"}],expression:{interpolated:!0,parameters:["sky-radial-progress"]},"property-type":"color-ramp"},"sky-atmosphere-halo-color":{type:"color",default:"white",transition:!1,requires:[{"sky-type":"atmosphere"}],"property-type":"data-constant"},"sky-atmosphere-color":{type:"color",default:"white",transition:!1,requires:[{"sky-type":"atmosphere"}],"property-type":"data-constant"},"sky-opacity":{type:"number",default:1,minimum:0,maximum:1,transition:!0,expression:{interpolated:!0,parameters:["zoom"]},"property-type":"data-constant"}},transition:{duration:{type:"number",default:300,minimum:0,units:"milliseconds"},delay:{type:"number",default:0,minimum:0,units:"milliseconds"}},"property-type":{"data-driven":{type:"property-type"},"color-ramp":{type:"property-type"},"data-constant":{type:"property-type"},constant:{type:"property-type"}},promoteId:{"*":{type:"string"}}};function cn(e){if(!0===e||!1===e)return!0;if(!Array.isArray(e)||0===e.length)return!1;switch(e[0]){case"has":return e.length>=2&&"$id"!==e[1]&&"$type"!==e[1];case"in":return e.length>=3&&("string"!=typeof e[1]||Array.isArray(e[2]));case"!in":case"!has":case"none":return!1;case"==":case"!=":case">":case">=":case"<":case"<=":return 3!==e.length||Array.isArray(e[1])||Array.isArray(e[2]);case"any":case"all":for(const t of e.slice(1))if(!cn(t)&&"boolean"!=typeof t)return!1;return!0;default:return!0}}function fn(e,t="fill"){if(null==e)return{filter:()=>!0,needGeometry:!1,needFeature:!1};cn(e)||(e=bn(e));const r=e;let n=!0;try{n=function(e){if(!yn(e))return e;let t=un(e);return mn(t),t=dn(t),t}(r)}catch(e){console.warn(`Failed to extract static filter. Filter will continue working, but at higher memory usage and slower framerate.\nThis is most likely a bug, please report this via https://github.com/mapbox/mapbox-gl-js/issues/new?assignees=&labels=&template=Bug_report.md\nand paste the contents of this message in the report.\nThank you!\nFilter Expression:\n${JSON.stringify(r,null,2)}\n `)}const o=pn[`filter_${t}`],a=nn(n,o);let i=null;if("error"===a.result)throw new Error(a.value.map((e=>`${e.key}: ${e.message}`)).join(", "));i=(e,t,r)=>a.value.evaluate(e,t,{},r);let s=null,l=null;if(n!==r){const e=nn(r,o);if("error"===e.result)throw new Error(e.value.map((e=>`${e.key}: ${e.message}`)).join(", "));s=(t,r,n,o,a)=>e.value.evaluate(t,r,{},n,void 0,void 0,o,a),l=!Lt(e.value.expression)}return{filter:i,dynamicFilter:s||void 0,needGeometry:vn(n),needFeature:!!l}}function dn(e){if(!Array.isArray(e))return e;const t=function(e){if(hn.has(e[0]))for(let t=1;tdn(e)))}function mn(e){let t=!1;const r=[];if("case"===e[0]){for(let n=1;n",">=","<","<=","to-boolean"]);function gn(e,t){return et?1:0}function vn(e){if(!Array.isArray(e))return!1;if("within"===e[0])return!0;for(let t=1;t"===t||"<="===t||">="===t?xn(e[1],e[2],t):"any"===t?(r=e.slice(1),["any"].concat(r.map(bn))):"all"===t?["all"].concat(e.slice(1).map(bn)):"none"===t?["all"].concat(e.slice(1).map(bn).map(zn)):"in"===t?wn(e[1],e.slice(2)):"!in"===t?zn(wn(e[1],e.slice(2))):"has"===t?kn(e[1]):"!has"===t?zn(kn(e[1])):"within"!==t||e}function xn(e,t,r){switch(e){case"$type":return[`filter-type-${r}`,t];case"$id":return[`filter-id-${r}`,t];default:return[`filter-${r}`,e,t]}}function wn(e,t){if(0===t.length)return!1;switch(e){case"$type":return["filter-type-in",["literal",t]];case"$id":return["filter-id-in",["literal",t]];default:return t.length>200&&!t.some((e=>typeof e!=typeof t[0]))?["filter-in-large",e,["literal",t.sort(gn)]]:["filter-in-small",e,["literal",t]]}}function kn(e){switch(e){case"$type":return!0;case"$id":return["filter-has-id"];default:return["filter-has",e]}}function zn(e){return["!",e]}var Mn=["type","source","source-layer","minzoom","maxzoom","filter","layout"];function jn(e,t){const r={};for(const t in e)"ref"!==t&&(r[t]=e[t]);return Mn.forEach((e=>{e in t&&(r[e]=t[e])})),r}function Sn(e){e=e.slice();const t=Object.create(null);for(let r=0;r1?c[c.length-2].toLowerCase():"";if(f==d||f==d.replace("-","")||m+"-"+f==d){i=o?i:qn[d],c.pop(),m&&d.startsWith(m)&&c.pop();break}}o||"number"!=typeof f||(i=f,o=!0);var y=c.join(Tn).replace("Klokantech Noto Sans","Noto Sans");-1!==y.indexOf(Tn)&&(y='"'+y+'"'),l.push(y)}n=$n[e]=[s,i,l]}return n[0]+Tn+n[1]+Tn+t+"px"+(r?"/"+r:"")+Tn+n[2]}));const Cn="https://api.mapbox.com";function An(e){const t="mapbox://";return 0!==e.indexOf(t)?"":e.slice(9)}function In(e,t){const r=An(e);if(!r)return decodeURI(new URL(e,location.href).href);const n="styles/";if(0!==r.indexOf(n))throw new Error(`unexpected style url: ${e}`);const o=r.slice(7);return`${Cn}/styles/v1/${o}?&access_token=${t}`}const Fn=["a","b","c","d"];function Pn(e,t,r,n){const o=new URL(e,n),a=An(e);if(!a)return t?(o.searchParams.has(r)||o.searchParams.set(r,t),[decodeURI(o.href)]):[decodeURI(o.href)];if("mapbox.satellite"===a){const e=window.devicePixelRatio>=1.5?"@2x":"";return[`https://api.mapbox.com/v4/${a}/{z}/{x}/{y}${e}.webp?access_token=${t}`]}return Fn.map((e=>`https://${e}.tiles.mapbox.com/v4/${a}/{z}/{x}/{y}.vector.pbf?access_token=${t}`))}const Ln={},On={};let Dn=0;function Rn(e){return e.id||(e.id=Dn++),e.id}function Un(e,t){return Rn(e)+"."+f.getUid(t)}function Nn(e){let t=Ln[e.id];return t||(t={},Ln[Rn(e)]=t),t}function Vn(e){let t=On[e.id];return t||(t={},On[Rn(e)]=t),t}function Gn(e){return e*Math.PI/180}const Jn=function(){const e=[];for(let t=78271.51696402048;e.length<=24;t/=2)e.push(t);return e}();function Wn(e,t){if("undefined"!=typeof WorkerGlobalScope&&self instanceof WorkerGlobalScope&&"undefined"!=typeof OffscreenCanvas)return new OffscreenCanvas(e,t);const r=document.createElement("canvas");return r.width=e,r.height=t,r}function Zn(e,t){let r=0;const n=t.length;for(;ro)).then((e=>(e instanceof Request||(e=new Request(e)),e.headers.get("Accept")||e.headers.set("Accept","application/json"),n&&(n.request=e),fetch(e).then((function(e){return delete Xn[t],e.ok?e.json():Promise.reject(new Error("Error fetching source "+t))})).catch((function(e){return delete Xn[t],Promise.reject(new Error("Error fetching source "+t))})))));return Xn[t]=[o,a],a}function Yn(e,t){if("string"!=typeof e)return Promise.resolve(e);if(!e.trim().startsWith("{"))return Hn("Style",e=In(e,t.accessToken),t);try{const t=JSON.parse(e);return Promise.resolve(t)}catch(e){return Promise.reject(e)}}const Kn={};function Qn(e,t,r={}){const n=[t,JSON.stringify(e)].toString();let o=Kn[n];if(!o||r.transformRequest){let a;r.transformRequest&&(a=(e,t)=>{const n=r.transformRequest&&r.transformRequest(t,"Tiles")||t;if(e instanceof c.VectorTile)e.setLoader(((t,r,o)=>{l.toPromise((()=>n)).then((r=>{fetch(r).then((e=>e.arrayBuffer())).then((r=>{const n=e.getFormat().readFeatures(r,{extent:t,featureProjection:o});e.setFeatures(n)})).catch((t=>e.setState(G.default.ERROR)))}))}));else{const t=e.getImage();l.toPromise((()=>n)).then((r=>{r instanceof Request?fetch(r).then((e=>e.blob())).then((e=>{const r=URL.createObjectURL(e);t.addEventListener("load",(()=>URL.revokeObjectURL(r))),t.addEventListener("error",(()=>URL.revokeObjectURL(r))),t.src=r})).catch((t=>e.setState(G.default.ERROR))):t.src=r}))}});const i=e.url;if(i&&!e.tiles){const n=Pn(i,r.accessToken,r.accessTokenParam||"access_token",t||location.href);if(i.startsWith("mapbox://"))o=Promise.resolve({tileJson:Object.assign({},e,{url:void 0,tiles:n}),tileLoadFunction:a});else{const e={};o=Hn("Source",n[0],r,e).then((function(t){return t.tiles=t.tiles.map((function(n){return"tms"===t.scheme&&(n=n.replace("{y}","{-y}")),Pn(n,r.accessToken,r.accessTokenParam||"access_token",e.request.url)[0]})),Promise.resolve({tileJson:t,tileLoadFunction:a})}))}}else e=Object.assign({},e,{tiles:e.tiles.map((function(n){return"tms"===e.scheme&&(n=n.replace("{y}","{-y}")),Pn(n,r.accessToken,r.accessTokenParam||"access_token",t||location.href)[0]}))}),o=Promise.resolve({tileJson:Object.assign({},e),tileLoadFunction:a});Kn[n]=o}return o}function eo(e,t,r,n){const o=[2*r*t.pixelRatio+t.width,2*r*t.pixelRatio+t.height],a=Wn(o[0],o[1]),i=a.getContext("2d");i.drawImage(e,t.x,t.y,t.width,t.height,r*t.pixelRatio,r*t.pixelRatio,t.width,t.height);const s=i.getImageData(0,0,o[0],o[1]);i.globalCompositeOperation="destination-over",i.fillStyle=`rgba(${255*n.r},${255*n.g},${255*n.b},${n.a})`;const l=s.data;for(let e=0,n=s.width;e0&&i.arc(e,o,r*t.pixelRatio,0,2*Math.PI)}return i.fill(),a}function to(e,t,r){const n=Math.max(0,Math.min(1,(r-e)/(t-e)));return n*n*(3-2*n)}function ro(e,t,r){const n=Wn(t.width,t.height),o=n.getContext("2d");o.drawImage(e,t.x,t.y,t.width,t.height,0,0,t.width,t.height);const a=o.getImageData(0,0,t.width,t.height),i=a.data;for(let e=0,t=a.width;e0?(i[o+0]=Math.round(255*r.r*l),i[o+1]=Math.round(255*r.g*l),i[o+2]=Math.round(255*r.b*l),i[o+3]=Math.round(255*l)):i[o+3]=0}return o.putImageData(a,0,0),n}const no=Array(256).join(" ");function oo(e,t){if(t>=.05){let r="";const n=e.split("\n"),o=no.slice(0,Math.round(t/.1));for(let e=0,t=n.length;e0&&(r+="\n"),r+=n[e].split("").join(o);return r}return e}let ao;function io(){return ao||(ao=Wn(1,1).getContext("2d")),ao}function so(e,t){return io().measureText(e).width+(e.length-1)*t}const lo={};function uo(e,t,r,n){if(-1!==e.indexOf("\n")){const o=e.split("\n"),a=[];for(let e=0,i=o.length;e1){const e=io();e.font=t;const o=e.measureText("M").width*r;let s="";const l=[];for(let e=0,t=i.length;e1;++e){const r=l[e];if(so(r,n)<.35*o){const o=e>0?so(l[e-1],n):1/0,a=e.7*o&&so(a,n)<.6*o){const i=r.split(" "),s=i.pop();so(s,n)<.2*o&&(l[e]=i.join(" "),l[e+1]=s+" "+a),t-=1}}a=l.join("\n")}else a=e;a=oo(a,n),lo[o]=a}return a}const po=/font-family: ?([^;]*);/,co=/("|')/g;let fo;function mo(e){if(!fo){fo={};const e=document.styleSheets;for(let t=0,r=e.length;t`${e.key}: ${e.message}`)).join(", "));return r.value},bo={},xo={zoom:0};let wo,ko;function zo(e,t,r,n,o,a,i){const s=e.id;a||(a={},console.warn("No functionCache provided to getValue()")),a[s]||(a[s]={});const l=a[s];if(!l[r]){let n=(e[t]||bo)[r];const o=pn[`${t}_${e.type}`][r];void 0===n&&(n=o.default);let a=(u=n,Array.isArray(u)&&u.length>0&&"string"==typeof u[0]&&u[0]in Kr);if(!a&&tn(n)&&(n=xe(n,o),a=!0),a){const e=vo(n,o);l[r]=e.evaluate.bind(e)}else"color"==o.type&&(n=ve.parse(n)),l[r]=function(){return n}}var u;return xo.zoom=n,l[r](xo,o,i)}function Mo(e,t,r,n,o){if(!zo(e,"layout",`${n}-allow-overlap`,t,r,o))return"declutter";return zo(e,"layout",`${n}-ignore-placement`,t,r,o)?"none":"obstacle"}function jo(e,t,r,n,o){return o||console.warn("No filterCache provided to evaluateFilter()"),e in o||(o[e]=fn(t).filter),xo.zoom=n,o[e](xo,r)}let So=!1;function qo(e,t){if(e){if(!So&&(0===e.a||0===t))return;const r=e.a;return t=void 0===t?1:t,0===r?"transparent":"rgba("+Math.round(255*e.r/r)+","+Math.round(255*e.g/r)+","+Math.round(255*e.b/r)+","+r*t+")"}return e}const To=/\{[^{}}]*\}/g;function Eo(e,t){return e.replace(To,(function(e){return t[e.slice(1,-1)]||""}))}let $o=!1;const _o={};function Co(e,t,r,n=Jn,o=void 0,a=void 0,i=void 0,s=void 0){if("string"==typeof t&&(t=JSON.parse(t)),8!=t.version)throw new Error("glStyle version 8 required.");let u,p,c;if(_o[Un(t,e)]=Array.from(arguments),a)if("undefined"!=typeof Image){const t=new Image;let r;l.toPromise((()=>a)).then((e=>{e instanceof Request?fetch(e).then((e=>e.blob())).then((e=>{r=URL.createObjectURL(e),t.src=r})).catch((()=>{})):(t.crossOrigin="anonymous",t.src=e,r&&URL.revokeObjectURL(r))})),t.onload=function(){u=t,p=[t.width,t.height],e.changed(),t.onload=null}}else if("undefined"!=typeof WorkerGlobalScope&&self instanceof WorkerGlobalScope){const e=self;e.postMessage({action:"loadImage",src:a}),e.addEventListener("message",(function(e){"imageLoaded"===e.data.action&&e.data.src===a&&(u=e.data.image,p=[u.width,u.height])}))}const f=Sn(t.layers),d={},m=[],y={},h={},g=Nn(t),v=Vn(t);let b;for(let e=0,n=f.length;e=T.maxzoom)continue;const C=T.filter;if(!C||jo(E,C,M,b,v)){let n,l,m,v,E,C;S=T;const A=d.index;if(3==z&&("fill"==T.type||"fill-extrusion"==T.type))if(l=zo(T,"paint",T.type+"-opacity",b,M,g,j),T.type+"-pattern"in _){const e=zo(T,"paint",T.type+"-pattern",b,M,g,j);if(e){const t="string"==typeof e?Eo(e,f):e.toString();if(u&&o&&o[t]){++q,C=k[q],C&&C.getFill()&&!C.getStroke()&&!C.getText()||(C=new N.default({fill:new O.default}),k[q]=C),m=C.getFill(),C.setZIndex(A);const e=t+"."+l;let r=h[e];if(!r){const n=o[t],a=Wn(n.width,n.height),i=a.getContext("2d");i.globalAlpha=l,i.drawImage(u,n.x,n.y,n.width,n.height,0,0,n.width,n.height),r=i.createPattern(a,"repeat"),h[e]=r}m.setColor(r)}}}else n=qo(zo(T,"paint",T.type+"-color",b,M,g,j),l),T.type+"-outline-color"in _&&(E=qo(zo(T,"paint",T.type+"-outline-color",b,M,g,j),l)),E||(E=n),(n||E)&&(++q,C=k[q],(!C||n&&!C.getFill()||!n&&C.getFill()||E&&!C.getStroke()||!E&&C.getStroke()||C.getText())&&(C=new N.default({fill:n?new O.default:void 0,stroke:E?new U.default:void 0}),k[q]=C),n&&(m=C.getFill(),m.setColor(n)),E&&(v=C.getStroke(),v.setColor(E),v.setWidth(.5)),C.setZIndex(A));if(1!=z&&"line"==T.type){n="line-pattern"in _?void 0:qo(zo(T,"paint","line-color",b,M,g,j),zo(T,"paint","line-opacity",b,M,g,j));const e=zo(T,"paint","line-width",b,M,g,j);n&&e>0&&(++q,C=k[q],C&&C.getStroke()&&!C.getFill()&&!C.getText()||(C=new N.default({stroke:new U.default}),k[q]=C),v=C.getStroke(),v.setLineCap(zo(T,"layout","line-cap",b,M,g,j)),v.setLineJoin(zo(T,"layout","line-join",b,M,g,j)),v.setMiterLimit(zo(T,"layout","line-miter-limit",b,M,g,j)),v.setColor(n),v.setWidth(e),v.setLineDash(_["line-dasharray"]?zo(T,"paint","line-dasharray",b,M,g,j).map((function(t){return t*e})):null),C.setZIndex(A))}let I,F,P,G,J,W,Z,B,X,H=!1,Y=null,K=0;if((1==z||2==z)&&"icon-image"in $){const t=zo(T,"layout","icon-image",b,M,g,j);if(t){let n;I="string"==typeof t?Eo(t,f):t.toString();const i=s?s(e,I):void 0;if(u&&o&&o[I]||i){const e=zo(T,"layout","icon-rotation-alignment",b,M,g,j);if(2==z){const t=r.getGeometry();if(t.getFlatMidpoint||t.getFlatMidpoints){const r=t.getExtent();if(Math.sqrt(Math.max(Math.pow((r[2]-r[0])/a,2),Math.pow((r[3]-r[1])/a,2)))>150){const r="MultiLineString"===t.getType()?t.getFlatMidpoints():t.getFlatMidpoint();ko||(wo=[NaN,NaN],ko=new R.default("Point",wo,[],2,{},void 0)),n=ko,wo[0]=r[0],wo[1]=r[1];if("line"===zo(T,"layout","symbol-placement",b,M,g,j)&&"map"===e){const e=t.getStride(),n=t.getFlatCoordinates();for(let t=0,o=n.length-e;t=l){K=Math.atan2(a-s,i-o);break}}}}}}if(2!==z||n){const t=zo(T,"layout","icon-size",b,M,g,j),r=void 0!==_["icon-color"]?zo(T,"paint","icon-color",b,M,g,j):null;if(!r||0!==r.a){const n=zo(T,"paint","icon-halo-color",b,M,g,j),a=zo(T,"paint","icon-halo-width",b,M,g,j);let s=`${I}.${t}.${a}.${n}`;if(null!==r&&(s+=`.${r}`),F=y[s],!F){const l=Mo(T,b,M,"icon",g);let f;"icon-offset"in $&&(f=zo(T,"layout","icon-offset",b,M,g,j).slice(0),f[0]*=t,f[1]*=-t);let d=r?[255*r.r,255*r.g,255*r.b,r.a]:void 0;if(i){const r={color:d,rotateWithView:"map"===e,displacement:f,declutterMode:l,scale:t};"string"==typeof i?r.src=i:(r.img=i,r.imgSize=[i.width,i.height]),F=new D.default(r)}else{const i=o[I];let s,m,y;a?i.sdf?(s=eo(ro(u,i,r||[0,0,0,1]),{x:0,y:0,width:i.width,height:i.height,pixelRatio:i.pixelRatio},a,n),d=void 0):s=eo(u,i,a,n):(i.sdf?(c||(c=ro(u,{x:0,y:0,width:p[0],height:p[1]},{r:1,g:1,b:1,a:1})),s=c):s=u,m=[i.width,i.height],y=[i.x,i.y]),F=new D.default({color:d,img:s,imgSize:p,size:m,offset:y,rotateWithView:"map"===e,scale:t/i.pixelRatio,displacement:f,declutterMode:l})}y[s]=F}}F&&(++q,C=k[q],C&&C.getImage()&&!C.getFill()&&!C.getStroke()||(C=new N.default,k[q]=C),C.setGeometry(n),F.setRotation(K+Gn(zo(T,"layout","icon-rotate",b,M,g,j))),F.setOpacity(zo(T,"paint","icon-opacity",b,M,g,j)),F.setAnchor(go[zo(T,"layout","icon-anchor",b,M,g,j)]),C.setImage(F),Y=C.getText(),C.setText(void 0),C.setZIndex(A),H=!0,P=!1)}else P=!0}}}if(1==z&&"circle"===T.type){++q,C=k[q],C&&C.getImage()&&!C.getFill()&&!C.getStroke()||(C=new N.default,k[q]=C);const e="circle-radius"in _?zo(T,"paint","circle-radius",b,M,g,j):5,t=qo(zo(T,"paint","circle-stroke-color",b,M,g,j),zo(T,"paint","circle-stroke-opacity",b,M,g,j)),r=zo(T,"paint","circle-translate",b,M,g,j),n=qo(zo(T,"paint","circle-color",b,M,g,j),zo(T,"paint","circle-opacity",b,M,g,j)),o=zo(T,"paint","circle-stroke-width",b,M,g,j),a=e+"."+t+"."+n+"."+o+"."+r[0]+"."+r[1];F=y[a],F||(F=new L.default({radius:e,displacement:[r[0],-r[1]],stroke:t&&o>0?new U.default({width:o,color:t}):void 0,fill:n?new O.default({color:n}):void 0,declutterMode:"none"}),y[a]=F),C.setImage(F),Y=C.getText(),C.setText(void 0),C.setGeometry(void 0),C.setZIndex(A),H=!0}if("text-field"in $){Z=Math.round(zo(T,"layout","text-size",b,M,g,j));const e=zo(T,"layout","text-font",b,M,g,j);W=zo(T,"layout","text-line-height",b,M,g,j),J=_n(i?i(e,t.metadata?t.metadata["ol:webfonts"]:void 0):e,Z,W),J.includes("sans-serif")||(J+=",sans-serif"),B=zo(T,"layout","text-letter-spacing",b,M,g,j),X=zo(T,"layout","text-max-width",b,M,g,j);const r=zo(T,"layout","text-field",b,M,g,j);G="object"==typeof r&&r.sections?1===r.sections.length?r.toString():r.sections.reduce(((t,r,n)=>{const o=r.fontStack?r.fontStack.split(","):e,a=_n(i?i(o):o,Z*(r.scale||1),W);let s=r.text;if("\n"===s)return t.push("\n",""),t;if(2==z)return t.push(oo(s,B),a),t;s=uo(s,a,X,B).split("\n");for(let e=0,r=s.length;e0&&t.push("\n",""),t.push(s[e],a);return t}),[]):Eo(r,f).trim(),l=zo(T,"paint","text-opacity",b,M,g,j)}if(G&&l&&!P){H||(++q,C=k[q],C&&C.getText()&&!C.getFill()&&!C.getStroke()||(C=new N.default,k[q]=C),C.setImage(void 0),C.setGeometry(void 0));const e=Mo(T,b,M,"text",g);C.getText()||C.setText(Y),Y=C.getText(),(!Y||"getDeclutterMode"in Y&&Y.getDeclutterMode()!==e)&&(Y=new V.default({padding:[2,2,2,2],declutterMode:e}),C.setText(Y));const t=zo(T,"layout","text-transform",b,M,g,j);"uppercase"==t?G=Array.isArray(G)?G.map(((e,t)=>t%2?e:e.toUpperCase())):G.toUpperCase():"lowercase"==t&&(G=Array.isArray(G)?G.map(((e,t)=>t%2?e:e.toLowerCase())):G.toLowerCase());const r=Array.isArray(G)?G:2==z?oo(G,B):uo(G,J,X,B);if(Y.setText(r),Y.setFont(J),Y.setRotation(Gn(zo(T,"layout","text-rotate",b,M,g,j))),"function"==typeof Y.setKeepUpright){const e=zo(T,"layout","text-keep-upright",b,M,g,j);Y.setKeepUpright(e)}const n=zo(T,"layout","text-anchor",b,M,g,j),o=H||1==z?"point":zo(T,"layout","symbol-placement",b,M,g,j);let a;if("line-center"===o?(Y.setPlacement("line"),a="center"):Y.setPlacement(o),"line"===o&&"function"==typeof Y.setRepeat){const e=zo(T,"layout","symbol-spacing",b,M,g,j);Y.setRepeat(2*e)}Y.setOverflow("point"===o);let i=zo(T,"paint","text-halo-width",b,M,g,j);const s=zo(T,"layout","text-offset",b,M,g,j),u=zo(T,"paint","text-translate",b,M,g,j);let p=0,c=0;if("point"==o){a="center",-1!==n.indexOf("left")?(a="left",c=i):-1!==n.indexOf("right")&&(a="right",c=-i);const e=zo(T,"layout","text-rotation-alignment",b,M,g,j);Y.setRotateWithView("map"==e)}else Y.setMaxAngle(Gn(zo(T,"layout","text-max-angle",b,M,g,j))*G.length/r.length),Y.setRotateWithView(!1);Y.setTextAlign(a);let f="middle";0==n.indexOf("bottom")?(f="bottom",p=-i-.5*(W-1)*Z):0==n.indexOf("top")&&(f="top",p=i+.5*(W-1)*Z),Y.setTextBaseline(f);const d=zo(T,"layout","text-justify",b,M,g,j);Y.setJustify("auto"===d?void 0:d),Y.setOffsetX(s[0]*Z+c+u[0]),Y.setOffsetY(s[1]*Z+p+u[1]),w.setColor(qo(zo(T,"paint","text-color",b,M,g,j),l)),Y.setFill(w);const m=qo(zo(T,"paint","text-halo-color",b,M,g,j),l);if(m&&i>0){x.setColor(m),i*=2;const e=.5*Z;x.setWidth(i<=e?i:e),Y.setStroke(x)}else Y.setStroke(void 0);const y=zo(T,"layout","text-padding",b,M,g,j),h=Y.getPadding();y!==h[0]&&(h[0]=y,h[1]=y,h[2]=y,h[3]=y),C.setZIndex(A)}}}return q>-1?(k.length=q+1,$o&&("set"in r?r.set("mapbox-layer",S):r.getProperties()["mapbox-layer"]=S),k):void 0};return e.setStyle(z),e.set("mapbox-source",b),e.set("mapbox-layers",m),e.set("mapbox-featurestate",e.get("mapbox-featurestate")||{}),z}function Ao(e,t){const r=e[0],n=r.width,o=r.height,a=r.data,i=new Uint8ClampedArray(a.length),s=2*t.resolution,l=n-1,u=o-1,p=[0,0,0,0],c=2*Math.PI,f=Math.PI/2,d=Math.PI*t.sunEl/180,m=Math.PI*t.sunAz/180,y=Math.cos(d),h=Math.sin(d),g=t.highlightColor,v=t.shadowColor,b=t.accentColor,x=t.encoding;let w,k,z,M,j,S,q,T,E,$,_,C,A,I,F,P,L,O,D,R,U,N;function V(e,t="mapbox"){return"mapbox"===t?.1*(256*e[0]*256+256*e[1]+e[2])-1e4:"terrarium"===t?256*e[0]+e[1]+e[2]/256-32768:void 0}for(k=0;k<=u;++k)for(j=0===k?0:k-1,S=k===u?u:k+1,w=0;w<=l;++w)z=0===w?0:w-1,M=w===l?l:w+1,q=4*(k*n+z),p[0]=a[q],p[1]=a[q+1],p[2]=a[q+2],p[3]=a[q+3],T=t.vert*V(p,x),q=4*(k*n+M),p[0]=a[q],p[1]=a[q+1],p[2]=a[q+2],p[3]=a[q+3],E=t.vert*V(p,x),$=(E-T)/s,q=4*(j*n+w),p[0]=a[q],p[1]=a[q+1],p[2]=a[q+2],p[3]=a[q+3],T=t.vert*V(p,x),q=4*(S*n+w),p[0]=a[q],p[1]=a[q+1],p[2]=a[q+2],p[3]=a[q+3],E=t.vert*V(p,x),_=(E-T)/s,A=Math.atan2(_,-$),A=A<0?f-A:A>f?c-A+f:f-A,C=Math.atan(Math.sqrt($*$+_*_)),N=h*Math.cos(C)+y*Math.sin(C)*Math.cos(m-A),I=Math.cos(C),F=255*N,D=Math.min(Math.max(2*t.sunEl,0),1),R=1.875-1.75*t.opacity,U=.5!==t.opacity?f*((Math.pow(R,C)-1)/(Math.pow(R,f)-1)):C,L={r:(1-I)*b.r*D*255,g:(1-I)*b.g*D*255,b:(1-I)*b.b*D*255,a:(1-I)*b.a*D*255},P=Math.abs(((A+m)/Math.PI+.5)%2-1),O={r:(g.r*(1-P)+v.r*P)*F,g:(g.g*(1-P)+v.g*P)*F,b:(g.b*(1-P)+v.b*P)*F,a:(g.a*(1-P)+v.a*P)*F},q=4*(k*n+w),i[q]=L.r*(1-P)+O.r,i[q+1]=L.g*(1-P)+O.g,i[q+2]=L.b*(1-P)+O.b,i[q+3]=a[q+3]*t.opacity*D*Math.sin(U);return new ImageData(i,n,o)}function Io(e,t=512){return e.getExtent()?_.createXYZ({extent:e.getExtent(),tileSize:t,maxZoom:22}).getResolutions():Jn}function Fo(e,t){if(!t.accessToken){t=Object.assign({},t);new URL(e).searchParams.forEach(((e,r)=>{t.accessToken=e,t.accessTokenParam=r}))}return t}function Po(e,t,r="",n={},o=void 0){let a,i,s,l,p=!0;return"string"==typeof r||Array.isArray(r)?l=r:(s=r,l=s.source||s.layers,n=s),"string"==typeof n?(a=n,s={}):(a=n.styleUrl,s=n),!1===s.updateSource&&(p=!1),o||(o=s.resolutions),a||"string"!=typeof t||t.trim().startsWith("{")||(a=t),a&&(a=a.startsWith("data:")?location.href:In(a,s.accessToken),s=Fo(a,s)),new Promise((function(r,n){Yn(t,s).then((function(t){if(8!=t.version)return n(new Error("glStyle version 8 required."));if(!(e instanceof re.default||e instanceof oe.default))return n(new Error("Can only apply to VectorLayer or VectorTileLayer"));const c=e instanceof oe.default?"vector":"geojson";if(l?i=Array.isArray(l)?t.layers.find((function(e){return e.id===l[0]})).source:l:(i=Object.keys(t.sources).find((function(e){return t.sources[e].type===c})),l=i),!i)return n(new Error(`No ${c} source found in the glStyle.`));function f(){if(!p)return Promise.resolve();if(e instanceof oe.default)return Vo(t.sources[i],a,s).then((function(t){const r=e.getSource();r?t!==r&&(r.setTileUrlFunction(t.getTileUrlFunction()),"function"==typeof r.setUrls&&"function"==typeof t.getUrls&&r.setUrls(t.getUrls()),r.format_||(r.format_=t.format_),r.getAttributions()||r.setAttributions(t.getAttributions()),r.getTileLoadFunction()===q.defaultLoadFunction&&r.setTileLoadFunction(t.getTileLoadFunction()),C.equivalent(r.getProjection(),t.getProjection())&&(r.tileGrid=t.getTileGrid())):e.setSource(t);const n=e.getSource().getTileGrid();!isFinite(e.getMaxResolution())&&!isFinite(e.getMinZoom())&&n.getMinZoom()>0&&e.setMaxResolution(Bn(Math.max(0,n.getMinZoom()-1e-12),n.getResolutions()))}));const r=t.sources[i];let n=e.getSource();n&&n.get("mapbox-source")===r||(n=Zo(r,a,s));const o=e.getSource();return o?n!==o&&(o.getAttributions()||o.setAttributions(n.getAttributions()),o.format_||(o.format_=n.getFormat()),o.url_=n.getUrl()):e.setSource(n),Promise.resolve()}let d,m,y,h;function g(){if(h||t.sprite&&!m)h?(e.setStyle(h),f().then(r).catch(n)):n(new Error("Something went wrong trying to apply style."));else{if(s.projection&&!o){const e=C.get(s.projection).getUnits();"m"!==e&&(o=Jn.map((t=>t/E.METERS_PER_UNIT[e])))}h=Co(e,t,l,o,m,y,((e,t=s.webfonts)=>function(e,t="https://cdn.jsdelivr.net/npm/@fontsource/{font-family}/{fontweight}{-fontstyle}.css"){const r=e.toString();if(r in yo)return yo[r];const n=[];for(let t=0,r=e.length;t=1.5?.5:1;const r=.5==d?"@2x":"";let o=e.origin+e.pathname+r+".json"+e.search;new Promise((function(t,r){Hn("Sprite",o,s).then(t).catch((function(n){o=e.origin+e.pathname+".json"+e.search,Hn("Sprite",o,s).then(t).catch(r)}))})).then((function(t){if(void 0===t&&n(new Error("No sprites found.")),m=t,y=e.origin+e.pathname+r+".png"+e.search,s.transformRequest){const e=s.transformRequest(y,"SpriteImage")||y;(e instanceof Request||e instanceof Promise)&&(y=e)}g()})).catch((function(e){n(new Error(`Sprites cannot be loaded: ${o}: ${e.message}`))}))}else g()})).catch(n)}))}const Lo={};function Oo(e,t,r={}){return Yn(t,r).then((function(t){!function(e,t,r){t.layers.some((function(t){if("background"===t.type){if(e instanceof Z.default)return e.setBackground((function(e){return Uo(t,e,r,{})})),!0;if(e instanceof H.default||e instanceof B.default)return e.getLayers().insertAt(0,No(t,r,{})),!0}}))}(e,t,r)}))}function Do(e,t){let r;return e.some((function(e){if(e.id==t)return r=e.source,!0})),r}function Ro(e,t,r){const n=new ee.default({tileJSON:t,tileSize:e.tileSize||t.tileSize||512}),o=n.getTileJSON(),a=n.getTileGrid(),i=C.get(r.projection||"EPSG:3857"),s=function(e,t){const r=e.bounds;if(r){const e=C.fromLonLat([r[0],r[1]],t),n=C.fromLonLat([r[2],r[3]],t);return[e[0],e[1],n[0],n[1]]}return C.get(t).getExtent()}(o,i),l=i.getExtent(),u=o.minzoom||0,p=o.maxzoom||22,c={attributions:n.getAttributions(),projection:i,tileGrid:new Q.default({origin:l?A.getTopLeft(l):a.getOrigin(0),extent:s||a.getExtent(),minZoom:u,resolutions:Io(i,t.tileSize).slice(0,p+1),tileSize:a.getTileSize(0)})};return Array.isArray(o.tiles)?c.urls=o.tiles:c.url=o.tiles,c}function Uo(e,t,r,n){const o={id:e.id,type:e.type},a=e.layout||{},i=e.paint||{};o.paint=i;const s=Zn(t,r.resolutions||Jn);let l;const u=zo(o,"paint","background-color",s,Lo,n);return void 0!==i["background-opacity"]&&(l=zo(o,"paint","background-opacity",s,Lo,n)),"none"==a.visibility?void 0:qo(u,l)}function No(e,t,r){const n=document.createElement("div");return n.className="ol-mapbox-style-background",n.style.position="absolute",n.style.width="100%",n.style.height="100%",new Z.default({source:new K.default({}),render(o){const a=Uo(e,o.viewState.resolution,t,r);return n.style.backgroundColor=a,n}})}function Vo(e,t,r){return new Promise((function(n,o){Qn(e,t,r).then((function({tileJson:t,tileLoadFunction:o}){const a=Ro(e,t,r);a.tileLoadFunction=o,a.format=new X.default,n(new ae.default(a))})).catch(o)}))}function Go(e){return`{bbox-${(e?e.getCode():"EPSG:3857").toLowerCase().replace(/[^a-z0-9]/g,"-")}}`}function Jo(e,t,r){return new Promise((function(n,o){Qn(e,t,r).then((function({tileJson:t,tileLoadFunction:o}){const a=new ee.default({interpolate:void 0===r.interpolate||r.interpolate,transition:0,crossOrigin:"anonymous",tileJSON:t});a.tileGrid=Ro(e,t,r).tileGrid,r.projection&&(a.projection=C.get(r.projection));const i=a.getTileUrlFunction();o&&a.setTileLoadFunction(o),a.setTileUrlFunction((function(e,t,r){const n=Go(r);let o=i(e,t,r);if(-1!=o.indexOf(n)){const t=a.getTileGrid().getTileCoordExtent(e);o=o.replace(n,t.toString())}return o})),a.set("mapbox-source",e),n(a)})).catch((function(e){o(e)}))}))}function Wo(e,t,r){const n=new te.default;return Jo(e,t,r).then((function(e){n.setSource(e)})).catch((function(){n.setSource(void 0)})),n}function Zo(e,t,r){const n=r.projection?new J.default({dataProjection:r.projection}):new J.default,o=e.data,a={};if("string"==typeof o){const[a]=Pn(o,r.accessToken,r.accessTokenParam||"access_token",t||location.href);if(/\{bbox-[0-9a-z-]+\}/.test(a)){const t=(e,t,r)=>{const n=Go(r);return a.replace(n,`${e.join(",")}`)},o=new ne.default({attributions:e.attribution,format:n,loader:(e,n,a,i,s)=>{Hn("GeoJSON","function"==typeof t?t(e,n,a):t,r).then((e=>{const t=o.getFormat().readFeatures(e,{featureProjection:a});o.addFeatures(t),i(t)})).catch((t=>{o.removeLoadedExtent(e),s()}))},strategy:$.bbox});return o.set("mapbox-source",e),o}const i=new ne.default({attributions:e.attribution,format:n,url:a,loader:(e,t,n,o,s)=>{Hn("GeoJSON",a,r).then((e=>{const t=i.getFormat().readFeatures(e,{featureProjection:n});i.addFeatures(t),o(t)})).catch((t=>{i.removeLoadedExtent(e),s()}))}});return i}a.features=n.readFeatures(o,{featureProjection:C.getUserProjection()||"EPSG:3857"});const i=new ne.default(Object.assign({attributions:e.attribution,format:n},a));return i.set("mapbox-source",e),i}function Bo(e,t,r){let n=null;return function(o){e.paint&&"raster-opacity"in e.paint&&o.frameState.viewState.zoom!==n&&(n=o.frameState.viewState.zoom,delete r[e.id],function(e,t,r,n){const o=zo(e,"paint","raster-opacity",r,Lo,n);t.setOpacity(o)}(e,t,n,r))}}function Xo(e,t,r,n){const o=Nn(e),a=e.layers,i=r.type,s=r.source||Do(a,r.ref),l=e.sources[s];let u;if("background"==i)u=No(r,n,o);else if("vector"==l.type)u=function(e,t,r){const n=new oe.default({declutter:!0,visible:!1});return Vo(e,t,r).then((function(t){t.set("mapbox-source",e),n.setSource(t)})).catch((function(e){n.setSource(void 0)})),n}(l,t,n);else if("raster"==l.type)u=Wo(l,t,n),u.setVisible(!r.layout||"none"!==r.layout.visibility),u.on("prerender",Bo(r,u,o));else if("geojson"==l.type)u=function(e,t,r){return new re.default({declutter:!0,source:Zo(e,t,r),visible:!1})}(l,t,n);else if("raster-dem"==l.type&&"hillshade"==r.type){const e=function(e,t,r){const n=Wo(e,t,r);return new W.default({source:new Y.default({operationType:"image",operation:Ao,sources:[n]})})}(l,t,n);u=e,e.getSource().on("beforeoperations",(function(e){const t=e.data;t.resolution=C.getPointResolution(n.projection||"EPSG:3857",e.resolution,A.getCenter(e.extent),"m");const a=Zn(e.resolution,n.resolutions||Jn);t.encoding=l.encoding,t.vert=5*zo(r,"paint","hillshade-exaggeration",a,Lo,o),t.sunAz=zo(r,"paint","hillshade-illumination-direction",a,Lo,o),t.sunEl=35,t.opacity=.3,t.highlightColor=zo(r,"paint","hillshade-highlight-color",a,Lo,o),t.shadowColor=zo(r,"paint","hillshade-shadow-color",a,Lo,o),t.accentColor=zo(r,"paint","hillshade-accent-color",a,Lo,o)})),u.setVisible(!r.layout||"none"!==r.layout.visibility)}const p=s;return u&&u.set("mapbox-source",p),u}function Ho(e,t,r,n){const o=[];let a=null;if(t instanceof H.default){if(a=t.getView(),!a.isDef()&&!a.getRotation()&&!a.getResolutions()){const e=n.projection?C.get(n.projection):a.getProjection();a=new ie.default(Object.assign(a.getProperties(),{maxResolution:Jn[0]/E.METERS_PER_UNIT[e.getUnits()],projection:n.projection||a.getProjection()})),t.setView(a)}"center"in e&&!a.getCenter()&&a.setCenter(C.fromLonLat(e.center,a.getProjection())),"zoom"in e&&void 0===a.getZoom()&&a.setResolution(Jn[0]/E.METERS_PER_UNIT[a.getProjection().getUnits()]/Math.pow(2,e.zoom)),a.getCenter()&&void 0!==a.getZoom()||a.fit(a.getProjection().getExtent(),{nearest:!0,size:t.getSize()})}t.set("mapbox-style",e),t.set("mapbox-metadata",{styleUrl:r,options:n});const i=e.layers;let s,l,u,p=[];for(let a=0,c=i.length;a0||r>0)&&e.setMaxResolution(Math.min(Bn(Math.max(0,i-1e-12),Jn),Bn(Math.max(0,r-1e-12),t.getResolutions()))),s<24&&e.setMinResolution(Bn(s,Jn))}}else i>0&&e.setMaxResolution(Bn(Math.max(0,i-1e-12),Jn));p instanceof ne.default||p instanceof ae.default?Po(e,r,t,Object.assign({styleUrl:n},a)).then((function(){!function(e,t){function r(){const r=t.get("mapbox-style");if(!r)return;const n=Sn(r.layers),o=e.get("mapbox-layers"),a=n.filter((function(e){return o.includes(e.id)})).some((function(e){return!e.layout||!e.layout.visibility||"visible"===e.layout.visibility}));e.get("visible")!==a&&e.setVisible(a)}e.on("change",r),r()}(e,o),l()})).catch(u):l()}else u(new Error("Error accessing data for source "+e.get("mapbox-source")))};e.set("mapbox-layers",t);const c=o.getLayers();-1===c.getArray().indexOf(e)&&c.push(e),e.getSource()?p():e.once("change:source",p)}))}function Qo(e,t){return e.get("mapbox-style").layers.find((function(e){return e.id===t}))}function ea(e,t){const r=e.getLayers().getArray();for(let e=0,n=r.length;e{r.setState("ready")})).catch((e=>{this.dispatchEvent(new na(e));this.getSource().setState("error")}))}}e.MapboxVectorLayer=oa,e.addMapboxLayer=function(e,t,r){const n=e.get("mapbox-style"),o=n.layers;let a,i,s=-1;if(void 0!==r){const t=Qo(e,r);if(void 0===t)throw new Error(`Layer with id "${r}" not found.`);a=o.indexOf(t)}else a=o.length;if(a>0&&o[a-1].source===t.source?(s=a-1,i=-1):ae.id===t.id)))throw new Error(`Layer with id "${t.id}" already exists.`);const l=o[s].id,u=_o[Un(e.get("mapbox-style"),ea(e,l))];if(o.splice(a,0,t),u){const[e,r,n,o,a,s,p,c]=u;if(Array.isArray(n)){const e=n.indexOf(l)+i;n.splice(e,0,t.id)}Co(e,r,n,o,a,s,p,c)}else ea(e,o[s].id).changed();return Promise.resolve()},e.apply=Yo,e.applyBackground=Oo,e.applyStyle=Po,e.default=Yo,e.getFeatureState=function(e,t){const r="getLayers"in e?ta(e,t.source):[e];for(let e=0,n=r.length;ee.id===r)),1);const s=_o[Un(a,n)];if(s){const[e,t,n,o,a,i,l,u]=s;Array.isArray(n)&&n.splice(n.findIndex((e=>e===r)),1),Co(e,t,n,o,a,i,l,u)}else ea(e,r).changed()},e.renderTransparent=function(e){e!==So&&(!function(){for(const e in Ln)delete Ln[e]}(),So=e)},e.setFeatureState=function(e,t,r){const n="getLayers"in e?ta(e,t.source):[e];for(let e=0,o=n.length;e, 2012.\n//\n// https://github.com/deanm/css-color-parser-js\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS\n// IN THE SOFTWARE.\n\n// http://www.w3.org/TR/css3-color/\nvar kCSSColorTable = {\n \"transparent\": [0,0,0,0], \"aliceblue\": [240,248,255,1],\n \"antiquewhite\": [250,235,215,1], \"aqua\": [0,255,255,1],\n \"aquamarine\": [127,255,212,1], \"azure\": [240,255,255,1],\n \"beige\": [245,245,220,1], \"bisque\": [255,228,196,1],\n \"black\": [0,0,0,1], \"blanchedalmond\": [255,235,205,1],\n \"blue\": [0,0,255,1], \"blueviolet\": [138,43,226,1],\n \"brown\": [165,42,42,1], \"burlywood\": [222,184,135,1],\n \"cadetblue\": [95,158,160,1], \"chartreuse\": [127,255,0,1],\n \"chocolate\": [210,105,30,1], \"coral\": [255,127,80,1],\n \"cornflowerblue\": [100,149,237,1], \"cornsilk\": [255,248,220,1],\n \"crimson\": [220,20,60,1], \"cyan\": [0,255,255,1],\n \"darkblue\": [0,0,139,1], \"darkcyan\": [0,139,139,1],\n \"darkgoldenrod\": [184,134,11,1], \"darkgray\": [169,169,169,1],\n \"darkgreen\": [0,100,0,1], \"darkgrey\": [169,169,169,1],\n \"darkkhaki\": [189,183,107,1], \"darkmagenta\": [139,0,139,1],\n \"darkolivegreen\": [85,107,47,1], \"darkorange\": [255,140,0,1],\n \"darkorchid\": [153,50,204,1], \"darkred\": [139,0,0,1],\n \"darksalmon\": [233,150,122,1], \"darkseagreen\": [143,188,143,1],\n \"darkslateblue\": [72,61,139,1], \"darkslategray\": [47,79,79,1],\n \"darkslategrey\": [47,79,79,1], \"darkturquoise\": [0,206,209,1],\n \"darkviolet\": [148,0,211,1], \"deeppink\": [255,20,147,1],\n \"deepskyblue\": [0,191,255,1], \"dimgray\": [105,105,105,1],\n \"dimgrey\": [105,105,105,1], \"dodgerblue\": [30,144,255,1],\n \"firebrick\": [178,34,34,1], \"floralwhite\": [255,250,240,1],\n \"forestgreen\": [34,139,34,1], \"fuchsia\": [255,0,255,1],\n \"gainsboro\": [220,220,220,1], \"ghostwhite\": [248,248,255,1],\n \"gold\": [255,215,0,1], \"goldenrod\": [218,165,32,1],\n \"gray\": [128,128,128,1], \"green\": [0,128,0,1],\n \"greenyellow\": [173,255,47,1], \"grey\": [128,128,128,1],\n \"honeydew\": [240,255,240,1], \"hotpink\": [255,105,180,1],\n \"indianred\": [205,92,92,1], \"indigo\": [75,0,130,1],\n \"ivory\": [255,255,240,1], \"khaki\": [240,230,140,1],\n \"lavender\": [230,230,250,1], \"lavenderblush\": [255,240,245,1],\n \"lawngreen\": [124,252,0,1], \"lemonchiffon\": [255,250,205,1],\n \"lightblue\": [173,216,230,1], \"lightcoral\": [240,128,128,1],\n \"lightcyan\": [224,255,255,1], \"lightgoldenrodyellow\": [250,250,210,1],\n \"lightgray\": [211,211,211,1], \"lightgreen\": [144,238,144,1],\n \"lightgrey\": [211,211,211,1], \"lightpink\": [255,182,193,1],\n \"lightsalmon\": [255,160,122,1], \"lightseagreen\": [32,178,170,1],\n \"lightskyblue\": [135,206,250,1], \"lightslategray\": [119,136,153,1],\n \"lightslategrey\": [119,136,153,1], \"lightsteelblue\": [176,196,222,1],\n \"lightyellow\": [255,255,224,1], \"lime\": [0,255,0,1],\n \"limegreen\": [50,205,50,1], \"linen\": [250,240,230,1],\n \"magenta\": [255,0,255,1], \"maroon\": [128,0,0,1],\n \"mediumaquamarine\": [102,205,170,1], \"mediumblue\": [0,0,205,1],\n \"mediumorchid\": [186,85,211,1], \"mediumpurple\": [147,112,219,1],\n \"mediumseagreen\": [60,179,113,1], \"mediumslateblue\": [123,104,238,1],\n \"mediumspringgreen\": [0,250,154,1], \"mediumturquoise\": [72,209,204,1],\n \"mediumvioletred\": [199,21,133,1], \"midnightblue\": [25,25,112,1],\n \"mintcream\": [245,255,250,1], \"mistyrose\": [255,228,225,1],\n \"moccasin\": [255,228,181,1], \"navajowhite\": [255,222,173,1],\n \"navy\": [0,0,128,1], \"oldlace\": [253,245,230,1],\n \"olive\": [128,128,0,1], \"olivedrab\": [107,142,35,1],\n \"orange\": [255,165,0,1], \"orangered\": [255,69,0,1],\n \"orchid\": [218,112,214,1], \"palegoldenrod\": [238,232,170,1],\n \"palegreen\": [152,251,152,1], \"paleturquoise\": [175,238,238,1],\n \"palevioletred\": [219,112,147,1], \"papayawhip\": [255,239,213,1],\n \"peachpuff\": [255,218,185,1], \"peru\": [205,133,63,1],\n \"pink\": [255,192,203,1], \"plum\": [221,160,221,1],\n \"powderblue\": [176,224,230,1], \"purple\": [128,0,128,1],\n \"rebeccapurple\": [102,51,153,1],\n \"red\": [255,0,0,1], \"rosybrown\": [188,143,143,1],\n \"royalblue\": [65,105,225,1], \"saddlebrown\": [139,69,19,1],\n \"salmon\": [250,128,114,1], \"sandybrown\": [244,164,96,1],\n \"seagreen\": [46,139,87,1], \"seashell\": [255,245,238,1],\n \"sienna\": [160,82,45,1], \"silver\": [192,192,192,1],\n \"skyblue\": [135,206,235,1], \"slateblue\": [106,90,205,1],\n \"slategray\": [112,128,144,1], \"slategrey\": [112,128,144,1],\n \"snow\": [255,250,250,1], \"springgreen\": [0,255,127,1],\n \"steelblue\": [70,130,180,1], \"tan\": [210,180,140,1],\n \"teal\": [0,128,128,1], \"thistle\": [216,191,216,1],\n \"tomato\": [255,99,71,1], \"turquoise\": [64,224,208,1],\n \"violet\": [238,130,238,1], \"wheat\": [245,222,179,1],\n \"white\": [255,255,255,1], \"whitesmoke\": [245,245,245,1],\n \"yellow\": [255,255,0,1], \"yellowgreen\": [154,205,50,1]}\n\nfunction clamp_css_byte(i) { // Clamp to integer 0 .. 255.\n i = Math.round(i); // Seems to be what Chrome does (vs truncation).\n return i < 0 ? 0 : i > 255 ? 255 : i;\n}\n\nfunction clamp_css_float(f) { // Clamp to float 0.0 .. 1.0.\n return f < 0 ? 0 : f > 1 ? 1 : f;\n}\n\nfunction parse_css_int(str) { // int or percentage.\n if (str[str.length - 1] === '%')\n return clamp_css_byte(parseFloat(str) / 100 * 255);\n return clamp_css_byte(parseInt(str));\n}\n\nfunction parse_css_float(str) { // float or percentage.\n if (str[str.length - 1] === '%')\n return clamp_css_float(parseFloat(str) / 100);\n return clamp_css_float(parseFloat(str));\n}\n\nfunction css_hue_to_rgb(m1, m2, h) {\n if (h < 0) h += 1;\n else if (h > 1) h -= 1;\n\n if (h * 6 < 1) return m1 + (m2 - m1) * h * 6;\n if (h * 2 < 1) return m2;\n if (h * 3 < 2) return m1 + (m2 - m1) * (2/3 - h) * 6;\n return m1;\n}\n\nfunction parseCSSColor(css_str) {\n // Remove all whitespace, not compliant, but should just be more accepting.\n var str = css_str.replace(/ /g, '').toLowerCase();\n\n // Color keywords (and transparent) lookup.\n if (str in kCSSColorTable) return kCSSColorTable[str].slice(); // dup.\n\n // #abc and #abc123 syntax.\n if (str[0] === '#') {\n if (str.length === 4) {\n var iv = parseInt(str.substr(1), 16); // TODO(deanm): Stricter parsing.\n if (!(iv >= 0 && iv <= 0xfff)) return null; // Covers NaN.\n return [((iv & 0xf00) >> 4) | ((iv & 0xf00) >> 8),\n (iv & 0xf0) | ((iv & 0xf0) >> 4),\n (iv & 0xf) | ((iv & 0xf) << 4),\n 1];\n } else if (str.length === 7) {\n var iv = parseInt(str.substr(1), 16); // TODO(deanm): Stricter parsing.\n if (!(iv >= 0 && iv <= 0xffffff)) return null; // Covers NaN.\n return [(iv & 0xff0000) >> 16,\n (iv & 0xff00) >> 8,\n iv & 0xff,\n 1];\n }\n\n return null;\n }\n\n var op = str.indexOf('('), ep = str.indexOf(')');\n if (op !== -1 && ep + 1 === str.length) {\n var fname = str.substr(0, op);\n var params = str.substr(op+1, ep-(op+1)).split(',');\n var alpha = 1; // To allow case fallthrough.\n switch (fname) {\n case 'rgba':\n if (params.length !== 4) return null;\n alpha = parse_css_float(params.pop());\n // Fall through.\n case 'rgb':\n if (params.length !== 3) return null;\n return [parse_css_int(params[0]),\n parse_css_int(params[1]),\n parse_css_int(params[2]),\n alpha];\n case 'hsla':\n if (params.length !== 4) return null;\n alpha = parse_css_float(params.pop());\n // Fall through.\n case 'hsl':\n if (params.length !== 3) return null;\n var h = (((parseFloat(params[0]) % 360) + 360) % 360) / 360; // 0 .. 1\n // NOTE(deanm): According to the CSS spec s/l should only be\n // percentages, but we don't bother and let float or percentage.\n var s = parse_css_float(params[1]);\n var l = parse_css_float(params[2]);\n var m2 = l <= 0.5 ? l * (s + 1) : l + s - l * s;\n var m1 = l * 2 - m2;\n return [clamp_css_byte(css_hue_to_rgb(m1, m2, h+1/3) * 255),\n clamp_css_byte(css_hue_to_rgb(m1, m2, h) * 255),\n clamp_css_byte(css_hue_to_rgb(m1, m2, h-1/3) * 255),\n alpha];\n default:\n return null;\n }\n }\n\n return null;\n}\n\ntry { exports.parseCSSColor = parseCSSColor } catch(e) { }\n","// @flow\n\nimport {parseCSSColor} from 'csscolorparser';\n\n/**\n * An RGBA color value. Create instances from color strings using the static\n * method `Color.parse`. The constructor accepts RGB channel values in the range\n * `[0, 1]`, premultiplied by A.\n *\n * @param {number} r The red channel.\n * @param {number} g The green channel.\n * @param {number} b The blue channel.\n * @param {number} a The alpha channel.\n * @private\n */\nclass Color {\n r: number;\n g: number;\n b: number;\n a: number;\n\n constructor(r: number, g: number, b: number, a: number = 1) {\n this.r = r;\n this.g = g;\n this.b = b;\n this.a = a;\n }\n\n static black: Color;\n static white: Color;\n static transparent: Color;\n static red: Color;\n static blue: Color;\n\n /**\n * Parses valid CSS color strings and returns a `Color` instance.\n * @returns A `Color` instance, or `undefined` if the input is not a valid color string.\n */\n static parse(input?: string | Color | null): Color | void {\n if (!input) {\n return undefined;\n }\n\n if (input instanceof Color) {\n return input;\n }\n\n if (typeof input !== 'string') {\n return undefined;\n }\n\n const rgba = parseCSSColor(input);\n if (!rgba) {\n return undefined;\n }\n\n return new Color(\n rgba[0] / 255 * rgba[3],\n rgba[1] / 255 * rgba[3],\n rgba[2] / 255 * rgba[3],\n rgba[3]\n );\n }\n\n /**\n * Returns an RGBA string representing the color value.\n *\n * @returns An RGBA string.\n * @example\n * var purple = new Color.parse('purple');\n * purple.toString; // = \"rgba(128,0,128,1)\"\n * var translucentGreen = new Color.parse('rgba(26, 207, 26, .73)');\n * translucentGreen.toString(); // = \"rgba(26,207,26,0.73)\"\n */\n toString(): string {\n const [r, g, b, a] = this.toArray();\n return `rgba(${Math.round(r)},${Math.round(g)},${Math.round(b)},${a})`;\n }\n\n /**\n * Returns an RGBA array of values representing the color, unpremultiplied by A.\n *\n * @returns An array of RGBA color values in the range [0, 255].\n */\n toArray(): [number, number, number, number] {\n const {r, g, b, a} = this;\n return a === 0 ? [0, 0, 0, 0] : [\n r * 255 / a,\n g * 255 / a,\n b * 255 / a,\n a\n ];\n }\n\n /**\n * Returns a RGBA array of float values representing the color, unpremultiplied by A.\n *\n * @returns An array of RGBA color values in the range [0, 1].\n */\n toArray01(): [number, number, number, number] {\n const {r, g, b, a} = this;\n return a === 0 ? [0, 0, 0, 0] : [\n r / a,\n g / a,\n b / a,\n a\n ];\n }\n\n /**\n * Returns an RGBA array of values representing the color, premultiplied by A.\n *\n * @returns An array of RGBA color values in the range [0, 1].\n */\n toArray01PremultipliedAlpha(): [number, number, number, number] {\n const {r, g, b, a} = this;\n return [\n r,\n g,\n b,\n a\n ];\n }\n}\n\nColor.black = new Color(0, 0, 0, 1);\nColor.white = new Color(1, 1, 1, 1);\nColor.transparent = new Color(0, 0, 0, 0);\nColor.red = new Color(1, 0, 0, 1);\nColor.blue = new Color(0, 0, 1, 1);\n\nexport default Color;\n","// @flow\n\nimport assert from 'assert';\n\nimport type {StylePropertySpecification} from '../style-spec.js';\nimport type {ExpressionSpecification} from '../types.js';\n\nfunction convertLiteral(value) {\n return typeof value === 'object' ? ['literal', value] : value;\n}\n\nexport default function convertFunction(parameters: any, propertySpec: StylePropertySpecification): ExpressionSpecification {\n let stops = parameters.stops;\n if (!stops) {\n // identity function\n return convertIdentityFunction(parameters, propertySpec);\n }\n\n const zoomAndFeatureDependent = stops && typeof stops[0][0] === 'object';\n const featureDependent = zoomAndFeatureDependent || parameters.property !== undefined;\n const zoomDependent = zoomAndFeatureDependent || !featureDependent;\n\n stops = stops.map((stop) => {\n if (!featureDependent && propertySpec.tokens && typeof stop[1] === 'string') {\n return [stop[0], convertTokenString(stop[1])];\n }\n return [stop[0], convertLiteral(stop[1])];\n });\n\n if (zoomAndFeatureDependent) {\n return convertZoomAndPropertyFunction(parameters, propertySpec, stops);\n } else if (zoomDependent) {\n return convertZoomFunction(parameters, propertySpec, stops);\n } else {\n return convertPropertyFunction(parameters, propertySpec, stops);\n }\n}\n\nfunction convertIdentityFunction(parameters, propertySpec): Array {\n const get = ['get', parameters.property];\n\n if (parameters.default === undefined) {\n // By default, expressions for string-valued properties get coerced. To preserve\n // legacy function semantics, insert an explicit assertion instead.\n return propertySpec.type === 'string' ? ['string', get] : get;\n } else if (propertySpec.type === 'enum') {\n return [\n 'match',\n get,\n Object.keys(propertySpec.values),\n get,\n parameters.default\n ];\n } else {\n const expression = [propertySpec.type === 'color' ? 'to-color' : propertySpec.type, get, convertLiteral(parameters.default)];\n if (propertySpec.type === 'array') {\n expression.splice(1, 0, propertySpec.value, propertySpec.length || null);\n }\n return expression;\n }\n}\n\nfunction getInterpolateOperator(parameters) {\n switch (parameters.colorSpace) {\n case 'hcl': return 'interpolate-hcl';\n case 'lab': return 'interpolate-lab';\n default: return 'interpolate';\n }\n}\n\nfunction convertZoomAndPropertyFunction(parameters, propertySpec, stops) {\n const featureFunctionParameters = {};\n const featureFunctionStops = {};\n const zoomStops = [];\n for (let s = 0; s < stops.length; s++) {\n const stop = stops[s];\n const zoom = stop[0].zoom;\n if (featureFunctionParameters[zoom] === undefined) {\n featureFunctionParameters[zoom] = {\n zoom,\n type: parameters.type,\n property: parameters.property,\n default: parameters.default,\n };\n featureFunctionStops[zoom] = [];\n zoomStops.push(zoom);\n }\n featureFunctionStops[zoom].push([stop[0].value, stop[1]]);\n }\n\n // the interpolation type for the zoom dimension of a zoom-and-property\n // function is determined directly from the style property specification\n // for which it's being used: linear for interpolatable properties, step\n // otherwise.\n const functionType = getFunctionType({}, propertySpec);\n if (functionType === 'exponential') {\n const expression = [getInterpolateOperator(parameters), ['linear'], ['zoom']];\n\n for (const z of zoomStops) {\n const output = convertPropertyFunction(featureFunctionParameters[z], propertySpec, featureFunctionStops[z]);\n appendStopPair(expression, z, output, false);\n }\n\n return expression;\n } else {\n const expression = ['step', ['zoom']];\n\n for (const z of zoomStops) {\n const output = convertPropertyFunction(featureFunctionParameters[z], propertySpec, featureFunctionStops[z]);\n appendStopPair(expression, z, output, true);\n }\n\n fixupDegenerateStepCurve(expression);\n\n return expression;\n }\n}\n\nfunction coalesce(a, b) {\n if (a !== undefined) return a;\n if (b !== undefined) return b;\n}\n\nfunction getFallback(parameters, propertySpec) {\n const defaultValue = convertLiteral(coalesce(parameters.default, propertySpec.default));\n\n /*\n * Some fields with type: resolvedImage have an undefined default.\n * Because undefined is an invalid value for resolvedImage, set fallback to\n * an empty string instead of undefined to ensure output\n * passes validation.\n */\n if (defaultValue === undefined && propertySpec.type === 'resolvedImage') {\n return '';\n }\n return defaultValue;\n}\n\nfunction convertPropertyFunction(parameters, propertySpec, stops) {\n const type = getFunctionType(parameters, propertySpec);\n const get = ['get', parameters.property];\n if (type === 'categorical' && typeof stops[0][0] === 'boolean') {\n assert(parameters.stops.length > 0 && parameters.stops.length <= 2);\n const expression = ['case'];\n for (const stop of stops) {\n expression.push(['==', get, stop[0]], stop[1]);\n }\n\n expression.push(getFallback(parameters, propertySpec));\n return expression;\n } else if (type === 'categorical') {\n const expression = ['match', get];\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], false);\n }\n expression.push(getFallback(parameters, propertySpec));\n return expression;\n } else if (type === 'interval') {\n const expression = ['step', ['number', get]];\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], true);\n }\n fixupDegenerateStepCurve(expression);\n return parameters.default === undefined ? expression : [\n 'case',\n ['==', ['typeof', get], 'number'],\n expression,\n convertLiteral(parameters.default)\n ];\n } else if (type === 'exponential') {\n const base = parameters.base !== undefined ? parameters.base : 1;\n const expression = [\n getInterpolateOperator(parameters),\n base === 1 ? [\"linear\"] : [\"exponential\", base],\n [\"number\", get]\n ];\n\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], false);\n }\n return parameters.default === undefined ? expression : [\n 'case',\n ['==', ['typeof', get], 'number'],\n expression,\n convertLiteral(parameters.default)\n ];\n } else {\n throw new Error(`Unknown property function type ${type}`);\n }\n}\n\nfunction convertZoomFunction(parameters, propertySpec, stops, input = ['zoom']) {\n const type = getFunctionType(parameters, propertySpec);\n let expression;\n let isStep = false;\n if (type === 'interval') {\n expression = ['step', input];\n isStep = true;\n } else if (type === 'exponential') {\n const base = parameters.base !== undefined ? parameters.base : 1;\n expression = [getInterpolateOperator(parameters), base === 1 ? [\"linear\"] : [\"exponential\", base], input];\n\n } else {\n throw new Error(`Unknown zoom function type \"${type}\"`);\n }\n\n for (const stop of stops) {\n appendStopPair(expression, stop[0], stop[1], isStep);\n }\n\n fixupDegenerateStepCurve(expression);\n\n return expression;\n}\n\nfunction fixupDegenerateStepCurve(expression) {\n // degenerate step curve (i.e. a constant function): add a noop stop\n if (expression[0] === 'step' && expression.length === 3) {\n expression.push(0);\n expression.push(expression[3]);\n }\n}\n\nfunction appendStopPair(curve, input, output, isStep) {\n // Skip duplicate stop values. They were not validated for functions, but they are for expressions.\n // https://github.com/mapbox/mapbox-gl-js/issues/4107\n if (curve.length > 3 && input === curve[curve.length - 2]) {\n return;\n }\n // step curves don't get the first input value, as it is redundant.\n if (!(isStep && curve.length === 2)) {\n curve.push(input);\n }\n curve.push(output);\n}\n\nfunction getFunctionType(parameters, propertySpec) {\n if (parameters.type) {\n return parameters.type;\n } else {\n assert(propertySpec.expression);\n return (propertySpec.expression: any).interpolated ? 'exponential' : 'interval';\n }\n}\n\n// \"String with {name} token\" => [\"concat\", \"String with \", [\"get\", \"name\"], \" token\"]\nexport function convertTokenString(s: string): string | ExpressionSpecification {\n const result = ['concat'];\n const re = /{([^{}]+)}/g;\n let pos = 0;\n for (let match = re.exec(s); match !== null; match = re.exec(s)) {\n const literal = s.slice(pos, re.lastIndex - match[0].length);\n pos = re.lastIndex;\n if (literal.length > 0) result.push(literal);\n result.push(['get', match[1]]);\n }\n\n if (result.length === 1) {\n return s;\n }\n\n if (pos < s.length) {\n result.push(s.slice(pos));\n } else if (result.length === 2) {\n return ['to-string', result[1]];\n }\n\n return result;\n}\n\n","// @flow\n\nclass ParsingError extends Error {\n key: string;\n message: string;\n constructor(key: string, message: string) {\n super(message);\n this.message = message;\n this.key = key;\n }\n}\n\nexport default ParsingError;\n","// @flow\n\nimport type {Expression} from './expression.js';\n\n/**\n * Tracks `let` bindings during expression parsing.\n * @private\n */\nclass Scope {\n parent: ?Scope;\n bindings: {[_: string]: Expression};\n constructor(parent?: Scope, bindings: Array<[string, Expression]> = []) {\n this.parent = parent;\n this.bindings = {};\n for (const [name, expression] of bindings) {\n this.bindings[name] = expression;\n }\n }\n\n concat(bindings: Array<[string, Expression]>): Scope {\n return new Scope(this, bindings);\n }\n\n get(name: string): Expression {\n if (this.bindings[name]) { return this.bindings[name]; }\n if (this.parent) { return this.parent.get(name); }\n throw new Error(`${name} not found in scope.`);\n }\n\n has(name: string): boolean {\n if (this.bindings[name]) return true;\n return this.parent ? this.parent.has(name) : false;\n }\n}\n\nexport default Scope;\n","// @flow\n\nexport type NullTypeT = { kind: 'null' };\nexport type NumberTypeT = { kind: 'number' };\nexport type StringTypeT = { kind: 'string' };\nexport type BooleanTypeT = { kind: 'boolean' };\nexport type ColorTypeT = { kind: 'color' };\nexport type ObjectTypeT = { kind: 'object' };\nexport type ValueTypeT = { kind: 'value' };\nexport type ErrorTypeT = { kind: 'error' };\nexport type CollatorTypeT = { kind: 'collator' };\nexport type FormattedTypeT = { kind: 'formatted' };\nexport type ResolvedImageTypeT = { kind: 'resolvedImage' };\n\nexport type EvaluationKind = 'constant' | 'source' | 'camera' | 'composite';\n\nexport type Type =\n NullTypeT |\n NumberTypeT |\n StringTypeT |\n BooleanTypeT |\n ColorTypeT |\n ObjectTypeT |\n ValueTypeT |\n ArrayType | // eslint-disable-line no-use-before-define\n ErrorTypeT |\n CollatorTypeT |\n FormattedTypeT |\n ResolvedImageTypeT\n\nexport type ArrayType = {\n kind: 'array',\n itemType: Type,\n N: ?number\n}\n\nexport type NativeType = 'number' | 'string' | 'boolean' | 'null' | 'array' | 'object'\n\nexport const NullType = {kind: 'null'};\nexport const NumberType = {kind: 'number'};\nexport const StringType = {kind: 'string'};\nexport const BooleanType = {kind: 'boolean'};\nexport const ColorType = {kind: 'color'};\nexport const ObjectType = {kind: 'object'};\nexport const ValueType = {kind: 'value'};\nexport const ErrorType = {kind: 'error'};\nexport const CollatorType = {kind: 'collator'};\nexport const FormattedType = {kind: 'formatted'};\nexport const ResolvedImageType = {kind: 'resolvedImage'};\n\nexport function array(itemType: Type, N: ?number): ArrayType {\n return {\n kind: 'array',\n itemType,\n N\n };\n}\n\nexport function toString(type: Type): string {\n if (type.kind === 'array') {\n const itemType = toString(type.itemType);\n return typeof type.N === 'number' ?\n `array<${itemType}, ${type.N}>` :\n type.itemType.kind === 'value' ? 'array' : `array<${itemType}>`;\n } else {\n return type.kind;\n }\n}\n\nconst valueMemberTypes = [\n NullType,\n NumberType,\n StringType,\n BooleanType,\n ColorType,\n FormattedType,\n ObjectType,\n array(ValueType),\n ResolvedImageType\n];\n\n/**\n * Returns null if `t` is a subtype of `expected`; otherwise returns an\n * error message.\n * @private\n */\nexport function checkSubtype(expected: Type, t: Type): ?string {\n if (t.kind === 'error') {\n // Error is a subtype of every type\n return null;\n } else if (expected.kind === 'array') {\n if (t.kind === 'array' &&\n ((t.N === 0 && t.itemType.kind === 'value') || !checkSubtype(expected.itemType, t.itemType)) &&\n (typeof expected.N !== 'number' || expected.N === t.N)) {\n return null;\n }\n } else if (expected.kind === t.kind) {\n return null;\n } else if (expected.kind === 'value') {\n for (const memberType of valueMemberTypes) {\n if (!checkSubtype(memberType, t)) {\n return null;\n }\n }\n }\n\n return `Expected ${toString(expected)} but found ${toString(t)} instead.`;\n}\n\nexport function isValidType(provided: Type, allowedTypes: Array): boolean {\n return allowedTypes.some(t => t.kind === provided.kind);\n}\n\nexport function isValidNativeType(provided: any, allowedTypes: Array): boolean {\n return allowedTypes.some(t => {\n if (t === 'null') {\n return provided === null;\n } else if (t === 'array') {\n return Array.isArray(provided);\n } else if (t === 'object') {\n return provided && !Array.isArray(provided) && typeof provided === 'object';\n } else {\n return t === typeof provided;\n }\n });\n}\n","// @flow\n\n// Flow type declarations for Intl cribbed from\n// https://github.com/facebook/flow/issues/1270\n\ndeclare var Intl: {\n Collator: Class\n};\n\ndeclare class Intl$Collator {\n constructor (\n locales?: string | string[],\n options?: CollatorOptions\n ): Intl$Collator;\n\n static (\n locales?: string | string[],\n options?: CollatorOptions\n ): Intl$Collator;\n\n compare (a: string, b: string): number;\n\n resolvedOptions(): any;\n}\n\ntype CollatorOptions = {\n localeMatcher?: 'lookup' | 'best fit',\n usage?: 'sort' | 'search',\n sensitivity?: 'base' | 'accent' | 'case' | 'variant',\n ignorePunctuation?: boolean,\n numeric?: boolean,\n caseFirst?: 'upper' | 'lower' | 'false'\n}\n\nexport default class Collator {\n locale: string | null;\n sensitivity: 'base' | 'accent' | 'case' | 'variant';\n collator: Intl$Collator;\n\n constructor(caseSensitive: boolean, diacriticSensitive: boolean, locale: string | null) {\n if (caseSensitive)\n this.sensitivity = diacriticSensitive ? 'variant' : 'case';\n else\n this.sensitivity = diacriticSensitive ? 'accent' : 'base';\n\n this.locale = locale;\n this.collator = new Intl.Collator(this.locale ? this.locale : [],\n {sensitivity: this.sensitivity, usage: 'search'});\n }\n\n compare(lhs: string, rhs: string): number {\n return this.collator.compare(lhs, rhs);\n }\n\n resolvedLocale(): string {\n // We create a Collator without \"usage: search\" because we don't want\n // the search options encoded in our result (e.g. \"en-u-co-search\")\n return new Intl.Collator(this.locale ? this.locale : [])\n .resolvedOptions().locale;\n }\n}\n","// @flow\nimport type Color from '../../util/color.js';\nimport type ResolvedImage from '../types/resolved_image.js';\n\nexport class FormattedSection {\n text: string;\n image: ResolvedImage | null;\n scale: number | null;\n fontStack: string | null;\n textColor: Color | null;\n\n constructor(text: string, image: ResolvedImage | null, scale: number | null, fontStack: string | null, textColor: Color | null) {\n // combine characters so that diacritic marks are not separate code points\n this.text = text.normalize ? text.normalize() : text;\n this.image = image;\n this.scale = scale;\n this.fontStack = fontStack;\n this.textColor = textColor;\n }\n}\n\nexport default class Formatted {\n sections: Array;\n\n constructor(sections: Array) {\n this.sections = sections;\n }\n\n static fromString(unformatted: string): Formatted {\n return new Formatted([new FormattedSection(unformatted, null, null, null, null)]);\n }\n\n isEmpty(): boolean {\n if (this.sections.length === 0) return true;\n return !this.sections.some(section => section.text.length !== 0 ||\n (section.image && section.image.name.length !== 0));\n }\n\n static factory(text: Formatted | string): Formatted {\n if (text instanceof Formatted) {\n return text;\n } else {\n return Formatted.fromString(text);\n }\n }\n\n toString(): string {\n if (this.sections.length === 0) return '';\n return this.sections.map(section => section.text).join('');\n }\n\n serialize(): Array {\n const serialized: Array = [\"format\"];\n for (const section of this.sections) {\n if (section.image) {\n serialized.push([\"image\", section.image.name]);\n continue;\n }\n serialized.push(section.text);\n const options: { [key: string]: mixed } = {};\n if (section.fontStack) {\n options[\"text-font\"] = [\"literal\", section.fontStack.split(',')];\n }\n if (section.scale) {\n options[\"font-scale\"] = section.scale;\n }\n if (section.textColor) {\n options[\"text-color\"] = ([\"rgba\"]: Array).concat(section.textColor.toArray());\n }\n serialized.push(options);\n }\n return serialized;\n }\n}\n","// @flow\n\nexport type ResolvedImageOptions = {\n name: string,\n available: boolean\n};\n\nexport default class ResolvedImage {\n name: string;\n available: boolean;\n\n constructor(options: ResolvedImageOptions) {\n this.name = options.name;\n this.available = options.available;\n }\n\n toString(): string {\n return this.name;\n }\n\n static fromString(name: string): ResolvedImage | null {\n if (!name) return null; // treat empty values as no image\n return new ResolvedImage({name, available: false});\n }\n\n serialize(): Array {\n return [\"image\", this.name];\n }\n}\n","// @flow\n\nimport assert from 'assert';\n\nimport Color from '../util/color.js';\nimport Collator from './types/collator.js';\nimport Formatted from './types/formatted.js';\nimport ResolvedImage from './types/resolved_image.js';\nimport {NullType, NumberType, StringType, BooleanType, ColorType, ObjectType, ValueType, CollatorType, FormattedType, ResolvedImageType, array} from './types.js';\n\nimport type {Type} from './types.js';\n\nexport function validateRGBA(r: mixed, g: mixed, b: mixed, a?: mixed): string | null {\n if (!(\n typeof r === 'number' && r >= 0 && r <= 255 &&\n typeof g === 'number' && g >= 0 && g <= 255 &&\n typeof b === 'number' && b >= 0 && b <= 255\n )) {\n const value = typeof a === 'number' ? [r, g, b, a] : [r, g, b];\n return `Invalid rgba value [${value.join(', ')}]: 'r', 'g', and 'b' must be between 0 and 255.`;\n }\n\n if (!(\n typeof a === 'undefined' || (typeof a === 'number' && a >= 0 && a <= 1)\n )) {\n return `Invalid rgba value [${[r, g, b, a].join(', ')}]: 'a' must be between 0 and 1.`;\n }\n\n return null;\n}\n\nexport type Value = null | string | boolean | number | Color | Collator | Formatted | ResolvedImage | $ReadOnlyArray | { +[string]: Value }\n\nexport function isValue(mixed: mixed): boolean {\n if (mixed === null) {\n return true;\n } else if (typeof mixed === 'string') {\n return true;\n } else if (typeof mixed === 'boolean') {\n return true;\n } else if (typeof mixed === 'number') {\n return true;\n } else if (mixed instanceof Color) {\n return true;\n } else if (mixed instanceof Collator) {\n return true;\n } else if (mixed instanceof Formatted) {\n return true;\n } else if (mixed instanceof ResolvedImage) {\n return true;\n } else if (Array.isArray(mixed)) {\n for (const item of mixed) {\n if (!isValue(item)) {\n return false;\n }\n }\n return true;\n } else if (typeof mixed === 'object') {\n for (const key in mixed) {\n if (!isValue(mixed[key])) {\n return false;\n }\n }\n return true;\n } else {\n return false;\n }\n}\n\nexport function typeOf(value: Value): Type {\n if (value === null) {\n return NullType;\n } else if (typeof value === 'string') {\n return StringType;\n } else if (typeof value === 'boolean') {\n return BooleanType;\n } else if (typeof value === 'number') {\n return NumberType;\n } else if (value instanceof Color) {\n return ColorType;\n } else if (value instanceof Collator) {\n return CollatorType;\n } else if (value instanceof Formatted) {\n return FormattedType;\n } else if (value instanceof ResolvedImage) {\n return ResolvedImageType;\n } else if (Array.isArray(value)) {\n const length = value.length;\n let itemType: Type | typeof undefined;\n\n for (const item of value) {\n const t = typeOf(item);\n if (!itemType) {\n itemType = t;\n } else if (itemType === t) {\n continue;\n } else {\n itemType = ValueType;\n break;\n }\n }\n\n return array(itemType || ValueType, length);\n } else {\n assert(typeof value === 'object');\n return ObjectType;\n }\n}\n\nexport function toString(value: Value): string {\n const type = typeof value;\n if (value === null) {\n return '';\n } else if (type === 'string' || type === 'number' || type === 'boolean') {\n return String(value);\n } else if (value instanceof Color || value instanceof Formatted || value instanceof ResolvedImage) {\n return value.toString();\n } else {\n return JSON.stringify(value);\n }\n}\n\nexport {Color, Collator};\n","// @flow\n\nimport assert from 'assert';\nimport {isValue, typeOf, Color} from '../values.js';\nimport Formatted from '../types/formatted.js';\n\nimport type {Type} from '../types.js';\nimport type {Value} from '../values.js';\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\n\nclass Literal implements Expression {\n type: Type;\n value: Value;\n\n constructor(type: Type, value: Value) {\n this.type = type;\n this.value = value;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): void | Literal {\n if (args.length !== 2)\n return context.error(`'literal' expression requires exactly one argument, but found ${args.length - 1} instead.`);\n\n if (!isValue(args[1]))\n return context.error(`invalid value`);\n\n const value = (args[1]: any);\n let type = typeOf(value);\n\n // special case: infer the item type if possible for zero-length arrays\n const expected = context.expectedType;\n if (\n type.kind === 'array' &&\n type.N === 0 &&\n expected &&\n expected.kind === 'array' &&\n (typeof expected.N !== 'number' || expected.N === 0)\n ) {\n type = expected;\n }\n\n return new Literal(type, value);\n }\n\n evaluate(): Value {\n return this.value;\n }\n\n eachChild() {}\n\n outputDefined(): boolean {\n return true;\n }\n\n serialize(): SerializedExpression {\n if (this.type.kind === 'array' || this.type.kind === 'object') {\n return [\"literal\", this.value];\n } else if (this.value instanceof Color) {\n // Constant-folding can generate Literal expressions that you\n // couldn't actually generate with a \"literal\" expression,\n // so we have to implement an equivalent serialization here\n return [\"rgba\"].concat(this.value.toArray());\n } else if (this.value instanceof Formatted) {\n // Same as Color\n return this.value.serialize();\n } else {\n assert(this.value === null ||\n typeof this.value === 'string' ||\n typeof this.value === 'number' ||\n typeof this.value === 'boolean');\n return (this.value: any);\n }\n }\n}\n\nexport default Literal;\n","// @flow\n\nclass RuntimeError {\n name: string;\n message: string;\n\n constructor(message: string) {\n this.name = 'ExpressionEvaluationError';\n this.message = message;\n }\n\n toJSON(): string {\n return this.message;\n }\n}\n\nexport default RuntimeError;\n","// @flow\n\nimport assert from 'assert';\n\nimport {\n ObjectType,\n ValueType,\n StringType,\n NumberType,\n BooleanType,\n checkSubtype,\n toString,\n array\n} from '../types.js';\nimport RuntimeError from '../runtime_error.js';\nimport {typeOf} from '../values.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nconst types = {\n string: StringType,\n number: NumberType,\n boolean: BooleanType,\n object: ObjectType\n};\n\nclass Assertion implements Expression {\n type: Type;\n args: Array;\n\n constructor(type: Type, args: Array) {\n this.type = type;\n this.args = args;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n if (args.length < 2)\n return context.error(`Expected at least one argument.`);\n\n let i = 1;\n let type;\n\n const name: string = (args[0]: any);\n if (name === 'array') {\n let itemType;\n if (args.length > 2) {\n const type = args[1];\n if (typeof type !== 'string' || !(type in types) || type === 'object')\n return context.error('The item type argument of \"array\" must be one of string, number, boolean', 1);\n itemType = types[type];\n i++;\n } else {\n itemType = ValueType;\n }\n\n let N;\n if (args.length > 3) {\n if (args[2] !== null &&\n (typeof args[2] !== 'number' ||\n args[2] < 0 ||\n args[2] !== Math.floor(args[2]))\n ) {\n return context.error('The length argument to \"array\" must be a positive integer literal', 2);\n }\n N = args[2];\n i++;\n }\n\n type = array(itemType, N);\n } else {\n assert(types[name], name);\n type = types[name];\n }\n\n const parsed = [];\n for (; i < args.length; i++) {\n const input = context.parse(args[i], i, ValueType);\n if (!input) return null;\n parsed.push(input);\n }\n\n return new Assertion(type, parsed);\n }\n\n evaluate(ctx: EvaluationContext): any | null {\n for (let i = 0; i < this.args.length; i++) {\n const value = this.args[i].evaluate(ctx);\n const error = checkSubtype(this.type, typeOf(value));\n if (!error) {\n return value;\n } else if (i === this.args.length - 1) {\n throw new RuntimeError(`Expected value to be of type ${toString(this.type)}, but found ${toString(typeOf(value))} instead.`);\n }\n }\n\n assert(false);\n return null;\n }\n\n eachChild(fn: (_: Expression) => void) {\n this.args.forEach(fn);\n }\n\n outputDefined(): boolean {\n return this.args.every(arg => arg.outputDefined());\n }\n\n serialize(): SerializedExpression {\n const type = this.type;\n const serialized = [type.kind];\n if (type.kind === 'array') {\n const itemType = type.itemType;\n if (itemType.kind === 'string' ||\n itemType.kind === 'number' ||\n itemType.kind === 'boolean') {\n serialized.push(itemType.kind);\n const N = type.N;\n if (typeof N === 'number' || this.args.length > 1) {\n serialized.push(N);\n }\n }\n }\n return serialized.concat(this.args.map(arg => arg.serialize()));\n }\n}\n\nexport default Assertion;\n","// @flow\n\nimport {NumberType, ValueType, FormattedType, array, StringType, ColorType, ResolvedImageType} from '../types.js';\nimport Formatted, {FormattedSection} from '../types/formatted.js';\nimport {toString, typeOf} from '../values.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type {Type} from '../types.js';\n\ntype FormattedSectionExpression = {\n // Content of a section may be Image expression or other\n // type of expression that is coercable to 'string'.\n content: Expression,\n scale: Expression | null;\n font: Expression | null;\n textColor: Expression | null;\n}\n\nexport default class FormatExpression implements Expression {\n type: Type;\n sections: Array;\n\n constructor(sections: Array) {\n this.type = FormattedType;\n this.sections = sections;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n if (args.length < 2) {\n return context.error(`Expected at least one argument.`);\n }\n\n const firstArg = args[1];\n if (!Array.isArray(firstArg) && typeof firstArg === 'object') {\n return context.error(`First argument must be an image or text section.`);\n }\n\n const sections: Array = [];\n let nextTokenMayBeObject = false;\n for (let i = 1; i <= args.length - 1; ++i) {\n const arg = (args[i]: any);\n\n if (nextTokenMayBeObject && typeof arg === \"object\" && !Array.isArray(arg)) {\n nextTokenMayBeObject = false;\n\n let scale = null;\n if (arg['font-scale']) {\n scale = context.parse(arg['font-scale'], 1, NumberType);\n if (!scale) return null;\n }\n\n let font = null;\n if (arg['text-font']) {\n font = context.parse(arg['text-font'], 1, array(StringType));\n if (!font) return null;\n }\n\n let textColor = null;\n if (arg['text-color']) {\n textColor = context.parse(arg['text-color'], 1, ColorType);\n if (!textColor) return null;\n }\n\n const lastExpression = sections[sections.length - 1];\n lastExpression.scale = scale;\n lastExpression.font = font;\n lastExpression.textColor = textColor;\n } else {\n const content = context.parse(args[i], 1, ValueType);\n if (!content) return null;\n\n const kind = content.type.kind;\n if (kind !== 'string' && kind !== 'value' && kind !== 'null' && kind !== 'resolvedImage')\n return context.error(`Formatted text type must be 'string', 'value', 'image' or 'null'.`);\n\n nextTokenMayBeObject = true;\n sections.push({content, scale: null, font: null, textColor: null});\n }\n }\n\n return new FormatExpression(sections);\n }\n\n evaluate(ctx: EvaluationContext): Formatted {\n const evaluateSection = section => {\n const evaluatedContent = section.content.evaluate(ctx);\n if (typeOf(evaluatedContent) === ResolvedImageType) {\n return new FormattedSection('', evaluatedContent, null, null, null);\n }\n\n return new FormattedSection(\n toString(evaluatedContent),\n null,\n section.scale ? section.scale.evaluate(ctx) : null,\n section.font ? section.font.evaluate(ctx).join(',') : null,\n section.textColor ? section.textColor.evaluate(ctx) : null\n );\n };\n\n return new Formatted(this.sections.map(evaluateSection));\n }\n\n eachChild(fn: (_: Expression) => void) {\n for (const section of this.sections) {\n fn(section.content);\n if (section.scale) {\n fn(section.scale);\n }\n if (section.font) {\n fn(section.font);\n }\n if (section.textColor) {\n fn(section.textColor);\n }\n }\n }\n\n outputDefined(): boolean {\n // Technically the combinatoric set of all children\n // Usually, this.text will be undefined anyway\n return false;\n }\n\n serialize(): SerializedExpression {\n const serialized = [\"format\"];\n for (const section of this.sections) {\n serialized.push(section.content.serialize());\n const options = {};\n if (section.scale) {\n options['font-scale'] = section.scale.serialize();\n }\n if (section.font) {\n options['text-font'] = section.font.serialize();\n }\n if (section.textColor) {\n options['text-color'] = section.textColor.serialize();\n }\n serialized.push(options);\n }\n return serialized;\n }\n}\n","// @flow\n\nimport {ResolvedImageType, StringType} from '../types.js';\nimport ResolvedImage from '../types/resolved_image.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type {Type} from '../types.js';\n\nexport default class ImageExpression implements Expression {\n type: Type;\n input: Expression;\n\n constructor(input: Expression) {\n this.type = ResolvedImageType;\n this.input = input;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n if (args.length !== 2) {\n return context.error(`Expected two arguments.`);\n }\n\n const name = context.parse(args[1], 1, StringType);\n if (!name) return context.error(`No image name provided.`);\n\n return new ImageExpression(name);\n }\n\n evaluate(ctx: EvaluationContext): null | ResolvedImage {\n const evaluatedImageName = this.input.evaluate(ctx);\n\n const value = ResolvedImage.fromString(evaluatedImageName);\n if (value && ctx.availableImages) value.available = ctx.availableImages.indexOf(evaluatedImageName) > -1;\n\n return value;\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.input);\n }\n\n outputDefined(): boolean {\n // The output of image is determined by the list of available images in the evaluation context\n return false;\n }\n\n serialize(): SerializedExpression {\n return [\"image\", this.input.serialize()];\n }\n}\n","// @flow\n\nimport assert from 'assert';\n\nimport {BooleanType, ColorType, NumberType, StringType, ValueType} from '../types.js';\nimport {Color, toString as valueToString, validateRGBA} from '../values.js';\nimport RuntimeError from '../runtime_error.js';\nimport Formatted from '../types/formatted.js';\nimport FormatExpression from '../definitions/format.js';\nimport ImageExpression from '../definitions/image.js';\nimport ResolvedImage from '../types/resolved_image.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nconst types = {\n 'to-boolean': BooleanType,\n 'to-color': ColorType,\n 'to-number': NumberType,\n 'to-string': StringType\n};\n\n/**\n * Special form for error-coalescing coercion expressions \"to-number\",\n * \"to-color\". Since these coercions can fail at runtime, they accept multiple\n * arguments, only evaluating one at a time until one succeeds.\n *\n * @private\n */\nclass Coercion implements Expression {\n type: Type;\n args: Array;\n\n constructor(type: Type, args: Array) {\n this.type = type;\n this.args = args;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n if (args.length < 2)\n return context.error(`Expected at least one argument.`);\n\n const name: string = (args[0]: any);\n assert(types[name], name);\n\n if ((name === 'to-boolean' || name === 'to-string') && args.length !== 2)\n return context.error(`Expected one argument.`);\n\n const type = types[name];\n\n const parsed = [];\n for (let i = 1; i < args.length; i++) {\n const input = context.parse(args[i], i, ValueType);\n if (!input) return null;\n parsed.push(input);\n }\n\n return new Coercion(type, parsed);\n }\n\n evaluate(ctx: EvaluationContext): null | boolean | number | string | Color | Formatted | ResolvedImage {\n if (this.type.kind === 'boolean') {\n return Boolean(this.args[0].evaluate(ctx));\n } else if (this.type.kind === 'color') {\n let input;\n let error;\n for (const arg of this.args) {\n input = arg.evaluate(ctx);\n error = null;\n if (input instanceof Color) {\n return input;\n } else if (typeof input === 'string') {\n const c = ctx.parseColor(input);\n if (c) return c;\n } else if (Array.isArray(input)) {\n if (input.length < 3 || input.length > 4) {\n error = `Invalid rbga value ${JSON.stringify(input)}: expected an array containing either three or four numeric values.`;\n } else {\n error = validateRGBA(input[0], input[1], input[2], input[3]);\n }\n if (!error) {\n return new Color((input[0]: any) / 255, (input[1]: any) / 255, (input[2]: any) / 255, (input[3]: any));\n }\n }\n }\n throw new RuntimeError(error || `Could not parse color from value '${typeof input === 'string' ? input : String(JSON.stringify(input))}'`);\n } else if (this.type.kind === 'number') {\n let value = null;\n for (const arg of this.args) {\n value = arg.evaluate(ctx);\n if (value === null) return 0;\n const num = Number(value);\n if (isNaN(num)) continue;\n return num;\n }\n throw new RuntimeError(`Could not convert ${JSON.stringify(value)} to number.`);\n } else if (this.type.kind === 'formatted') {\n // There is no explicit 'to-formatted' but this coercion can be implicitly\n // created by properties that expect the 'formatted' type.\n return Formatted.fromString(valueToString(this.args[0].evaluate(ctx)));\n } else if (this.type.kind === 'resolvedImage') {\n return ResolvedImage.fromString(valueToString(this.args[0].evaluate(ctx)));\n } else {\n return valueToString(this.args[0].evaluate(ctx));\n }\n }\n\n eachChild(fn: (_: Expression) => void) {\n this.args.forEach(fn);\n }\n\n outputDefined(): boolean {\n return this.args.every(arg => arg.outputDefined());\n }\n\n serialize(): SerializedExpression {\n if (this.type.kind === 'formatted') {\n return new FormatExpression([{content: this.args[0], scale: null, font: null, textColor: null}]).serialize();\n }\n\n if (this.type.kind === 'resolvedImage') {\n return new ImageExpression(this.args[0]).serialize();\n }\n\n const serialized = [`to-${this.type.kind}`];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n}\n\nexport default Coercion;\n","// @flow\n\nimport {Color} from './values.js';\n\nimport type Point from '@mapbox/point-geometry';\nimport type {FormattedSection} from './types/formatted.js';\nimport type {GlobalProperties, Feature, FeatureState} from './index.js';\nimport type {CanonicalTileID} from '../../source/tile_id.js';\nimport type {FeatureDistanceData} from '../feature_filter/index.js';\n\nconst geometryTypes = ['Unknown', 'Point', 'LineString', 'Polygon'];\n\nclass EvaluationContext {\n globals: GlobalProperties;\n feature: ?Feature;\n featureState: ?FeatureState;\n formattedSection: ?FormattedSection;\n availableImages: ?Array;\n canonical: null | CanonicalTileID;\n featureTileCoord: ?Point;\n featureDistanceData: ?FeatureDistanceData;\n\n _parseColorCache: {[_: string]: ?Color};\n\n constructor() {\n this.globals = (null: any);\n this.feature = null;\n this.featureState = null;\n this.formattedSection = null;\n this._parseColorCache = {};\n this.availableImages = null;\n this.canonical = null;\n this.featureTileCoord = null;\n this.featureDistanceData = null;\n }\n\n id(): number | null {\n return this.feature && this.feature.id !== undefined ? this.feature.id : null;\n }\n\n geometryType(): null | string {\n return this.feature ? typeof this.feature.type === 'number' ? geometryTypes[this.feature.type] : this.feature.type : null;\n }\n\n geometry(): ?Array> {\n return this.feature && 'geometry' in this.feature ? this.feature.geometry : null;\n }\n\n canonicalID(): null | CanonicalTileID {\n return this.canonical;\n }\n\n properties(): {[string]: any} {\n return (this.feature && this.feature.properties) || {};\n }\n\n distanceFromCenter(): number {\n if (this.featureTileCoord && this.featureDistanceData) {\n\n const c = this.featureDistanceData.center;\n const scale = this.featureDistanceData.scale;\n const {x, y} = this.featureTileCoord;\n\n // Calculate the distance vector `d` (left handed)\n const dX = x * scale - c[0];\n const dY = y * scale - c[1];\n\n // The bearing vector `b` (left handed)\n const bX = this.featureDistanceData.bearing[0];\n const bY = this.featureDistanceData.bearing[1];\n\n // Distance is calculated as `dot(d, v)`\n const dist = (bX * dX + bY * dY);\n return dist;\n }\n\n return 0;\n }\n\n parseColor(input: string): ?Color {\n let cached = this._parseColorCache[input];\n if (!cached) {\n cached = this._parseColorCache[input] = Color.parse(input);\n }\n return cached;\n }\n}\n\nexport default EvaluationContext;\n","// @flow\n\nimport {toString} from './types.js';\n\nimport ParsingContext from './parsing_context.js';\nimport EvaluationContext from './evaluation_context.js';\nimport assert from 'assert';\n\nimport type {Expression, ExpressionRegistry} from './expression.js';\nimport type {Type} from './types.js';\nimport type {Value} from './values.js';\n\nexport type Varargs = {| type: Type |};\ntype Signature = Array | Varargs;\ntype Evaluate = (EvaluationContext, Array) => Value;\ntype Definition = [Type, Signature, Evaluate] |\n {|type: Type, overloads: Array<[Signature, Evaluate]>|};\n\nclass CompoundExpression implements Expression {\n name: string;\n type: Type;\n _evaluate: Evaluate;\n args: Array;\n\n static definitions: {[_: string]: Definition };\n\n constructor(name: string, type: Type, evaluate: Evaluate, args: Array) {\n this.name = name;\n this.type = type;\n this._evaluate = evaluate;\n this.args = args;\n }\n\n evaluate(ctx: EvaluationContext): Value {\n return this._evaluate(ctx, this.args);\n }\n\n eachChild(fn: (_: Expression) => void) {\n this.args.forEach(fn);\n }\n\n outputDefined(): boolean {\n return false;\n }\n\n serialize(): Array {\n return [this.name].concat(this.args.map(arg => arg.serialize()));\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n const op: string = (args[0]: any);\n const definition = CompoundExpression.definitions[op];\n if (!definition) {\n return context.error(`Unknown expression \"${op}\". If you wanted a literal array, use [\"literal\", [...]].`, 0);\n }\n\n // Now check argument types against each signature\n const type = Array.isArray(definition) ?\n definition[0] : definition.type;\n\n const availableOverloads = Array.isArray(definition) ?\n [[definition[1], definition[2]]] :\n definition.overloads;\n\n const overloads = availableOverloads.filter(([signature]) => (\n !Array.isArray(signature) || // varags\n signature.length === args.length - 1 // correct param count\n ));\n\n let signatureContext: ParsingContext = (null: any);\n\n for (const [params, evaluate] of overloads) {\n // Use a fresh context for each attempted signature so that, if\n // we eventually succeed, we haven't polluted `context.errors`.\n signatureContext = new ParsingContext(context.registry, context.path, null, context.scope);\n\n // First parse all the args, potentially coercing to the\n // types expected by this overload.\n const parsedArgs: Array = [];\n let argParseFailed = false;\n for (let i = 1; i < args.length; i++) {\n const arg = args[i];\n const expectedType = Array.isArray(params) ?\n params[i - 1] :\n params.type;\n\n const parsed = signatureContext.parse(arg, 1 + parsedArgs.length, expectedType);\n if (!parsed) {\n argParseFailed = true;\n break;\n }\n parsedArgs.push(parsed);\n }\n if (argParseFailed) {\n // Couldn't coerce args of this overload to expected type, move\n // on to next one.\n continue;\n }\n\n if (Array.isArray(params)) {\n if (params.length !== parsedArgs.length) {\n signatureContext.error(`Expected ${params.length} arguments, but found ${parsedArgs.length} instead.`);\n continue;\n }\n }\n\n for (let i = 0; i < parsedArgs.length; i++) {\n const expected = Array.isArray(params) ? params[i] : params.type;\n const arg = parsedArgs[i];\n signatureContext.concat(i + 1).checkSubtype(expected, arg.type);\n }\n\n if (signatureContext.errors.length === 0) {\n return new CompoundExpression(op, type, evaluate, parsedArgs);\n }\n }\n\n assert(!signatureContext || signatureContext.errors.length > 0);\n\n if (overloads.length === 1) {\n context.errors.push(...signatureContext.errors);\n } else {\n const expected = overloads.length ? overloads : availableOverloads;\n const signatures = expected\n .map(([params]) => stringifySignature(params))\n .join(' | ');\n\n const actualTypes = [];\n // For error message, re-parse arguments without trying to\n // apply any coercions\n for (let i = 1; i < args.length; i++) {\n const parsed = context.parse(args[i], 1 + actualTypes.length);\n if (!parsed) return null;\n actualTypes.push(toString(parsed.type));\n }\n context.error(`Expected arguments of type ${signatures}, but found (${actualTypes.join(', ')}) instead.`);\n }\n\n return null;\n }\n\n static register(\n registry: ExpressionRegistry,\n definitions: {[_: string]: Definition }\n ) {\n assert(!CompoundExpression.definitions);\n CompoundExpression.definitions = definitions;\n for (const name in definitions) {\n registry[name] = CompoundExpression;\n }\n }\n}\n\nfunction stringifySignature(signature: Signature): string {\n if (Array.isArray(signature)) {\n return `(${signature.map(toString).join(', ')})`;\n } else {\n return `(${toString(signature.type)}...)`;\n }\n}\n\nexport default CompoundExpression;\n","// @flow\n\nimport {StringType, BooleanType, CollatorType} from '../types.js';\nimport Collator from '../types/collator.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type {Type} from '../types.js';\n\nexport default class CollatorExpression implements Expression {\n type: Type;\n caseSensitive: Expression;\n diacriticSensitive: Expression;\n locale: Expression | null;\n\n constructor(caseSensitive: Expression, diacriticSensitive: Expression, locale: Expression | null) {\n this.type = CollatorType;\n this.locale = locale;\n this.caseSensitive = caseSensitive;\n this.diacriticSensitive = diacriticSensitive;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n if (args.length !== 2)\n return context.error(`Expected one argument.`);\n\n const options = (args[1]: any);\n if (typeof options !== \"object\" || Array.isArray(options))\n return context.error(`Collator options argument must be an object.`);\n\n const caseSensitive = context.parse(\n options['case-sensitive'] === undefined ? false : options['case-sensitive'], 1, BooleanType);\n if (!caseSensitive) return null;\n\n const diacriticSensitive = context.parse(\n options['diacritic-sensitive'] === undefined ? false : options['diacritic-sensitive'], 1, BooleanType);\n if (!diacriticSensitive) return null;\n\n let locale = null;\n if (options['locale']) {\n locale = context.parse(options['locale'], 1, StringType);\n if (!locale) return null;\n }\n\n return new CollatorExpression(caseSensitive, diacriticSensitive, locale);\n }\n\n evaluate(ctx: EvaluationContext): Collator {\n return new Collator(this.caseSensitive.evaluate(ctx), this.diacriticSensitive.evaluate(ctx), this.locale ? this.locale.evaluate(ctx) : null);\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.caseSensitive);\n fn(this.diacriticSensitive);\n if (this.locale) {\n fn(this.locale);\n }\n }\n\n outputDefined(): boolean {\n // Technically the set of possible outputs is the combinatoric set of Collators produced\n // by all possible outputs of locale/caseSensitive/diacriticSensitive\n // But for the primary use of Collators in comparison operators, we ignore the Collator's\n // possible outputs anyway, so we can get away with leaving this false for now.\n return false;\n }\n\n serialize(): SerializedExpression {\n const options = {};\n options['case-sensitive'] = this.caseSensitive.serialize();\n options['diacritic-sensitive'] = this.diacriticSensitive.serialize();\n if (this.locale) {\n options['locale'] = this.locale.serialize();\n }\n return [\"collator\", options];\n }\n}\n","// @flow\n\nimport {isValue} from '../values.js';\nimport type {Type} from '../types.js';\nimport {BooleanType} from '../types.js';\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {GeoJSON, GeoJSONPolygon, GeoJSONMultiPolygon} from '@mapbox/geojson-types';\nimport type {CanonicalTileID} from '../../../source/tile_id.js';\n\ntype GeoJSONPolygons =| GeoJSONPolygon | GeoJSONMultiPolygon;\n\n// minX, minY, maxX, maxY\ntype BBox = [number, number, number, number];\nconst EXTENT = 8192;\n\nfunction updateBBox(bbox: BBox, coord: [number, number]) {\n bbox[0] = Math.min(bbox[0], coord[0]);\n bbox[1] = Math.min(bbox[1], coord[1]);\n bbox[2] = Math.max(bbox[2], coord[0]);\n bbox[3] = Math.max(bbox[3], coord[1]);\n}\n\nfunction mercatorXfromLng(lng: number) {\n return (180 + lng) / 360;\n}\n\nfunction mercatorYfromLat(lat: number) {\n return (180 - (180 / Math.PI * Math.log(Math.tan(Math.PI / 4 + lat * Math.PI / 360)))) / 360;\n}\n\nfunction boxWithinBox(bbox1: BBox, bbox2: BBox) {\n if (bbox1[0] <= bbox2[0]) return false;\n if (bbox1[2] >= bbox2[2]) return false;\n if (bbox1[1] <= bbox2[1]) return false;\n if (bbox1[3] >= bbox2[3]) return false;\n return true;\n}\n\nfunction getTileCoordinates(p, canonical: CanonicalTileID) {\n const x = mercatorXfromLng(p[0]);\n const y = mercatorYfromLat(p[1]);\n const tilesAtZoom = Math.pow(2, canonical.z);\n return [Math.round(x * tilesAtZoom * EXTENT), Math.round(y * tilesAtZoom * EXTENT)];\n}\n\nfunction onBoundary(p, p1, p2) {\n const x1 = p[0] - p1[0];\n const y1 = p[1] - p1[1];\n const x2 = p[0] - p2[0];\n const y2 = p[1] - p2[1];\n return (x1 * y2 - x2 * y1 === 0) && (x1 * x2 <= 0) && (y1 * y2 <= 0);\n}\n\nfunction rayIntersect(p, p1, p2) {\n return ((p1[1] > p[1]) !== (p2[1] > p[1])) && (p[0] < (p2[0] - p1[0]) * (p[1] - p1[1]) / (p2[1] - p1[1]) + p1[0]);\n}\n\n// ray casting algorithm for detecting if point is in polygon\nfunction pointWithinPolygon(point, rings) {\n let inside = false;\n for (let i = 0, len = rings.length; i < len; i++) {\n const ring = rings[i];\n for (let j = 0, len2 = ring.length; j < len2 - 1; j++) {\n if (onBoundary(point, ring[j], ring[j + 1])) return false;\n if (rayIntersect(point, ring[j], ring[j + 1])) inside = !inside;\n }\n }\n return inside;\n}\n\nfunction pointWithinPolygons(point, polygons) {\n for (let i = 0; i < polygons.length; i++) {\n if (pointWithinPolygon(point, polygons[i])) return true;\n }\n return false;\n}\n\nfunction perp(v1, v2) {\n return (v1[0] * v2[1] - v1[1] * v2[0]);\n}\n\n// check if p1 and p2 are in different sides of line segment q1->q2\nfunction twoSided(p1, p2, q1, q2) {\n // q1->p1 (x1, y1), q1->p2 (x2, y2), q1->q2 (x3, y3)\n const x1 = p1[0] - q1[0];\n const y1 = p1[1] - q1[1];\n const x2 = p2[0] - q1[0];\n const y2 = p2[1] - q1[1];\n const x3 = q2[0] - q1[0];\n const y3 = q2[1] - q1[1];\n const det1 = (x1 * y3 - x3 * y1);\n const det2 = (x2 * y3 - x3 * y2);\n if ((det1 > 0 && det2 < 0) || (det1 < 0 && det2 > 0)) return true;\n return false;\n}\n// a, b are end points for line segment1, c and d are end points for line segment2\nfunction lineIntersectLine(a, b, c, d) {\n // check if two segments are parallel or not\n // precondition is end point a, b is inside polygon, if line a->b is\n // parallel to polygon edge c->d, then a->b won't intersect with c->d\n const vectorP = [b[0] - a[0], b[1] - a[1]];\n const vectorQ = [d[0] - c[0], d[1] - c[1]];\n if (perp(vectorQ, vectorP) === 0) return false;\n\n // If lines are intersecting with each other, the relative location should be:\n // a and b lie in different sides of segment c->d\n // c and d lie in different sides of segment a->b\n if (twoSided(a, b, c, d) && twoSided(c, d, a, b)) return true;\n return false;\n}\n\nfunction lineIntersectPolygon(p1, p2, polygon) {\n for (const ring of polygon) {\n // loop through every edge of the ring\n for (let j = 0; j < ring.length - 1; ++j) {\n if (lineIntersectLine(p1, p2, ring[j], ring[j + 1])) {\n return true;\n }\n }\n }\n return false;\n}\n\nfunction lineStringWithinPolygon(line, polygon) {\n // First, check if geometry points of line segments are all inside polygon\n for (let i = 0; i < line.length; ++i) {\n if (!pointWithinPolygon(line[i], polygon)) {\n return false;\n }\n }\n\n // Second, check if there is line segment intersecting polygon edge\n for (let i = 0; i < line.length - 1; ++i) {\n if (lineIntersectPolygon(line[i], line[i + 1], polygon)) {\n return false;\n }\n }\n return true;\n}\n\nfunction lineStringWithinPolygons(line, polygons) {\n for (let i = 0; i < polygons.length; i++) {\n if (lineStringWithinPolygon(line, polygons[i])) return true;\n }\n return false;\n}\n\nfunction getTilePolygon(coordinates, bbox: BBox, canonical: CanonicalTileID) {\n const polygon = [];\n for (let i = 0; i < coordinates.length; i++) {\n const ring = [];\n for (let j = 0; j < coordinates[i].length; j++) {\n const coord = getTileCoordinates(coordinates[i][j], canonical);\n updateBBox(bbox, coord);\n ring.push(coord);\n }\n polygon.push(ring);\n }\n return polygon;\n}\n\nfunction getTilePolygons(coordinates, bbox, canonical: CanonicalTileID) {\n const polygons = [];\n for (let i = 0; i < coordinates.length; i++) {\n const polygon = getTilePolygon(coordinates[i], bbox, canonical);\n polygons.push(polygon);\n }\n return polygons;\n}\n\nfunction updatePoint(p, bbox, polyBBox, worldSize) {\n if (p[0] < polyBBox[0] || p[0] > polyBBox[2]) {\n const halfWorldSize = worldSize * 0.5;\n let shift = (p[0] - polyBBox[0] > halfWorldSize) ? -worldSize : (polyBBox[0] - p[0] > halfWorldSize) ? worldSize : 0;\n if (shift === 0) {\n shift = (p[0] - polyBBox[2] > halfWorldSize) ? -worldSize : (polyBBox[2] - p[0] > halfWorldSize) ? worldSize : 0;\n }\n p[0] += shift;\n }\n updateBBox(bbox, p);\n}\n\nfunction resetBBox(bbox) {\n bbox[0] = bbox[1] = Infinity;\n bbox[2] = bbox[3] = -Infinity;\n}\n\nfunction getTilePoints(geometry, pointBBox, polyBBox, canonical: CanonicalTileID) {\n const worldSize = Math.pow(2, canonical.z) * EXTENT;\n const shifts = [canonical.x * EXTENT, canonical.y * EXTENT];\n const tilePoints = [];\n if (!geometry) return tilePoints;\n for (const points of geometry) {\n for (const point of points) {\n const p = [point.x + shifts[0], point.y + shifts[1]];\n updatePoint(p, pointBBox, polyBBox, worldSize);\n tilePoints.push(p);\n }\n }\n return tilePoints;\n}\n\nfunction getTileLines(geometry, lineBBox, polyBBox, canonical: CanonicalTileID) {\n const worldSize = Math.pow(2, canonical.z) * EXTENT;\n const shifts = [canonical.x * EXTENT, canonical.y * EXTENT];\n const tileLines = [];\n if (!geometry) return tileLines;\n for (const line of geometry) {\n const tileLine = [];\n for (const point of line) {\n const p = [point.x + shifts[0], point.y + shifts[1]];\n updateBBox(lineBBox, p);\n tileLine.push(p);\n }\n tileLines.push(tileLine);\n }\n if (lineBBox[2] - lineBBox[0] <= worldSize / 2) {\n resetBBox(lineBBox);\n for (const line of tileLines) {\n for (const p of line) {\n updatePoint(p, lineBBox, polyBBox, worldSize);\n }\n }\n }\n return tileLines;\n}\n\nfunction pointsWithinPolygons(ctx: EvaluationContext, polygonGeometry: GeoJSONPolygons) {\n const pointBBox = [Infinity, Infinity, -Infinity, -Infinity];\n const polyBBox = [Infinity, Infinity, -Infinity, -Infinity];\n\n const canonical = ctx.canonicalID();\n if (!canonical) {\n return false;\n }\n\n if (polygonGeometry.type === 'Polygon') {\n const tilePolygon = getTilePolygon(polygonGeometry.coordinates, polyBBox, canonical);\n const tilePoints = getTilePoints(ctx.geometry(), pointBBox, polyBBox, canonical);\n if (!boxWithinBox(pointBBox, polyBBox)) return false;\n\n for (const point of tilePoints) {\n if (!pointWithinPolygon(point, tilePolygon)) return false;\n }\n }\n if (polygonGeometry.type === 'MultiPolygon') {\n const tilePolygons = getTilePolygons(polygonGeometry.coordinates, polyBBox, canonical);\n const tilePoints = getTilePoints(ctx.geometry(), pointBBox, polyBBox, canonical);\n if (!boxWithinBox(pointBBox, polyBBox)) return false;\n\n for (const point of tilePoints) {\n if (!pointWithinPolygons(point, tilePolygons)) return false;\n }\n }\n\n return true;\n}\n\nfunction linesWithinPolygons(ctx: EvaluationContext, polygonGeometry: GeoJSONPolygons) {\n const lineBBox = [Infinity, Infinity, -Infinity, -Infinity];\n const polyBBox = [Infinity, Infinity, -Infinity, -Infinity];\n\n const canonical = ctx.canonicalID();\n if (!canonical) {\n return false;\n }\n\n if (polygonGeometry.type === 'Polygon') {\n const tilePolygon = getTilePolygon(polygonGeometry.coordinates, polyBBox, canonical);\n const tileLines = getTileLines(ctx.geometry(), lineBBox, polyBBox, canonical);\n if (!boxWithinBox(lineBBox, polyBBox)) return false;\n\n for (const line of tileLines) {\n if (!lineStringWithinPolygon(line, tilePolygon)) return false;\n }\n }\n if (polygonGeometry.type === 'MultiPolygon') {\n const tilePolygons = getTilePolygons(polygonGeometry.coordinates, polyBBox, canonical);\n const tileLines = getTileLines(ctx.geometry(), lineBBox, polyBBox, canonical);\n if (!boxWithinBox(lineBBox, polyBBox)) return false;\n\n for (const line of tileLines) {\n if (!lineStringWithinPolygons(line, tilePolygons)) return false;\n }\n }\n return true;\n}\n\nclass Within implements Expression {\n type: Type;\n geojson: GeoJSON\n geometries: GeoJSONPolygons;\n\n constructor(geojson: GeoJSON, geometries: GeoJSONPolygons) {\n this.type = BooleanType;\n this.geojson = geojson;\n this.geometries = geometries;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Within {\n if (args.length !== 2)\n return context.error(`'within' expression requires exactly one argument, but found ${args.length - 1} instead.`);\n if (isValue(args[1])) {\n const geojson = (args[1]: Object);\n if (geojson.type === 'FeatureCollection') {\n for (let i = 0; i < geojson.features.length; ++i) {\n const type = geojson.features[i].geometry.type;\n if (type === 'Polygon' || type === 'MultiPolygon') {\n return new Within(geojson, geojson.features[i].geometry);\n }\n }\n } else if (geojson.type === 'Feature') {\n const type = geojson.geometry.type;\n if (type === 'Polygon' || type === 'MultiPolygon') {\n return new Within(geojson, geojson.geometry);\n }\n } else if (geojson.type === 'Polygon' || geojson.type === 'MultiPolygon') {\n return new Within(geojson, geojson);\n }\n }\n return context.error(`'within' expression requires valid geojson object that contains polygon geometry type.`);\n }\n\n evaluate(ctx: EvaluationContext): boolean {\n if (ctx.geometry() != null && ctx.canonicalID() != null) {\n if (ctx.geometryType() === 'Point') {\n return pointsWithinPolygons(ctx, this.geometries);\n } else if (ctx.geometryType() === 'LineString') {\n return linesWithinPolygons(ctx, this.geometries);\n }\n }\n return false;\n }\n\n eachChild() {}\n\n outputDefined(): boolean {\n return true;\n }\n\n serialize(): SerializedExpression {\n return [\"within\", this.geojson];\n }\n\n}\n\nexport default Within;\n","// @flow\n\nimport CompoundExpression from './compound_expression.js';\nimport Within from './definitions/within.js';\nimport type {Expression} from './expression.js';\n\nfunction isFeatureConstant(e: Expression): boolean {\n if (e instanceof CompoundExpression) {\n if (e.name === 'get' && e.args.length === 1) {\n return false;\n } else if (e.name === 'feature-state') {\n return false;\n } else if (e.name === 'has' && e.args.length === 1) {\n return false;\n } else if (\n e.name === 'properties' ||\n e.name === 'geometry-type' ||\n e.name === 'id'\n ) {\n return false;\n } else if (/^filter-/.test(e.name)) {\n return false;\n }\n }\n\n if (e instanceof Within) {\n return false;\n }\n\n let result = true;\n e.eachChild(arg => {\n if (result && !isFeatureConstant(arg)) { result = false; }\n });\n return result;\n}\n\nfunction isStateConstant(e: Expression): boolean {\n if (e instanceof CompoundExpression) {\n if (e.name === 'feature-state') {\n return false;\n }\n }\n let result = true;\n e.eachChild(arg => {\n if (result && !isStateConstant(arg)) { result = false; }\n });\n return result;\n}\n\nfunction isGlobalPropertyConstant(e: Expression, properties: Array): boolean {\n if (e instanceof CompoundExpression && properties.indexOf(e.name) >= 0) { return false; }\n let result = true;\n e.eachChild((arg) => {\n if (result && !isGlobalPropertyConstant(arg, properties)) { result = false; }\n });\n return result;\n}\n\nexport {isFeatureConstant, isGlobalPropertyConstant, isStateConstant};\n","// @flow\n\nimport type {Type} from '../types.js';\nimport type {Expression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\n\nclass Var implements Expression {\n type: Type;\n name: string;\n boundExpression: Expression;\n\n constructor(name: string, boundExpression: Expression) {\n this.type = boundExpression.type;\n this.name = name;\n this.boundExpression = boundExpression;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): void | Var {\n if (args.length !== 2 || typeof args[1] !== 'string')\n return context.error(`'var' expression requires exactly one string literal argument.`);\n\n const name = args[1];\n if (!context.scope.has(name)) {\n return context.error(`Unknown variable \"${name}\". Make sure \"${name}\" has been bound in an enclosing \"let\" expression before using it.`, 1);\n }\n\n return new Var(name, context.scope.get(name));\n }\n\n evaluate(ctx: EvaluationContext): any {\n return this.boundExpression.evaluate(ctx);\n }\n\n eachChild() {}\n\n outputDefined(): boolean {\n return false;\n }\n\n serialize(): Array {\n return [\"var\", this.name];\n }\n}\n\nexport default Var;\n","// @flow\n\nimport Scope from './scope.js';\nimport {checkSubtype} from './types.js';\nimport ParsingError from './parsing_error.js';\nimport Literal from './definitions/literal.js';\nimport Assertion from './definitions/assertion.js';\nimport Coercion from './definitions/coercion.js';\nimport EvaluationContext from './evaluation_context.js';\nimport CompoundExpression from './compound_expression.js';\nimport CollatorExpression from './definitions/collator.js';\nimport Within from './definitions/within.js';\nimport {isGlobalPropertyConstant, isFeatureConstant} from './is_constant.js';\nimport Var from './definitions/var.js';\n\nimport type {Expression, ExpressionRegistry} from './expression.js';\nimport type {Type} from './types.js';\n\n/**\n * State associated parsing at a given point in an expression tree.\n * @private\n */\nclass ParsingContext {\n registry: ExpressionRegistry;\n path: Array;\n key: string;\n scope: Scope;\n errors: Array;\n\n // The expected type of this expression. Provided only to allow Expression\n // implementations to infer argument types: Expression#parse() need not\n // check that the output type of the parsed expression matches\n // `expectedType`.\n expectedType: ?Type;\n\n constructor(\n registry: ExpressionRegistry,\n path: Array = [],\n expectedType: ?Type,\n scope: Scope = new Scope(),\n errors: Array = []\n ) {\n this.registry = registry;\n this.path = path;\n this.key = path.map(part => `[${part}]`).join('');\n this.scope = scope;\n this.errors = errors;\n this.expectedType = expectedType;\n }\n\n /**\n * @param expr the JSON expression to parse\n * @param index the optional argument index if this expression is an argument of a parent expression that's being parsed\n * @param options\n * @param options.omitTypeAnnotations set true to omit inferred type annotations. Caller beware: with this option set, the parsed expression's type will NOT satisfy `expectedType` if it would normally be wrapped in an inferred annotation.\n * @private\n */\n parse(\n expr: mixed,\n index?: number,\n expectedType?: ?Type,\n bindings?: Array<[string, Expression]>,\n options: {typeAnnotation?: 'assert' | 'coerce' | 'omit'} = {}\n ): ?Expression {\n if (index) {\n return this.concat(index, expectedType, bindings)._parse(expr, options);\n }\n return this._parse(expr, options);\n }\n\n _parse(expr: mixed, options: {typeAnnotation?: 'assert' | 'coerce' | 'omit'}): ?Expression {\n if (expr === null || typeof expr === 'string' || typeof expr === 'boolean' || typeof expr === 'number') {\n expr = ['literal', expr];\n }\n\n function annotate(parsed, type, typeAnnotation: 'assert' | 'coerce' | 'omit') {\n if (typeAnnotation === 'assert') {\n return new Assertion(type, [parsed]);\n } else if (typeAnnotation === 'coerce') {\n return new Coercion(type, [parsed]);\n } else {\n return parsed;\n }\n }\n\n if (Array.isArray(expr)) {\n if (expr.length === 0) {\n return this.error(`Expected an array with at least one element. If you wanted a literal array, use [\"literal\", []].`);\n }\n\n const op = expr[0];\n if (typeof op !== 'string') {\n this.error(`Expression name must be a string, but found ${typeof op} instead. If you wanted a literal array, use [\"literal\", [...]].`, 0);\n return null;\n }\n\n const Expr = this.registry[op];\n if (Expr) {\n let parsed = Expr.parse(expr, this);\n if (!parsed) return null;\n\n if (this.expectedType) {\n const expected = this.expectedType;\n const actual = parsed.type;\n\n // When we expect a number, string, boolean, or array but have a value, wrap it in an assertion.\n // When we expect a color or formatted string, but have a string or value, wrap it in a coercion.\n // Otherwise, we do static type-checking.\n //\n // These behaviors are overridable for:\n // * The \"coalesce\" operator, which needs to omit type annotations.\n // * String-valued properties (e.g. `text-field`), where coercion is more convenient than assertion.\n //\n if ((expected.kind === 'string' || expected.kind === 'number' || expected.kind === 'boolean' || expected.kind === 'object' || expected.kind === 'array') && actual.kind === 'value') {\n parsed = annotate(parsed, expected, options.typeAnnotation || 'assert');\n } else if ((expected.kind === 'color' || expected.kind === 'formatted' || expected.kind === 'resolvedImage') && (actual.kind === 'value' || actual.kind === 'string')) {\n parsed = annotate(parsed, expected, options.typeAnnotation || 'coerce');\n } else if (this.checkSubtype(expected, actual)) {\n return null;\n }\n }\n\n // If an expression's arguments are all literals, we can evaluate\n // it immediately and replace it with a literal value in the\n // parsed/compiled result. Expressions that expect an image should\n // not be resolved here so we can later get the available images.\n if (!(parsed instanceof Literal) && (parsed.type.kind !== 'resolvedImage') && isConstant(parsed)) {\n const ec = new EvaluationContext();\n try {\n parsed = new Literal(parsed.type, parsed.evaluate(ec));\n } catch (e) {\n this.error(e.message);\n return null;\n }\n }\n\n return parsed;\n }\n\n return this.error(`Unknown expression \"${op}\". If you wanted a literal array, use [\"literal\", [...]].`, 0);\n } else if (typeof expr === 'undefined') {\n return this.error(`'undefined' value invalid. Use null instead.`);\n } else if (typeof expr === 'object') {\n return this.error(`Bare objects invalid. Use [\"literal\", {...}] instead.`);\n } else {\n return this.error(`Expected an array, but found ${typeof expr} instead.`);\n }\n }\n\n /**\n * Returns a copy of this context suitable for parsing the subexpression at\n * index `index`, optionally appending to 'let' binding map.\n *\n * Note that `errors` property, intended for collecting errors while\n * parsing, is copied by reference rather than cloned.\n * @private\n */\n concat(index: number, expectedType?: ?Type, bindings?: Array<[string, Expression]>): ParsingContext {\n const path = typeof index === 'number' ? this.path.concat(index) : this.path;\n const scope = bindings ? this.scope.concat(bindings) : this.scope;\n return new ParsingContext(\n this.registry,\n path,\n expectedType || null,\n scope,\n this.errors\n );\n }\n\n /**\n * Push a parsing (or type checking) error into the `this.errors`\n * @param error The message\n * @param keys Optionally specify the source of the error at a child\n * of the current expression at `this.key`.\n * @private\n */\n error(error: string, ...keys: Array) {\n const key = `${this.key}${keys.map(k => `[${k}]`).join('')}`;\n this.errors.push(new ParsingError(key, error));\n }\n\n /**\n * Returns null if `t` is a subtype of `expected`; otherwise returns an\n * error message and also pushes it to `this.errors`.\n */\n checkSubtype(expected: Type, t: Type): ?string {\n const error = checkSubtype(expected, t);\n if (error) this.error(error);\n return error;\n }\n}\n\nexport default ParsingContext;\n\nfunction isConstant(expression: Expression) {\n if (expression instanceof Var) {\n return isConstant(expression.boundExpression);\n } else if (expression instanceof CompoundExpression && expression.name === 'error') {\n return false;\n } else if (expression instanceof CollatorExpression) {\n // Although the results of a Collator expression with fixed arguments\n // generally shouldn't change between executions, we can't serialize them\n // as constant expressions because results change based on environment.\n return false;\n } else if (expression instanceof Within) {\n return false;\n }\n\n const isTypeAnnotation = expression instanceof Coercion ||\n expression instanceof Assertion;\n\n let childrenConstant = true;\n expression.eachChild(child => {\n // We can _almost_ assume that if `expressions` children are constant,\n // they would already have been evaluated to Literal values when they\n // were parsed. Type annotations are the exception, because they might\n // have been inferred and added after a child was parsed.\n\n // So we recurse into isConstant() for the children of type annotations,\n // but otherwise simply check whether they are Literals.\n if (isTypeAnnotation) {\n childrenConstant = childrenConstant && isConstant(child);\n } else {\n childrenConstant = childrenConstant && child instanceof Literal;\n }\n });\n if (!childrenConstant) {\n return false;\n }\n\n return isFeatureConstant(expression) &&\n isGlobalPropertyConstant(expression, ['zoom', 'heatmap-density', 'line-progress', 'sky-radial-progress', 'accumulated', 'is-supported-script', 'pitch', 'distance-from-center']);\n}\n","// @flow\n\nimport RuntimeError from './runtime_error.js';\n\nimport type {Expression} from './expression.js';\n\nexport type Stops = Array<[number, Expression]>;\n\n/**\n * Returns the index of the last stop <= input, or 0 if it doesn't exist.\n * @private\n */\nexport function findStopLessThanOrEqualTo(stops: Array, input: number): number {\n const lastIndex = stops.length - 1;\n let lowerIndex = 0;\n let upperIndex = lastIndex;\n let currentIndex = 0;\n let currentValue, nextValue;\n\n while (lowerIndex <= upperIndex) {\n currentIndex = Math.floor((lowerIndex + upperIndex) / 2);\n currentValue = stops[currentIndex];\n nextValue = stops[currentIndex + 1];\n\n if (currentValue <= input) {\n if (currentIndex === lastIndex || input < nextValue) { // Search complete\n return currentIndex;\n }\n\n lowerIndex = currentIndex + 1;\n } else if (currentValue > input) {\n upperIndex = currentIndex - 1;\n } else {\n throw new RuntimeError('Input is not a number.');\n }\n }\n\n return 0;\n}\n","// @flow\n\nimport {NumberType} from '../types.js';\n\nimport {findStopLessThanOrEqualTo} from '../stops.js';\n\nimport type {Stops} from '../stops.js';\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nclass Step implements Expression {\n type: Type;\n\n input: Expression;\n labels: Array;\n outputs: Array;\n\n constructor(type: Type, input: Expression, stops: Stops) {\n this.type = type;\n this.input = input;\n\n this.labels = [];\n this.outputs = [];\n for (const [label, expression] of stops) {\n this.labels.push(label);\n this.outputs.push(expression);\n }\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Step {\n if (args.length - 1 < 4) {\n return context.error(`Expected at least 4 arguments, but found only ${args.length - 1}.`);\n }\n\n if ((args.length - 1) % 2 !== 0) {\n return context.error(`Expected an even number of arguments.`);\n }\n\n const input = context.parse(args[1], 1, NumberType);\n if (!input) return null;\n\n const stops: Stops = [];\n\n let outputType: Type = (null: any);\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n\n for (let i = 1; i < args.length; i += 2) {\n const label = i === 1 ? -Infinity : args[i];\n const value = args[i + 1];\n\n const labelKey = i;\n const valueKey = i + 1;\n\n if (typeof label !== 'number') {\n return context.error('Input/output pairs for \"step\" expressions must be defined using literal numeric values (not computed expressions) for the input values.', labelKey);\n }\n\n if (stops.length && stops[stops.length - 1][0] >= label) {\n return context.error('Input/output pairs for \"step\" expressions must be arranged with input values in strictly ascending order.', labelKey);\n }\n\n const parsed = context.parse(value, valueKey, outputType);\n if (!parsed) return null;\n outputType = outputType || parsed.type;\n stops.push([label, parsed]);\n }\n\n return new Step(outputType, input, stops);\n }\n\n evaluate(ctx: EvaluationContext): any {\n const labels = this.labels;\n const outputs = this.outputs;\n\n if (labels.length === 1) {\n return outputs[0].evaluate(ctx);\n }\n\n const value = ((this.input.evaluate(ctx): any): number);\n if (value <= labels[0]) {\n return outputs[0].evaluate(ctx);\n }\n\n const stopCount = labels.length;\n if (value >= labels[stopCount - 1]) {\n return outputs[stopCount - 1].evaluate(ctx);\n }\n\n const index = findStopLessThanOrEqualTo(labels, value);\n return outputs[index].evaluate(ctx);\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.input);\n for (const expression of this.outputs) {\n fn(expression);\n }\n }\n\n outputDefined(): boolean {\n return this.outputs.every(out => out.outputDefined());\n }\n\n serialize(): SerializedExpression {\n const serialized = [\"step\", this.input.serialize()];\n for (let i = 0; i < this.labels.length; i++) {\n if (i > 0) {\n serialized.push(this.labels[i]);\n }\n serialized.push(this.outputs[i].serialize());\n }\n return serialized;\n }\n}\n\nexport default Step;\n","/*\n * Copyright (C) 2008 Apple Inc. All Rights Reserved.\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions\n * are met:\n * 1. Redistributions of source code must retain the above copyright\n * notice, this list of conditions and the following disclaimer.\n * 2. Redistributions in binary form must reproduce the above copyright\n * notice, this list of conditions and the following disclaimer in the\n * documentation and/or other materials provided with the distribution.\n *\n * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY\n * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR\n * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR\n * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,\n * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,\n * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR\n * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY\n * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\n * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n *\n * Ported from Webkit\n * http://svn.webkit.org/repository/webkit/trunk/Source/WebCore/platform/graphics/UnitBezier.h\n */\n\nmodule.exports = UnitBezier;\n\nfunction UnitBezier(p1x, p1y, p2x, p2y) {\n // Calculate the polynomial coefficients, implicit first and last control points are (0,0) and (1,1).\n this.cx = 3.0 * p1x;\n this.bx = 3.0 * (p2x - p1x) - this.cx;\n this.ax = 1.0 - this.cx - this.bx;\n\n this.cy = 3.0 * p1y;\n this.by = 3.0 * (p2y - p1y) - this.cy;\n this.ay = 1.0 - this.cy - this.by;\n\n this.p1x = p1x;\n this.p1y = p2y;\n this.p2x = p2x;\n this.p2y = p2y;\n}\n\nUnitBezier.prototype.sampleCurveX = function(t) {\n // `ax t^3 + bx t^2 + cx t' expanded using Horner's rule.\n return ((this.ax * t + this.bx) * t + this.cx) * t;\n};\n\nUnitBezier.prototype.sampleCurveY = function(t) {\n return ((this.ay * t + this.by) * t + this.cy) * t;\n};\n\nUnitBezier.prototype.sampleCurveDerivativeX = function(t) {\n return (3.0 * this.ax * t + 2.0 * this.bx) * t + this.cx;\n};\n\nUnitBezier.prototype.solveCurveX = function(x, epsilon) {\n if (typeof epsilon === 'undefined') epsilon = 1e-6;\n\n var t0, t1, t2, x2, i;\n\n // First try a few iterations of Newton's method -- normally very fast.\n for (t2 = x, i = 0; i < 8; i++) {\n\n x2 = this.sampleCurveX(t2) - x;\n if (Math.abs(x2) < epsilon) return t2;\n\n var d2 = this.sampleCurveDerivativeX(t2);\n if (Math.abs(d2) < 1e-6) break;\n\n t2 = t2 - x2 / d2;\n }\n\n // Fall back to the bisection method for reliability.\n t0 = 0.0;\n t1 = 1.0;\n t2 = x;\n\n if (t2 < t0) return t0;\n if (t2 > t1) return t1;\n\n while (t0 < t1) {\n\n x2 = this.sampleCurveX(t2);\n if (Math.abs(x2 - x) < epsilon) return t2;\n\n if (x > x2) {\n t0 = t2;\n } else {\n t1 = t2;\n }\n\n t2 = (t1 - t0) * 0.5 + t0;\n }\n\n // Failure.\n return t2;\n};\n\nUnitBezier.prototype.solve = function(x, epsilon) {\n return this.sampleCurveY(this.solveCurveX(x, epsilon));\n};\n","// @flow\n\nimport Color from './color.js';\n\nexport function number(a: number, b: number, t: number): number {\n return (a * (1 - t)) + (b * t);\n}\n\nexport function color(from: Color, to: Color, t: number): Color {\n return new Color(\n number(from.r, to.r, t),\n number(from.g, to.g, t),\n number(from.b, to.b, t),\n number(from.a, to.a, t)\n );\n}\n\nexport function array(from: Array, to: Array, t: number): Array {\n return from.map((d, i) => {\n return number(d, to[i], t);\n });\n}\n","// @flow\n\nimport Color from './color.js';\n\nimport {number as interpolateNumber} from './interpolate.js';\n\ntype LABColor = {\n l: number,\n a: number,\n b: number,\n alpha: number\n};\n\ntype HCLColor = {\n h: number,\n c: number,\n l: number,\n alpha: number\n};\n\n// Constants\nconst Xn = 0.950470, // D65 standard referent\n Yn = 1,\n Zn = 1.088830,\n t0 = 4 / 29,\n t1 = 6 / 29,\n t2 = 3 * t1 * t1,\n t3 = t1 * t1 * t1,\n deg2rad = Math.PI / 180,\n rad2deg = 180 / Math.PI;\n\n// Utilities\nfunction xyz2lab(t: number) {\n return t > t3 ? Math.pow(t, 1 / 3) : t / t2 + t0;\n}\n\nfunction lab2xyz(t: number) {\n return t > t1 ? t * t * t : t2 * (t - t0);\n}\n\nfunction xyz2rgb(x: number) {\n return 255 * (x <= 0.0031308 ? 12.92 * x : 1.055 * Math.pow(x, 1 / 2.4) - 0.055);\n}\n\nfunction rgb2xyz(x: number) {\n x /= 255;\n return x <= 0.04045 ? x / 12.92 : Math.pow((x + 0.055) / 1.055, 2.4);\n}\n\n// LAB\nfunction rgbToLab(rgbColor: Color): LABColor {\n const b = rgb2xyz(rgbColor.r),\n a = rgb2xyz(rgbColor.g),\n l = rgb2xyz(rgbColor.b),\n x = xyz2lab((0.4124564 * b + 0.3575761 * a + 0.1804375 * l) / Xn),\n y = xyz2lab((0.2126729 * b + 0.7151522 * a + 0.0721750 * l) / Yn),\n z = xyz2lab((0.0193339 * b + 0.1191920 * a + 0.9503041 * l) / Zn);\n\n return {\n l: 116 * y - 16,\n a: 500 * (x - y),\n b: 200 * (y - z),\n alpha: rgbColor.a\n };\n}\n\nfunction labToRgb(labColor: LABColor): Color {\n let y = (labColor.l + 16) / 116,\n x = isNaN(labColor.a) ? y : y + labColor.a / 500,\n z = isNaN(labColor.b) ? y : y - labColor.b / 200;\n y = Yn * lab2xyz(y);\n x = Xn * lab2xyz(x);\n z = Zn * lab2xyz(z);\n return new Color(\n xyz2rgb(3.2404542 * x - 1.5371385 * y - 0.4985314 * z), // D65 -> sRGB\n xyz2rgb(-0.9692660 * x + 1.8760108 * y + 0.0415560 * z),\n xyz2rgb(0.0556434 * x - 0.2040259 * y + 1.0572252 * z),\n labColor.alpha\n );\n}\n\nfunction interpolateLab(from: LABColor, to: LABColor, t: number): LABColor {\n return {\n l: interpolateNumber(from.l, to.l, t),\n a: interpolateNumber(from.a, to.a, t),\n b: interpolateNumber(from.b, to.b, t),\n alpha: interpolateNumber(from.alpha, to.alpha, t)\n };\n}\n\n// HCL\nfunction rgbToHcl(rgbColor: Color): HCLColor {\n const {l, a, b} = rgbToLab(rgbColor);\n const h = Math.atan2(b, a) * rad2deg;\n return {\n h: h < 0 ? h + 360 : h,\n c: Math.sqrt(a * a + b * b),\n l,\n alpha: rgbColor.a\n };\n}\n\nfunction hclToRgb(hclColor: HCLColor): Color {\n const h = hclColor.h * deg2rad,\n c = hclColor.c,\n l = hclColor.l;\n return labToRgb({\n l,\n a: Math.cos(h) * c,\n b: Math.sin(h) * c,\n alpha: hclColor.alpha\n });\n}\n\nfunction interpolateHue(a: number, b: number, t: number) {\n const d = b - a;\n return a + t * (d > 180 || d < -180 ? d - 360 * Math.round(d / 360) : d);\n}\n\nfunction interpolateHcl(from: HCLColor, to: HCLColor, t: number): HCLColor {\n return {\n h: interpolateHue(from.h, to.h, t),\n c: interpolateNumber(from.c, to.c, t),\n l: interpolateNumber(from.l, to.l, t),\n alpha: interpolateNumber(from.alpha, to.alpha, t)\n };\n}\n\nexport const lab = {\n forward: rgbToLab,\n reverse: labToRgb,\n interpolate: interpolateLab\n};\n\nexport const hcl = {\n forward: rgbToHcl,\n reverse: hclToRgb,\n interpolate: interpolateHcl\n};\n","// @flow\n\nimport UnitBezier from '@mapbox/unitbezier';\n\nimport * as interpolate from '../../util/interpolate.js';\nimport {toString, NumberType, ColorType} from '../types.js';\nimport {findStopLessThanOrEqualTo} from '../stops.js';\nimport {hcl, lab} from '../../util/color_spaces.js';\nimport Color from '../../util/color.js';\n\nimport type {Stops} from '../stops.js';\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nexport type InterpolationType =\n { name: 'linear' } |\n { name: 'exponential', base: number } |\n { name: 'cubic-bezier', controlPoints: [number, number, number, number] };\n\nclass Interpolate implements Expression {\n type: Type;\n\n operator: 'interpolate' | 'interpolate-hcl' | 'interpolate-lab';\n interpolation: InterpolationType;\n input: Expression;\n labels: Array;\n outputs: Array;\n\n constructor(type: Type, operator: 'interpolate' | 'interpolate-hcl' | 'interpolate-lab', interpolation: InterpolationType, input: Expression, stops: Stops) {\n this.type = type;\n this.operator = operator;\n this.interpolation = interpolation;\n this.input = input;\n\n this.labels = [];\n this.outputs = [];\n for (const [label, expression] of stops) {\n this.labels.push(label);\n this.outputs.push(expression);\n }\n }\n\n static interpolationFactor(interpolation: InterpolationType, input: number, lower: number, upper: number): number {\n let t = 0;\n if (interpolation.name === 'exponential') {\n t = exponentialInterpolation(input, interpolation.base, lower, upper);\n } else if (interpolation.name === 'linear') {\n t = exponentialInterpolation(input, 1, lower, upper);\n } else if (interpolation.name === 'cubic-bezier') {\n const c = interpolation.controlPoints;\n const ub = new UnitBezier(c[0], c[1], c[2], c[3]);\n t = ub.solve(exponentialInterpolation(input, 1, lower, upper));\n }\n return t;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Interpolate {\n let [operator, interpolation, input, ...rest] = args;\n\n if (!Array.isArray(interpolation) || interpolation.length === 0) {\n return context.error(`Expected an interpolation type expression.`, 1);\n }\n\n if (interpolation[0] === 'linear') {\n interpolation = {name: 'linear'};\n } else if (interpolation[0] === 'exponential') {\n const base = interpolation[1];\n if (typeof base !== 'number')\n return context.error(`Exponential interpolation requires a numeric base.`, 1, 1);\n interpolation = {\n name: 'exponential',\n base\n };\n } else if (interpolation[0] === 'cubic-bezier') {\n const controlPoints = interpolation.slice(1);\n if (\n controlPoints.length !== 4 ||\n controlPoints.some(t => typeof t !== 'number' || t < 0 || t > 1)\n ) {\n return context.error('Cubic bezier interpolation requires four numeric arguments with values between 0 and 1.', 1);\n }\n\n interpolation = {\n name: 'cubic-bezier',\n controlPoints: (controlPoints: any)\n };\n } else {\n return context.error(`Unknown interpolation type ${String(interpolation[0])}`, 1, 0);\n }\n\n if (args.length - 1 < 4) {\n return context.error(`Expected at least 4 arguments, but found only ${args.length - 1}.`);\n }\n\n if ((args.length - 1) % 2 !== 0) {\n return context.error(`Expected an even number of arguments.`);\n }\n\n input = context.parse(input, 2, NumberType);\n if (!input) return null;\n\n const stops: Stops = [];\n\n let outputType: Type = (null: any);\n if (operator === 'interpolate-hcl' || operator === 'interpolate-lab') {\n outputType = ColorType;\n } else if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n\n for (let i = 0; i < rest.length; i += 2) {\n const label = rest[i];\n const value = rest[i + 1];\n\n const labelKey = i + 3;\n const valueKey = i + 4;\n\n if (typeof label !== 'number') {\n return context.error('Input/output pairs for \"interpolate\" expressions must be defined using literal numeric values (not computed expressions) for the input values.', labelKey);\n }\n\n if (stops.length && stops[stops.length - 1][0] >= label) {\n return context.error('Input/output pairs for \"interpolate\" expressions must be arranged with input values in strictly ascending order.', labelKey);\n }\n\n const parsed = context.parse(value, valueKey, outputType);\n if (!parsed) return null;\n outputType = outputType || parsed.type;\n stops.push([label, parsed]);\n }\n\n if (outputType.kind !== 'number' &&\n outputType.kind !== 'color' &&\n !(\n outputType.kind === 'array' &&\n outputType.itemType.kind === 'number' &&\n typeof outputType.N === 'number'\n )\n ) {\n return context.error(`Type ${toString(outputType)} is not interpolatable.`);\n }\n\n return new Interpolate(outputType, (operator: any), interpolation, input, stops);\n }\n\n evaluate(ctx: EvaluationContext): Color {\n const labels = this.labels;\n const outputs = this.outputs;\n\n if (labels.length === 1) {\n return outputs[0].evaluate(ctx);\n }\n\n const value = ((this.input.evaluate(ctx): any): number);\n if (value <= labels[0]) {\n return outputs[0].evaluate(ctx);\n }\n\n const stopCount = labels.length;\n if (value >= labels[stopCount - 1]) {\n return outputs[stopCount - 1].evaluate(ctx);\n }\n\n const index = findStopLessThanOrEqualTo(labels, value);\n const lower = labels[index];\n const upper = labels[index + 1];\n const t = Interpolate.interpolationFactor(this.interpolation, value, lower, upper);\n\n const outputLower = outputs[index].evaluate(ctx);\n const outputUpper = outputs[index + 1].evaluate(ctx);\n\n if (this.operator === 'interpolate') {\n return (interpolate[this.type.kind.toLowerCase()]: any)(outputLower, outputUpper, t); // eslint-disable-line import/namespace\n } else if (this.operator === 'interpolate-hcl') {\n return hcl.reverse(hcl.interpolate(hcl.forward(outputLower), hcl.forward(outputUpper), t));\n } else {\n return lab.reverse(lab.interpolate(lab.forward(outputLower), lab.forward(outputUpper), t));\n }\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.input);\n for (const expression of this.outputs) {\n fn(expression);\n }\n }\n\n outputDefined(): boolean {\n return this.outputs.every(out => out.outputDefined());\n }\n\n serialize(): SerializedExpression {\n let interpolation;\n if (this.interpolation.name === 'linear') {\n interpolation = [\"linear\"];\n } else if (this.interpolation.name === 'exponential') {\n if (this.interpolation.base === 1) {\n interpolation = [\"linear\"];\n } else {\n interpolation = [\"exponential\", this.interpolation.base];\n }\n } else {\n interpolation = [\"cubic-bezier\" ].concat(this.interpolation.controlPoints);\n }\n\n const serialized = [this.operator, interpolation, this.input.serialize()];\n\n for (let i = 0; i < this.labels.length; i++) {\n serialized.push(\n this.labels[i],\n this.outputs[i].serialize()\n );\n }\n return serialized;\n }\n}\n\n/**\n * Returns a ratio that can be used to interpolate between exponential function\n * stops.\n * How it works: Two consecutive stop values define a (scaled and shifted) exponential function `f(x) = a * base^x + b`, where `base` is the user-specified base,\n * and `a` and `b` are constants affording sufficient degrees of freedom to fit\n * the function to the given stops.\n *\n * Here's a bit of algebra that lets us compute `f(x)` directly from the stop\n * values without explicitly solving for `a` and `b`:\n *\n * First stop value: `f(x0) = y0 = a * base^x0 + b`\n * Second stop value: `f(x1) = y1 = a * base^x1 + b`\n * => `y1 - y0 = a(base^x1 - base^x0)`\n * => `a = (y1 - y0)/(base^x1 - base^x0)`\n *\n * Desired value: `f(x) = y = a * base^x + b`\n * => `f(x) = y0 + a * (base^x - base^x0)`\n *\n * From the above, we can replace the `a` in `a * (base^x - base^x0)` and do a\n * little algebra:\n * ```\n * a * (base^x - base^x0) = (y1 - y0)/(base^x1 - base^x0) * (base^x - base^x0)\n * = (y1 - y0) * (base^x - base^x0) / (base^x1 - base^x0)\n * ```\n *\n * If we let `(base^x - base^x0) / (base^x1 base^x0)`, then we have\n * `f(x) = y0 + (y1 - y0) * ratio`. In other words, `ratio` may be treated as\n * an interpolation factor between the two stops' output values.\n *\n * (Note: a slightly different form for `ratio`,\n * `(base^(x-x0) - 1) / (base^(x1-x0) - 1) `, is equivalent, but requires fewer\n * expensive `Math.pow()` operations.)\n *\n * @private\n*/\nfunction exponentialInterpolation(input, base, lowerValue, upperValue) {\n const difference = upperValue - lowerValue;\n const progress = input - lowerValue;\n\n if (difference === 0) {\n return 0;\n } else if (base === 1) {\n return progress / difference;\n } else {\n return (Math.pow(base, progress) - 1) / (Math.pow(base, difference) - 1);\n }\n}\n\nexport default Interpolate;\n","// @flow\n\nimport assert from 'assert';\n\nimport {checkSubtype, ValueType} from '../types.js';\nimport ResolvedImage from '../types/resolved_image.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nclass Coalesce implements Expression {\n type: Type;\n args: Array;\n\n constructor(type: Type, args: Array) {\n this.type = type;\n this.args = args;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Coalesce {\n if (args.length < 2) {\n return context.error(\"Expectected at least one argument.\");\n }\n let outputType: Type = (null: any);\n const expectedType = context.expectedType;\n if (expectedType && expectedType.kind !== 'value') {\n outputType = expectedType;\n }\n const parsedArgs = [];\n\n for (const arg of args.slice(1)) {\n const parsed = context.parse(arg, 1 + parsedArgs.length, outputType, undefined, {typeAnnotation: 'omit'});\n if (!parsed) return null;\n outputType = outputType || parsed.type;\n parsedArgs.push(parsed);\n }\n assert(outputType);\n\n // Above, we parse arguments without inferred type annotation so that\n // they don't produce a runtime error for `null` input, which would\n // preempt the desired null-coalescing behavior.\n // Thus, if any of our arguments would have needed an annotation, we\n // need to wrap the enclosing coalesce expression with it instead.\n const needsAnnotation = expectedType &&\n parsedArgs.some(arg => checkSubtype(expectedType, arg.type));\n\n return needsAnnotation ?\n new Coalesce(ValueType, parsedArgs) :\n new Coalesce((outputType: any), parsedArgs);\n }\n\n evaluate(ctx: EvaluationContext): any | null {\n let result = null;\n let argCount = 0;\n let firstImage;\n for (const arg of this.args) {\n argCount++;\n result = arg.evaluate(ctx);\n // we need to keep track of the first requested image in a coalesce statement\n // if coalesce can't find a valid image, we return the first image so styleimagemissing can fire\n if (result && result instanceof ResolvedImage && !result.available) {\n // set to first image\n if (!firstImage) {\n firstImage = result;\n }\n result = null;\n // if we reach the end, return the first image\n if (argCount === this.args.length) {\n return firstImage;\n }\n }\n\n if (result !== null) break;\n }\n return result;\n }\n\n eachChild(fn: (_: Expression) => void) {\n this.args.forEach(fn);\n }\n\n outputDefined(): boolean {\n return this.args.every(arg => arg.outputDefined());\n }\n\n serialize(): SerializedExpression {\n const serialized = [\"coalesce\"];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n}\n\nexport default Coalesce;\n","// @flow\n\nimport type {Type} from '../types.js';\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\n\nclass Let implements Expression {\n type: Type;\n bindings: Array<[string, Expression]>;\n result: Expression;\n\n constructor(bindings: Array<[string, Expression]>, result: Expression) {\n this.type = result.type;\n this.bindings = [].concat(bindings);\n this.result = result;\n }\n\n evaluate(ctx: EvaluationContext): any {\n return this.result.evaluate(ctx);\n }\n\n eachChild(fn: (_: Expression) => void) {\n for (const binding of this.bindings) {\n fn(binding[1]);\n }\n fn(this.result);\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Let {\n if (args.length < 4)\n return context.error(`Expected at least 3 arguments, but found ${args.length - 1} instead.`);\n\n const bindings: Array<[string, Expression]> = [];\n for (let i = 1; i < args.length - 1; i += 2) {\n const name = args[i];\n\n if (typeof name !== 'string') {\n return context.error(`Expected string, but found ${typeof name} instead.`, i);\n }\n\n if (/[^a-zA-Z0-9_]/.test(name)) {\n return context.error(`Variable names must contain only alphanumeric characters or '_'.`, i);\n }\n\n const value = context.parse(args[i + 1], i + 1);\n if (!value) return null;\n\n bindings.push([name, value]);\n }\n\n const result = context.parse(args[args.length - 1], args.length - 1, context.expectedType, bindings);\n if (!result) return null;\n\n return new Let(bindings, result);\n }\n\n outputDefined(): boolean {\n return this.result.outputDefined();\n }\n\n serialize(): SerializedExpression {\n const serialized = [\"let\"];\n for (const [name, expr] of this.bindings) {\n serialized.push(name, expr.serialize());\n }\n serialized.push(this.result.serialize());\n return serialized;\n }\n}\n\nexport default Let;\n","// @flow\n\nimport {array, ValueType, NumberType} from '../types.js';\n\nimport RuntimeError from '../runtime_error.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type, ArrayType} from '../types.js';\nimport type {Value} from '../values.js';\n\nclass At implements Expression {\n type: Type;\n index: Expression;\n input: Expression;\n\n constructor(type: Type, index: Expression, input: Expression) {\n this.type = type;\n this.index = index;\n this.input = input;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?At {\n if (args.length !== 3)\n return context.error(`Expected 2 arguments, but found ${args.length - 1} instead.`);\n\n const index = context.parse(args[1], 1, NumberType);\n const input = context.parse(args[2], 2, array(context.expectedType || ValueType));\n\n if (!index || !input) return null;\n\n const t: ArrayType = (input.type: any);\n return new At(t.itemType, index, input);\n }\n\n evaluate(ctx: EvaluationContext): Value {\n const index = ((this.index.evaluate(ctx): any): number);\n const array = ((this.input.evaluate(ctx): any): Array);\n\n if (index < 0) {\n throw new RuntimeError(`Array index out of bounds: ${index} < 0.`);\n }\n\n if (index >= array.length) {\n throw new RuntimeError(`Array index out of bounds: ${index} > ${array.length - 1}.`);\n }\n\n if (index !== Math.floor(index)) {\n throw new RuntimeError(`Array index must be an integer, but found ${index} instead.`);\n }\n\n return array[index];\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.index);\n fn(this.input);\n }\n\n outputDefined(): boolean {\n return false;\n }\n\n serialize(): SerializedExpression {\n return [\"at\", this.index.serialize(), this.input.serialize()];\n }\n}\n\nexport default At;\n","// @flow\n\nimport {BooleanType, StringType, ValueType, NullType, toString, NumberType, isValidType, isValidNativeType} from '../types.js';\nimport RuntimeError from '../runtime_error.js';\nimport {typeOf} from '../values.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nclass In implements Expression {\n type: Type;\n needle: Expression;\n haystack: Expression;\n\n constructor(needle: Expression, haystack: Expression) {\n this.type = BooleanType;\n this.needle = needle;\n this.haystack = haystack;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?In {\n if (args.length !== 3) {\n return context.error(`Expected 2 arguments, but found ${args.length - 1} instead.`);\n }\n\n const needle = context.parse(args[1], 1, ValueType);\n\n const haystack = context.parse(args[2], 2, ValueType);\n\n if (!needle || !haystack) return null;\n\n if (!isValidType(needle.type, [BooleanType, StringType, NumberType, NullType, ValueType])) {\n return context.error(`Expected first argument to be of type boolean, string, number or null, but found ${toString(needle.type)} instead`);\n }\n\n return new In(needle, haystack);\n }\n\n evaluate(ctx: EvaluationContext): boolean {\n const needle = (this.needle.evaluate(ctx): any);\n const haystack = (this.haystack.evaluate(ctx): any);\n\n if (haystack == null) return false;\n\n if (!isValidNativeType(needle, ['boolean', 'string', 'number', 'null'])) {\n throw new RuntimeError(`Expected first argument to be of type boolean, string, number or null, but found ${toString(typeOf(needle))} instead.`);\n }\n\n if (!isValidNativeType(haystack, ['string', 'array'])) {\n throw new RuntimeError(`Expected second argument to be of type array or string, but found ${toString(typeOf(haystack))} instead.`);\n }\n\n return haystack.indexOf(needle) >= 0;\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.needle);\n fn(this.haystack);\n }\n\n outputDefined(): boolean {\n return true;\n }\n\n serialize(): SerializedExpression {\n return [\"in\", this.needle.serialize(), this.haystack.serialize()];\n }\n}\n\nexport default In;\n","// @flow\n\nimport {BooleanType, StringType, ValueType, NullType, toString, NumberType, isValidType, isValidNativeType} from '../types.js';\nimport RuntimeError from '../runtime_error.js';\nimport {typeOf} from '../values.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nclass IndexOf implements Expression {\n type: Type;\n needle: Expression;\n haystack: Expression;\n fromIndex: ?Expression;\n\n constructor(needle: Expression, haystack: Expression, fromIndex?: Expression) {\n this.type = NumberType;\n this.needle = needle;\n this.haystack = haystack;\n this.fromIndex = fromIndex;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?IndexOf {\n if (args.length <= 2 || args.length >= 5) {\n return context.error(`Expected 3 or 4 arguments, but found ${args.length - 1} instead.`);\n }\n\n const needle = context.parse(args[1], 1, ValueType);\n\n const haystack = context.parse(args[2], 2, ValueType);\n\n if (!needle || !haystack) return null;\n if (!isValidType(needle.type, [BooleanType, StringType, NumberType, NullType, ValueType])) {\n return context.error(`Expected first argument to be of type boolean, string, number or null, but found ${toString(needle.type)} instead`);\n }\n\n if (args.length === 4) {\n const fromIndex = context.parse(args[3], 3, NumberType);\n if (!fromIndex) return null;\n return new IndexOf(needle, haystack, fromIndex);\n } else {\n return new IndexOf(needle, haystack);\n }\n }\n\n evaluate(ctx: EvaluationContext): any {\n const needle = (this.needle.evaluate(ctx): any);\n const haystack = (this.haystack.evaluate(ctx): any);\n\n if (!isValidNativeType(needle, ['boolean', 'string', 'number', 'null'])) {\n throw new RuntimeError(`Expected first argument to be of type boolean, string, number or null, but found ${toString(typeOf(needle))} instead.`);\n }\n\n if (!isValidNativeType(haystack, ['string', 'array'])) {\n throw new RuntimeError(`Expected second argument to be of type array or string, but found ${toString(typeOf(haystack))} instead.`);\n }\n\n if (this.fromIndex) {\n const fromIndex = (this.fromIndex.evaluate(ctx): number);\n return haystack.indexOf(needle, fromIndex);\n }\n\n return haystack.indexOf(needle);\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.needle);\n fn(this.haystack);\n if (this.fromIndex) {\n fn(this.fromIndex);\n }\n }\n\n outputDefined(): boolean {\n return false;\n }\n\n serialize(): SerializedExpression {\n if (this.fromIndex != null && this.fromIndex !== undefined) {\n const fromIndex = this.fromIndex.serialize();\n return [\"index-of\", this.needle.serialize(), this.haystack.serialize(), fromIndex];\n }\n return [\"index-of\", this.needle.serialize(), this.haystack.serialize()];\n }\n}\n\nexport default IndexOf;\n","// @flow\n\nimport assert from 'assert';\n\nimport {typeOf} from '../values.js';\nimport {ValueType, type Type} from '../types.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\n\n// Map input label values to output expression index\ntype Cases = {[number | string]: number};\n\nclass Match implements Expression {\n type: Type;\n inputType: Type;\n\n input: Expression;\n cases: Cases;\n outputs: Array;\n otherwise: Expression;\n\n constructor(inputType: Type, outputType: Type, input: Expression, cases: Cases, outputs: Array, otherwise: Expression) {\n this.inputType = inputType;\n this.type = outputType;\n this.input = input;\n this.cases = cases;\n this.outputs = outputs;\n this.otherwise = otherwise;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Match {\n if (args.length < 5)\n return context.error(`Expected at least 4 arguments, but found only ${args.length - 1}.`);\n if (args.length % 2 !== 1)\n return context.error(`Expected an even number of arguments.`);\n\n let inputType;\n let outputType;\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n const cases = {};\n const outputs = [];\n for (let i = 2; i < args.length - 1; i += 2) {\n let labels = args[i];\n const value = args[i + 1];\n\n if (!Array.isArray(labels)) {\n labels = [labels];\n }\n\n const labelContext = context.concat(i);\n if (labels.length === 0) {\n return labelContext.error('Expected at least one branch label.');\n }\n\n for (const label of labels) {\n if (typeof label !== 'number' && typeof label !== 'string') {\n return labelContext.error(`Branch labels must be numbers or strings.`);\n } else if (typeof label === 'number' && Math.abs(label) > Number.MAX_SAFE_INTEGER) {\n return labelContext.error(`Branch labels must be integers no larger than ${Number.MAX_SAFE_INTEGER}.`);\n\n } else if (typeof label === 'number' && Math.floor(label) !== label) {\n return labelContext.error(`Numeric branch labels must be integer values.`);\n\n } else if (!inputType) {\n inputType = typeOf(label);\n } else if (labelContext.checkSubtype(inputType, typeOf(label))) {\n return null;\n }\n\n if (typeof cases[String(label)] !== 'undefined') {\n return labelContext.error('Branch labels must be unique.');\n }\n\n cases[String(label)] = outputs.length;\n }\n\n const result = context.parse(value, i, outputType);\n if (!result) return null;\n outputType = outputType || result.type;\n outputs.push(result);\n }\n\n const input = context.parse(args[1], 1, ValueType);\n if (!input) return null;\n\n const otherwise = context.parse(args[args.length - 1], args.length - 1, outputType);\n if (!otherwise) return null;\n\n assert(inputType && outputType);\n\n if (input.type.kind !== 'value' && context.concat(1).checkSubtype((inputType: any), input.type)) {\n return null;\n }\n\n return new Match((inputType: any), (outputType: any), input, cases, outputs, otherwise);\n }\n\n evaluate(ctx: EvaluationContext): any {\n const input = (this.input.evaluate(ctx): any);\n const output = (typeOf(input) === this.inputType && this.outputs[this.cases[input]]) || this.otherwise;\n return output.evaluate(ctx);\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.input);\n this.outputs.forEach(fn);\n fn(this.otherwise);\n }\n\n outputDefined(): boolean {\n return this.outputs.every(out => out.outputDefined()) && this.otherwise.outputDefined();\n }\n\n serialize(): SerializedExpression {\n const serialized = [\"match\", this.input.serialize()];\n\n // Sort so serialization has an arbitrary defined order, even though\n // branch order doesn't affect evaluation\n const sortedLabels = Object.keys(this.cases).sort();\n\n // Group branches by unique match expression to support condensed\n // serializations of the form [case1, case2, ...] -> matchExpression\n const groupedByOutput: Array<[number, Array]> = [];\n const outputLookup: {[index: number]: number} = {}; // lookup index into groupedByOutput for a given output expression\n for (const label of sortedLabels) {\n const outputIndex = outputLookup[this.cases[label]];\n if (outputIndex === undefined) {\n // First time seeing this output, add it to the end of the grouped list\n outputLookup[this.cases[label]] = groupedByOutput.length;\n groupedByOutput.push([this.cases[label], [label]]);\n } else {\n // We've seen this expression before, add the label to that output's group\n groupedByOutput[outputIndex][1].push(label);\n }\n }\n\n const coerceLabel = (label) => this.inputType.kind === 'number' ? Number(label) : label;\n\n for (const [outputIndex, labels] of groupedByOutput) {\n if (labels.length === 1) {\n // Only a single label matches this output expression\n serialized.push(coerceLabel(labels[0]));\n } else {\n // Array of literal labels pointing to this output expression\n serialized.push(labels.map(coerceLabel));\n }\n serialized.push(this.outputs[outputIndex].serialize());\n }\n serialized.push(this.otherwise.serialize());\n return serialized;\n }\n}\n\nexport default Match;\n","// @flow\n\nimport assert from 'assert';\n\nimport {BooleanType} from '../types.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\ntype Branches = Array<[Expression, Expression]>;\n\nclass Case implements Expression {\n type: Type;\n\n branches: Branches;\n otherwise: Expression;\n\n constructor(type: Type, branches: Branches, otherwise: Expression) {\n this.type = type;\n this.branches = branches;\n this.otherwise = otherwise;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Case {\n if (args.length < 4)\n return context.error(`Expected at least 3 arguments, but found only ${args.length - 1}.`);\n if (args.length % 2 !== 0)\n return context.error(`Expected an odd number of arguments.`);\n\n let outputType: ?Type;\n if (context.expectedType && context.expectedType.kind !== 'value') {\n outputType = context.expectedType;\n }\n\n const branches = [];\n for (let i = 1; i < args.length - 1; i += 2) {\n const test = context.parse(args[i], i, BooleanType);\n if (!test) return null;\n\n const result = context.parse(args[i + 1], i + 1, outputType);\n if (!result) return null;\n\n branches.push([test, result]);\n\n outputType = outputType || result.type;\n }\n\n const otherwise = context.parse(args[args.length - 1], args.length - 1, outputType);\n if (!otherwise) return null;\n\n assert(outputType);\n return new Case((outputType: any), branches, otherwise);\n }\n\n evaluate(ctx: EvaluationContext): any {\n for (const [test, expression] of this.branches) {\n if (test.evaluate(ctx)) {\n return expression.evaluate(ctx);\n }\n }\n return this.otherwise.evaluate(ctx);\n }\n\n eachChild(fn: (_: Expression) => void) {\n for (const [test, expression] of this.branches) {\n fn(test);\n fn(expression);\n }\n fn(this.otherwise);\n }\n\n outputDefined(): boolean {\n return this.branches.every(([_, out]) => out.outputDefined()) && this.otherwise.outputDefined();\n }\n\n serialize(): SerializedExpression {\n const serialized = [\"case\"];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n}\n\nexport default Case;\n","// @flow\n\nimport {ValueType, NumberType, StringType, array, toString, isValidType, isValidNativeType} from '../types.js';\nimport RuntimeError from '../runtime_error.js';\nimport {typeOf} from '../values.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nclass Slice implements Expression {\n type: Type;\n input: Expression;\n beginIndex: Expression;\n endIndex: ?Expression;\n\n constructor(type: Type, input: Expression, beginIndex: Expression, endIndex?: Expression) {\n this.type = type;\n this.input = input;\n this.beginIndex = beginIndex;\n this.endIndex = endIndex;\n\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Slice {\n if (args.length <= 2 || args.length >= 5) {\n return context.error(`Expected 3 or 4 arguments, but found ${args.length - 1} instead.`);\n }\n\n const input = context.parse(args[1], 1, ValueType);\n const beginIndex = context.parse(args[2], 2, NumberType);\n\n if (!input || !beginIndex) return null;\n\n if (!isValidType(input.type, [array(ValueType), StringType, ValueType])) {\n return context.error(`Expected first argument to be of type array or string, but found ${toString(input.type)} instead`);\n }\n\n if (args.length === 4) {\n const endIndex = context.parse(args[3], 3, NumberType);\n if (!endIndex) return null;\n return new Slice(input.type, input, beginIndex, endIndex);\n } else {\n return new Slice(input.type, input, beginIndex);\n }\n }\n\n evaluate(ctx: EvaluationContext): any {\n const input = (this.input.evaluate(ctx): any);\n const beginIndex = (this.beginIndex.evaluate(ctx): number);\n\n if (!isValidNativeType(input, ['string', 'array'])) {\n throw new RuntimeError(`Expected first argument to be of type array or string, but found ${toString(typeOf(input))} instead.`);\n }\n\n if (this.endIndex) {\n const endIndex = (this.endIndex.evaluate(ctx): number);\n return input.slice(beginIndex, endIndex);\n }\n\n return input.slice(beginIndex);\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.input);\n fn(this.beginIndex);\n if (this.endIndex) {\n fn(this.endIndex);\n }\n }\n\n outputDefined(): boolean {\n return false;\n }\n\n serialize(): SerializedExpression {\n if (this.endIndex != null && this.endIndex !== undefined) {\n const endIndex = this.endIndex.serialize();\n return [\"slice\", this.input.serialize(), this.beginIndex.serialize(), endIndex];\n }\n return [\"slice\", this.input.serialize(), this.beginIndex.serialize()];\n }\n}\n\nexport default Slice;\n","// @flow\n\nimport {toString, ValueType, BooleanType, CollatorType} from '../types.js';\nimport Assertion from './assertion.js';\nimport {typeOf} from '../values.js';\nimport RuntimeError from '../runtime_error.js';\n\nimport type {Expression, SerializedExpression, ExpressionRegistration} from '../expression.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type {Type} from '../types.js';\n\ntype ComparisonOperator = '==' | '!=' | '<' | '>' | '<=' | '>=' ;\n\nfunction isComparableType(op: ComparisonOperator, type: Type) {\n if (op === '==' || op === '!=') {\n // equality operator\n return type.kind === 'boolean' ||\n type.kind === 'string' ||\n type.kind === 'number' ||\n type.kind === 'null' ||\n type.kind === 'value';\n } else {\n // ordering operator\n return type.kind === 'string' ||\n type.kind === 'number' ||\n type.kind === 'value';\n }\n}\n\nfunction eq(ctx: EvaluationContext, a: any, b: any): boolean { return a === b; }\nfunction neq(ctx: EvaluationContext, a: any, b: any): boolean { return a !== b; }\nfunction lt(ctx: EvaluationContext, a: any, b: any): boolean { return a < b; }\nfunction gt(ctx: EvaluationContext, a: any, b: any): boolean { return a > b; }\nfunction lteq(ctx: EvaluationContext, a: any, b: any): boolean { return a <= b; }\nfunction gteq(ctx: EvaluationContext, a: any, b: any): boolean { return a >= b; }\n\nfunction eqCollate(ctx: EvaluationContext, a: any, b: any, c: any): boolean { return c.compare(a, b) === 0; }\nfunction neqCollate(ctx: EvaluationContext, a: any, b: any, c: any): boolean { return !eqCollate(ctx, a, b, c); }\nfunction ltCollate(ctx: EvaluationContext, a: any, b: any, c: any): boolean { return c.compare(a, b) < 0; }\nfunction gtCollate(ctx: EvaluationContext, a: any, b: any, c: any): boolean { return c.compare(a, b) > 0; }\nfunction lteqCollate(ctx: EvaluationContext, a: any, b: any, c: any): boolean { return c.compare(a, b) <= 0; }\nfunction gteqCollate(ctx: EvaluationContext, a: any, b: any, c: any): boolean { return c.compare(a, b) >= 0; }\n\n/**\n * Special form for comparison operators, implementing the signatures:\n * - (T, T, ?Collator) => boolean\n * - (T, value, ?Collator) => boolean\n * - (value, T, ?Collator) => boolean\n *\n * For inequalities, T must be either value, string, or number. For ==/!=, it\n * can also be boolean or null.\n *\n * Equality semantics are equivalent to Javascript's strict equality (===/!==)\n * -- i.e., when the arguments' types don't match, == evaluates to false, != to\n * true.\n *\n * When types don't match in an ordering comparison, a runtime error is thrown.\n *\n * @private\n */\nfunction makeComparison(op: ComparisonOperator, compareBasic: (EvaluationContext, any, any) => boolean, compareWithCollator: (EvaluationContext, any, any, any) => boolean): ExpressionRegistration {\n const isOrderComparison = op !== '==' && op !== '!=';\n\n return class Comparison implements Expression {\n type: Type;\n lhs: Expression;\n rhs: Expression;\n collator: ?Expression;\n hasUntypedArgument: boolean;\n\n constructor(lhs: Expression, rhs: Expression, collator: ?Expression) {\n this.type = BooleanType;\n this.lhs = lhs;\n this.rhs = rhs;\n this.collator = collator;\n this.hasUntypedArgument = lhs.type.kind === 'value' || rhs.type.kind === 'value';\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n if (args.length !== 3 && args.length !== 4)\n return context.error(`Expected two or three arguments.`);\n\n const op: ComparisonOperator = (args[0]: any);\n\n let lhs = context.parse(args[1], 1, ValueType);\n if (!lhs) return null;\n if (!isComparableType(op, lhs.type)) {\n return context.concat(1).error(`\"${op}\" comparisons are not supported for type '${toString(lhs.type)}'.`);\n }\n let rhs = context.parse(args[2], 2, ValueType);\n if (!rhs) return null;\n if (!isComparableType(op, rhs.type)) {\n return context.concat(2).error(`\"${op}\" comparisons are not supported for type '${toString(rhs.type)}'.`);\n }\n\n if (\n lhs.type.kind !== rhs.type.kind &&\n lhs.type.kind !== 'value' &&\n rhs.type.kind !== 'value'\n ) {\n return context.error(`Cannot compare types '${toString(lhs.type)}' and '${toString(rhs.type)}'.`);\n }\n\n if (isOrderComparison) {\n // typing rules specific to less/greater than operators\n if (lhs.type.kind === 'value' && rhs.type.kind !== 'value') {\n // (value, T)\n lhs = new Assertion(rhs.type, [lhs]);\n } else if (lhs.type.kind !== 'value' && rhs.type.kind === 'value') {\n // (T, value)\n rhs = new Assertion(lhs.type, [rhs]);\n }\n }\n\n let collator = null;\n if (args.length === 4) {\n if (\n lhs.type.kind !== 'string' &&\n rhs.type.kind !== 'string' &&\n lhs.type.kind !== 'value' &&\n rhs.type.kind !== 'value'\n ) {\n return context.error(`Cannot use collator to compare non-string types.`);\n }\n collator = context.parse(args[3], 3, CollatorType);\n if (!collator) return null;\n }\n\n return new Comparison(lhs, rhs, collator);\n }\n\n evaluate(ctx: EvaluationContext): boolean {\n const lhs = this.lhs.evaluate(ctx);\n const rhs = this.rhs.evaluate(ctx);\n\n if (isOrderComparison && this.hasUntypedArgument) {\n const lt = typeOf(lhs);\n const rt = typeOf(rhs);\n // check that type is string or number, and equal\n if (lt.kind !== rt.kind || !(lt.kind === 'string' || lt.kind === 'number')) {\n throw new RuntimeError(`Expected arguments for \"${op}\" to be (string, string) or (number, number), but found (${lt.kind}, ${rt.kind}) instead.`);\n }\n }\n\n if (this.collator && !isOrderComparison && this.hasUntypedArgument) {\n const lt = typeOf(lhs);\n const rt = typeOf(rhs);\n if (lt.kind !== 'string' || rt.kind !== 'string') {\n return compareBasic(ctx, lhs, rhs);\n }\n }\n\n return this.collator ?\n compareWithCollator(ctx, lhs, rhs, this.collator.evaluate(ctx)) :\n compareBasic(ctx, lhs, rhs);\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.lhs);\n fn(this.rhs);\n if (this.collator) {\n fn(this.collator);\n }\n }\n\n outputDefined(): boolean {\n return true;\n }\n\n serialize(): SerializedExpression {\n const serialized = [op];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n };\n}\n\nexport const Equals: $Call = makeComparison('==', eq, eqCollate);\nexport const NotEquals: $Call = makeComparison('<', lt, ltCollate);\nexport const GreaterThan: $Call', typeof gt, typeof gtCollate> = makeComparison('>', gt, gtCollate);\nexport const LessThanOrEqual: $Call=', typeof gteq, typeof gteqCollate> = makeComparison('>=', gteq, gteqCollate);\n","// @flow\n\nimport {StringType, NumberType} from '../types.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type {Type} from '../types.js';\n\ndeclare var Intl: {\n NumberFormat: Class\n};\n\ndeclare class Intl$NumberFormat {\n constructor (\n locales?: string | string[],\n options?: NumberFormatOptions\n ): Intl$NumberFormat;\n\n static (\n locales?: string | string[],\n options?: NumberFormatOptions\n ): Intl$NumberFormat;\n\n format(a: number): string;\n\n resolvedOptions(): any;\n}\n\ntype NumberFormatOptions = {\n style?: 'decimal' | 'currency' | 'percent' | 'unit';\n currency?: null | string;\n unit?: null | string;\n minimumFractionDigits?: null | string;\n maximumFractionDigits?: null | string;\n};\n\nexport default class NumberFormat implements Expression {\n type: Type;\n number: Expression;\n locale: Expression | null; // BCP 47 language tag\n currency: Expression | null; // ISO 4217 currency code, required if style=currency\n unit: Expression | null; // Simple units sanctioned for use in ECMAScript, required if style=unit. https://tc39.es/proposal-unified-intl-numberformat/section6/locales-currencies-tz_proposed_out.html#sec-issanctionedsimpleunitidentifier\n minFractionDigits: Expression | null; // Default 0\n maxFractionDigits: Expression | null; // Default 3\n\n constructor(number: Expression,\n locale: Expression | null,\n currency: Expression | null,\n unit: Expression | null,\n minFractionDigits: Expression | null,\n maxFractionDigits: Expression | null) {\n this.type = StringType;\n this.number = number;\n this.locale = locale;\n this.currency = currency;\n this.unit = unit;\n this.minFractionDigits = minFractionDigits;\n this.maxFractionDigits = maxFractionDigits;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Expression {\n if (args.length !== 3)\n return context.error(`Expected two arguments.`);\n\n const number = context.parse(args[1], 1, NumberType);\n if (!number) return null;\n\n const options = (args[2]: any);\n if (typeof options !== \"object\" || Array.isArray(options))\n return context.error(`NumberFormat options argument must be an object.`);\n\n let locale = null;\n if (options['locale']) {\n locale = context.parse(options['locale'], 1, StringType);\n if (!locale) return null;\n }\n\n let currency = null;\n if (options['currency']) {\n currency = context.parse(options['currency'], 1, StringType);\n if (!currency) return null;\n }\n\n let unit = null;\n if (options['unit']) {\n unit = context.parse(options['unit'], 1, StringType);\n if (!unit) return null;\n }\n\n let minFractionDigits = null;\n if (options['min-fraction-digits']) {\n minFractionDigits = context.parse(options['min-fraction-digits'], 1, NumberType);\n if (!minFractionDigits) return null;\n }\n\n let maxFractionDigits = null;\n if (options['max-fraction-digits']) {\n maxFractionDigits = context.parse(options['max-fraction-digits'], 1, NumberType);\n if (!maxFractionDigits) return null;\n }\n\n return new NumberFormat(number, locale, currency, unit, minFractionDigits, maxFractionDigits);\n }\n\n evaluate(ctx: EvaluationContext): string {\n return new Intl.NumberFormat(this.locale ? this.locale.evaluate(ctx) : [],\n {\n style:\n (this.currency && \"currency\") ||\n (this.unit && \"unit\") ||\n \"decimal\",\n currency: this.currency ? this.currency.evaluate(ctx) : undefined,\n unit: this.unit ? this.unit.evaluate(ctx) : undefined,\n minimumFractionDigits: this.minFractionDigits ? this.minFractionDigits.evaluate(ctx) : undefined,\n maximumFractionDigits: this.maxFractionDigits ? this.maxFractionDigits.evaluate(ctx) : undefined,\n }).format(this.number.evaluate(ctx));\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.number);\n if (this.locale) {\n fn(this.locale);\n }\n if (this.currency) {\n fn(this.currency);\n }\n if (this.unit) {\n fn(this.unit);\n }\n if (this.minFractionDigits) {\n fn(this.minFractionDigits);\n }\n if (this.maxFractionDigits) {\n fn(this.maxFractionDigits);\n }\n }\n\n outputDefined(): boolean {\n return false;\n }\n\n serialize(): SerializedExpression {\n const options = {};\n if (this.locale) {\n options['locale'] = this.locale.serialize();\n }\n if (this.currency) {\n options['currency'] = this.currency.serialize();\n }\n if (this.unit) {\n options['unit'] = this.unit.serialize();\n }\n if (this.minFractionDigits) {\n options['min-fraction-digits'] = this.minFractionDigits.serialize();\n }\n if (this.maxFractionDigits) {\n options['max-fraction-digits'] = this.maxFractionDigits.serialize();\n }\n return [\"number-format\", this.number.serialize(), options];\n }\n}\n","// @flow\n\nimport {NumberType, toString} from '../types.js';\n\nimport {typeOf} from '../values.js';\nimport RuntimeError from '../runtime_error.js';\n\nimport type {Expression, SerializedExpression} from '../expression.js';\nimport type ParsingContext from '../parsing_context.js';\nimport type EvaluationContext from '../evaluation_context.js';\nimport type {Type} from '../types.js';\n\nclass Length implements Expression {\n type: Type;\n input: Expression;\n\n constructor(input: Expression) {\n this.type = NumberType;\n this.input = input;\n }\n\n static parse(args: $ReadOnlyArray, context: ParsingContext): ?Length {\n if (args.length !== 2)\n return context.error(`Expected 1 argument, but found ${args.length - 1} instead.`);\n\n const input = context.parse(args[1], 1);\n if (!input) return null;\n\n if (input.type.kind !== 'array' && input.type.kind !== 'string' && input.type.kind !== 'value')\n return context.error(`Expected argument of type string or array, but found ${toString(input.type)} instead.`);\n\n return new Length(input);\n }\n\n evaluate(ctx: EvaluationContext): any | number {\n const input = this.input.evaluate(ctx);\n if (typeof input === 'string') {\n return input.length;\n } else if (Array.isArray(input)) {\n return input.length;\n } else {\n throw new RuntimeError(`Expected value to be of type string or array, but found ${toString(typeOf(input))} instead.`);\n }\n }\n\n eachChild(fn: (_: Expression) => void) {\n fn(this.input);\n }\n\n outputDefined(): boolean {\n return false;\n }\n\n serialize(): SerializedExpression {\n const serialized = [\"length\"];\n this.eachChild(child => { serialized.push(child.serialize()); });\n return serialized;\n }\n}\n\nexport default Length;\n","// @flow\n\nimport {\n type Type,\n NumberType,\n StringType,\n BooleanType,\n ColorType,\n ObjectType,\n ValueType,\n ErrorType,\n CollatorType,\n array,\n toString as typeToString\n} from '../types.js';\n\nimport {typeOf, Color, validateRGBA, toString as valueToString} from '../values.js';\nimport CompoundExpression from '../compound_expression.js';\nimport RuntimeError from '../runtime_error.js';\nimport Let from './let.js';\nimport Var from './var.js';\nimport Literal from './literal.js';\nimport Assertion from './assertion.js';\nimport Coercion from './coercion.js';\nimport At from './at.js';\nimport In from './in.js';\nimport IndexOf from './index_of.js';\nimport Match from './match.js';\nimport Case from './case.js';\nimport Slice from './slice.js';\nimport Step from './step.js';\nimport Interpolate from './interpolate.js';\nimport Coalesce from './coalesce.js';\nimport {\n Equals,\n NotEquals,\n LessThan,\n GreaterThan,\n LessThanOrEqual,\n GreaterThanOrEqual\n} from './comparison.js';\nimport CollatorExpression from './collator.js';\nimport NumberFormat from './number_format.js';\nimport FormatExpression from './format.js';\nimport ImageExpression from './image.js';\nimport Length from './length.js';\nimport Within from './within.js';\n\nimport type {Varargs} from '../compound_expression.js';\nimport type {ExpressionRegistry} from '../expression.js';\n\nconst expressions: ExpressionRegistry = {\n // special forms\n '==': Equals,\n '!=': NotEquals,\n '>': GreaterThan,\n '<': LessThan,\n '>=': GreaterThanOrEqual,\n '<=': LessThanOrEqual,\n 'array': Assertion,\n 'at': At,\n 'boolean': Assertion,\n 'case': Case,\n 'coalesce': Coalesce,\n 'collator': CollatorExpression,\n 'format': FormatExpression,\n 'image': ImageExpression,\n 'in': In,\n 'index-of': IndexOf,\n 'interpolate': Interpolate,\n 'interpolate-hcl': Interpolate,\n 'interpolate-lab': Interpolate,\n 'length': Length,\n 'let': Let,\n 'literal': Literal,\n 'match': Match,\n 'number': Assertion,\n 'number-format': NumberFormat,\n 'object': Assertion,\n 'slice': Slice,\n 'step': Step,\n 'string': Assertion,\n 'to-boolean': Coercion,\n 'to-color': Coercion,\n 'to-number': Coercion,\n 'to-string': Coercion,\n 'var': Var,\n 'within': Within\n};\n\nfunction rgba(ctx, [r, g, b, a]) {\n r = r.evaluate(ctx);\n g = g.evaluate(ctx);\n b = b.evaluate(ctx);\n const alpha = a ? a.evaluate(ctx) : 1;\n const error = validateRGBA(r, g, b, alpha);\n if (error) throw new RuntimeError(error);\n return new Color(r / 255 * alpha, g / 255 * alpha, b / 255 * alpha, alpha);\n}\n\nfunction has(key, obj) {\n return key in obj;\n}\n\nfunction get(key, obj) {\n const v = obj[key];\n return typeof v === 'undefined' ? null : v;\n}\n\nfunction binarySearch(v, a, i, j) {\n while (i <= j) {\n const m = (i + j) >> 1;\n if (a[m] === v)\n return true;\n if (a[m] > v)\n j = m - 1;\n else\n i = m + 1;\n }\n return false;\n}\n\nfunction varargs(type: Type): Varargs {\n return {type};\n}\n\nCompoundExpression.register(expressions, {\n 'error': [\n ErrorType,\n [StringType],\n (ctx, [v]) => { throw new RuntimeError(v.evaluate(ctx)); }\n ],\n 'typeof': [\n StringType,\n [ValueType],\n (ctx, [v]) => typeToString(typeOf(v.evaluate(ctx)))\n ],\n 'to-rgba': [\n array(NumberType, 4),\n [ColorType],\n (ctx, [v]) => {\n return v.evaluate(ctx).toArray();\n }\n ],\n 'rgb': [\n ColorType,\n [NumberType, NumberType, NumberType],\n rgba\n ],\n 'rgba': [\n ColorType,\n [NumberType, NumberType, NumberType, NumberType],\n rgba\n ],\n 'has': {\n type: BooleanType,\n overloads: [\n [\n [StringType],\n (ctx, [key]) => has(key.evaluate(ctx), ctx.properties())\n ], [\n [StringType, ObjectType],\n (ctx, [key, obj]) => has(key.evaluate(ctx), obj.evaluate(ctx))\n ]\n ]\n },\n 'get': {\n type: ValueType,\n overloads: [\n [\n [StringType],\n (ctx, [key]) => get(key.evaluate(ctx), ctx.properties())\n ], [\n [StringType, ObjectType],\n (ctx, [key, obj]) => get(key.evaluate(ctx), obj.evaluate(ctx))\n ]\n ]\n },\n 'feature-state': [\n ValueType,\n [StringType],\n (ctx, [key]) => get(key.evaluate(ctx), ctx.featureState || {})\n ],\n 'properties': [\n ObjectType,\n [],\n (ctx) => ctx.properties()\n ],\n 'geometry-type': [\n StringType,\n [],\n (ctx) => ctx.geometryType()\n ],\n 'id': [\n ValueType,\n [],\n (ctx) => ctx.id()\n ],\n 'zoom': [\n NumberType,\n [],\n (ctx) => ctx.globals.zoom\n ],\n 'pitch': [\n NumberType,\n [],\n (ctx) => ctx.globals.pitch || 0\n ],\n 'distance-from-center': [\n NumberType,\n [],\n (ctx) => ctx.distanceFromCenter()\n ],\n 'heatmap-density': [\n NumberType,\n [],\n (ctx) => ctx.globals.heatmapDensity || 0\n ],\n 'line-progress': [\n NumberType,\n [],\n (ctx) => ctx.globals.lineProgress || 0\n ],\n 'sky-radial-progress': [\n NumberType,\n [],\n (ctx) => ctx.globals.skyRadialProgress || 0\n ],\n 'accumulated': [\n ValueType,\n [],\n (ctx) => ctx.globals.accumulated === undefined ? null : ctx.globals.accumulated\n ],\n '+': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => {\n let result = 0;\n for (const arg of args) {\n result += arg.evaluate(ctx);\n }\n return result;\n }\n ],\n '*': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => {\n let result = 1;\n for (const arg of args) {\n result *= arg.evaluate(ctx);\n }\n return result;\n }\n ],\n '-': {\n type: NumberType,\n overloads: [\n [\n [NumberType, NumberType],\n (ctx, [a, b]) => a.evaluate(ctx) - b.evaluate(ctx)\n ], [\n [NumberType],\n (ctx, [a]) => -a.evaluate(ctx)\n ]\n ]\n },\n '/': [\n NumberType,\n [NumberType, NumberType],\n (ctx, [a, b]) => a.evaluate(ctx) / b.evaluate(ctx)\n ],\n '%': [\n NumberType,\n [NumberType, NumberType],\n (ctx, [a, b]) => a.evaluate(ctx) % b.evaluate(ctx)\n ],\n 'ln2': [\n NumberType,\n [],\n () => Math.LN2\n ],\n 'pi': [\n NumberType,\n [],\n () => Math.PI\n ],\n 'e': [\n NumberType,\n [],\n () => Math.E\n ],\n '^': [\n NumberType,\n [NumberType, NumberType],\n (ctx, [b, e]) => Math.pow(b.evaluate(ctx), e.evaluate(ctx))\n ],\n 'sqrt': [\n NumberType,\n [NumberType],\n (ctx, [x]) => Math.sqrt(x.evaluate(ctx))\n ],\n 'log10': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.log(n.evaluate(ctx)) / Math.LN10\n ],\n 'ln': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.log(n.evaluate(ctx))\n ],\n 'log2': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.log(n.evaluate(ctx)) / Math.LN2\n ],\n 'sin': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.sin(n.evaluate(ctx))\n ],\n 'cos': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.cos(n.evaluate(ctx))\n ],\n 'tan': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.tan(n.evaluate(ctx))\n ],\n 'asin': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.asin(n.evaluate(ctx))\n ],\n 'acos': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.acos(n.evaluate(ctx))\n ],\n 'atan': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.atan(n.evaluate(ctx))\n ],\n 'min': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => Math.min(...args.map(arg => arg.evaluate(ctx)))\n ],\n 'max': [\n NumberType,\n varargs(NumberType),\n (ctx, args) => Math.max(...args.map(arg => arg.evaluate(ctx)))\n ],\n 'abs': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.abs(n.evaluate(ctx))\n ],\n 'round': [\n NumberType,\n [NumberType],\n (ctx, [n]) => {\n const v = n.evaluate(ctx);\n // Javascript's Math.round() rounds towards +Infinity for halfway\n // values, even when they're negative. It's more common to round\n // away from 0 (e.g., this is what python and C++ do)\n return v < 0 ? -Math.round(-v) : Math.round(v);\n }\n ],\n 'floor': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.floor(n.evaluate(ctx))\n ],\n 'ceil': [\n NumberType,\n [NumberType],\n (ctx, [n]) => Math.ceil(n.evaluate(ctx))\n ],\n 'filter-==': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => ctx.properties()[(k: any).value] === (v: any).value\n ],\n 'filter-id-==': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => ctx.id() === (v: any).value\n ],\n 'filter-type-==': [\n BooleanType,\n [StringType],\n (ctx, [v]) => ctx.geometryType() === (v: any).value\n ],\n 'filter-<': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[(k: any).value];\n const b = (v: any).value;\n return typeof a === typeof b && a < b;\n }\n ],\n 'filter-id-<': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = (v: any).value;\n return typeof a === typeof b && a < b;\n }\n ],\n 'filter->': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[(k: any).value];\n const b = (v: any).value;\n return typeof a === typeof b && a > b;\n }\n ],\n 'filter-id->': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = (v: any).value;\n return typeof a === typeof b && a > b;\n }\n ],\n 'filter-<=': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[(k: any).value];\n const b = (v: any).value;\n return typeof a === typeof b && a <= b;\n }\n ],\n 'filter-id-<=': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = (v: any).value;\n return typeof a === typeof b && a <= b;\n }\n ],\n 'filter->=': [\n BooleanType,\n [StringType, ValueType],\n (ctx, [k, v]) => {\n const a = ctx.properties()[(k: any).value];\n const b = (v: any).value;\n return typeof a === typeof b && a >= b;\n }\n ],\n 'filter-id->=': [\n BooleanType,\n [ValueType],\n (ctx, [v]) => {\n const a = ctx.id();\n const b = (v: any).value;\n return typeof a === typeof b && a >= b;\n }\n ],\n 'filter-has': [\n BooleanType,\n [ValueType],\n (ctx, [k]) => (k: any).value in ctx.properties()\n ],\n 'filter-has-id': [\n BooleanType,\n [],\n (ctx) => (ctx.id() !== null && ctx.id() !== undefined)\n ],\n 'filter-type-in': [\n BooleanType,\n [array(StringType)],\n (ctx, [v]) => (v: any).value.indexOf(ctx.geometryType()) >= 0\n ],\n 'filter-id-in': [\n BooleanType,\n [array(ValueType)],\n (ctx, [v]) => (v: any).value.indexOf(ctx.id()) >= 0\n ],\n 'filter-in-small': [\n BooleanType,\n [StringType, array(ValueType)],\n // assumes v is an array literal\n (ctx, [k, v]) => (v: any).value.indexOf(ctx.properties()[(k: any).value]) >= 0\n ],\n 'filter-in-large': [\n BooleanType,\n [StringType, array(ValueType)],\n // assumes v is a array literal with values sorted in ascending order and of a single type\n (ctx, [k, v]) => binarySearch(ctx.properties()[(k: any).value], (v: any).value, 0, (v: any).value.length - 1)\n ],\n 'all': {\n type: BooleanType,\n overloads: [\n [\n [BooleanType, BooleanType],\n (ctx, [a, b]) => a.evaluate(ctx) && b.evaluate(ctx)\n ],\n [\n varargs(BooleanType),\n (ctx, args) => {\n for (const arg of args) {\n if (!arg.evaluate(ctx))\n return false;\n }\n return true;\n }\n ]\n ]\n },\n 'any': {\n type: BooleanType,\n overloads: [\n [\n [BooleanType, BooleanType],\n (ctx, [a, b]) => a.evaluate(ctx) || b.evaluate(ctx)\n ],\n [\n varargs(BooleanType),\n (ctx, args) => {\n for (const arg of args) {\n if (arg.evaluate(ctx))\n return true;\n }\n return false;\n }\n ]\n ]\n },\n '!': [\n BooleanType,\n [BooleanType],\n (ctx, [b]) => !b.evaluate(ctx)\n ],\n 'is-supported-script': [\n BooleanType,\n [StringType],\n // At parse time this will always return true, so we need to exclude this expression with isGlobalPropertyConstant\n (ctx, [s]) => {\n const isSupportedScript = ctx.globals && ctx.globals.isSupportedScript;\n if (isSupportedScript) {\n return isSupportedScript(s.evaluate(ctx));\n }\n return true;\n }\n ],\n 'upcase': [\n StringType,\n [StringType],\n (ctx, [s]) => s.evaluate(ctx).toUpperCase()\n ],\n 'downcase': [\n StringType,\n [StringType],\n (ctx, [s]) => s.evaluate(ctx).toLowerCase()\n ],\n 'concat': [\n StringType,\n varargs(ValueType),\n (ctx, args) => args.map(arg => valueToString(arg.evaluate(ctx))).join('')\n ],\n 'resolved-locale': [\n StringType,\n [CollatorType],\n (ctx, [collator]) => collator.evaluate(ctx).resolvedLocale()\n ]\n});\n\nexport default expressions;\n","// @flow\n\n/**\n * A type used for returning and propagating errors. The first element of the union\n * represents success and contains a value, and the second represents an error and\n * contains an error value.\n * @private\n */\nexport type Result =\n | {| result: 'success', value: T |}\n | {| result: 'error', value: E |};\n\nexport function success(value: T): Result {\n return {result: 'success', value};\n}\n\nexport function error(value: E): Result {\n return {result: 'error', value};\n}\n","\nimport * as colorSpaces from '../util/color_spaces.js';\nimport Color from '../util/color.js';\nimport extend from '../util/extend.js';\nimport getType from '../util/get_type.js';\nimport * as interpolate from '../util/interpolate.js';\nimport Interpolate from '../expression/definitions/interpolate.js';\nimport Formatted from '../expression/types/formatted.js';\nimport ResolvedImage from '../expression/types/resolved_image.js';\nimport {supportsInterpolation} from '../util/properties.js';\nimport {findStopLessThanOrEqualTo} from '../expression/stops.js';\n\nexport function isFunction(value) {\n return typeof value === 'object' && value !== null && !Array.isArray(value);\n}\n\nfunction identityFunction(x) {\n return x;\n}\n\nexport function createFunction(parameters, propertySpec) {\n const isColor = propertySpec.type === 'color';\n const zoomAndFeatureDependent = parameters.stops && typeof parameters.stops[0][0] === 'object';\n const featureDependent = zoomAndFeatureDependent || parameters.property !== undefined;\n const zoomDependent = zoomAndFeatureDependent || !featureDependent;\n const type = parameters.type || (supportsInterpolation(propertySpec) ? 'exponential' : 'interval');\n\n if (isColor) {\n parameters = extend({}, parameters);\n\n if (parameters.stops) {\n parameters.stops = parameters.stops.map((stop) => {\n return [stop[0], Color.parse(stop[1])];\n });\n }\n\n if (parameters.default) {\n parameters.default = Color.parse(parameters.default);\n } else {\n parameters.default = Color.parse(propertySpec.default);\n }\n }\n\n if (parameters.colorSpace && parameters.colorSpace !== 'rgb' && !colorSpaces[parameters.colorSpace]) { // eslint-disable-line import/namespace\n throw new Error(`Unknown color space: ${parameters.colorSpace}`);\n }\n\n let innerFun;\n let hashedStops;\n let categoricalKeyType;\n if (type === 'exponential') {\n innerFun = evaluateExponentialFunction;\n } else if (type === 'interval') {\n innerFun = evaluateIntervalFunction;\n } else if (type === 'categorical') {\n innerFun = evaluateCategoricalFunction;\n\n // For categorical functions, generate an Object as a hashmap of the stops for fast searching\n hashedStops = Object.create(null);\n for (const stop of parameters.stops) {\n hashedStops[stop[0]] = stop[1];\n }\n\n // Infer key type based on first stop key-- used to encforce strict type checking later\n categoricalKeyType = typeof parameters.stops[0][0];\n\n } else if (type === 'identity') {\n innerFun = evaluateIdentityFunction;\n } else {\n throw new Error(`Unknown function type \"${type}\"`);\n }\n\n if (zoomAndFeatureDependent) {\n const featureFunctions = {};\n const zoomStops = [];\n for (let s = 0; s < parameters.stops.length; s++) {\n const stop = parameters.stops[s];\n const zoom = stop[0].zoom;\n if (featureFunctions[zoom] === undefined) {\n featureFunctions[zoom] = {\n zoom,\n type: parameters.type,\n property: parameters.property,\n default: parameters.default,\n stops: []\n };\n zoomStops.push(zoom);\n }\n featureFunctions[zoom].stops.push([stop[0].value, stop[1]]);\n }\n\n const featureFunctionStops = [];\n for (const z of zoomStops) {\n featureFunctionStops.push([featureFunctions[z].zoom, createFunction(featureFunctions[z], propertySpec)]);\n }\n\n const interpolationType = {name: 'linear'};\n return {\n kind: 'composite',\n interpolationType,\n interpolationFactor: Interpolate.interpolationFactor.bind(undefined, interpolationType),\n zoomStops: featureFunctionStops.map(s => s[0]),\n evaluate({zoom}, properties) {\n return evaluateExponentialFunction({\n stops: featureFunctionStops,\n base: parameters.base\n }, propertySpec, zoom).evaluate(zoom, properties);\n }\n };\n } else if (zoomDependent) {\n const interpolationType = type === 'exponential' ?\n {name: 'exponential', base: parameters.base !== undefined ? parameters.base : 1} : null;\n return {\n kind: 'camera',\n interpolationType,\n interpolationFactor: Interpolate.interpolationFactor.bind(undefined, interpolationType),\n zoomStops: parameters.stops.map(s => s[0]),\n evaluate: ({zoom}) => innerFun(parameters, propertySpec, zoom, hashedStops, categoricalKeyType)\n };\n } else {\n return {\n kind: 'source',\n evaluate(_, feature) {\n const value = feature && feature.properties ? feature.properties[parameters.property] : undefined;\n if (value === undefined) {\n return coalesce(parameters.default, propertySpec.default);\n }\n return innerFun(parameters, propertySpec, value, hashedStops, categoricalKeyType);\n }\n };\n }\n}\n\nfunction coalesce(a, b, c) {\n if (a !== undefined) return a;\n if (b !== undefined) return b;\n if (c !== undefined) return c;\n}\n\nfunction evaluateCategoricalFunction(parameters, propertySpec, input, hashedStops, keyType) {\n const evaluated = typeof input === keyType ? hashedStops[input] : undefined; // Enforce strict typing on input\n return coalesce(evaluated, parameters.default, propertySpec.default);\n}\n\nfunction evaluateIntervalFunction(parameters, propertySpec, input) {\n // Edge cases\n if (getType(input) !== 'number') return coalesce(parameters.default, propertySpec.default);\n const n = parameters.stops.length;\n if (n === 1) return parameters.stops[0][1];\n if (input <= parameters.stops[0][0]) return parameters.stops[0][1];\n if (input >= parameters.stops[n - 1][0]) return parameters.stops[n - 1][1];\n\n const index = findStopLessThanOrEqualTo(parameters.stops.map((stop) => stop[0]), input);\n\n return parameters.stops[index][1];\n}\n\nfunction evaluateExponentialFunction(parameters, propertySpec, input) {\n const base = parameters.base !== undefined ? parameters.base : 1;\n\n // Edge cases\n if (getType(input) !== 'number') return coalesce(parameters.default, propertySpec.default);\n const n = parameters.stops.length;\n if (n === 1) return parameters.stops[0][1];\n if (input <= parameters.stops[0][0]) return parameters.stops[0][1];\n if (input >= parameters.stops[n - 1][0]) return parameters.stops[n - 1][1];\n\n const index = findStopLessThanOrEqualTo(parameters.stops.map((stop) => stop[0]), input);\n const t = interpolationFactor(\n input, base,\n parameters.stops[index][0],\n parameters.stops[index + 1][0]);\n\n const outputLower = parameters.stops[index][1];\n const outputUpper = parameters.stops[index + 1][1];\n let interp = interpolate[propertySpec.type] || identityFunction; // eslint-disable-line import/namespace\n\n if (parameters.colorSpace && parameters.colorSpace !== 'rgb') {\n const colorspace = colorSpaces[parameters.colorSpace]; // eslint-disable-line import/namespace\n interp = (a, b) => colorspace.reverse(colorspace.interpolate(colorspace.forward(a), colorspace.forward(b), t));\n }\n\n if (typeof outputLower.evaluate === 'function') {\n return {\n evaluate(...args) {\n const evaluatedLower = outputLower.evaluate.apply(undefined, args);\n const evaluatedUpper = outputUpper.evaluate.apply(undefined, args);\n // Special case for fill-outline-color, which has no spec default.\n if (evaluatedLower === undefined || evaluatedUpper === undefined) {\n return undefined;\n }\n return interp(evaluatedLower, evaluatedUpper, t);\n }\n };\n }\n\n return interp(outputLower, outputUpper, t);\n}\n\nfunction evaluateIdentityFunction(parameters, propertySpec, input) {\n if (propertySpec.type === 'color') {\n input = Color.parse(input);\n } else if (propertySpec.type === 'formatted') {\n input = Formatted.fromString(input.toString());\n } else if (propertySpec.type === 'resolvedImage') {\n input = ResolvedImage.fromString(input.toString());\n } else if (getType(input) !== propertySpec.type && (propertySpec.type !== 'enum' || !propertySpec.values[input])) {\n input = undefined;\n }\n return coalesce(input, parameters.default, propertySpec.default);\n}\n\n/**\n * Returns a ratio that can be used to interpolate between exponential function\n * stops.\n *\n * How it works:\n * Two consecutive stop values define a (scaled and shifted) exponential\n * function `f(x) = a * base^x + b`, where `base` is the user-specified base,\n * and `a` and `b` are constants affording sufficient degrees of freedom to fit\n * the function to the given stops.\n *\n * Here's a bit of algebra that lets us compute `f(x)` directly from the stop\n * values without explicitly solving for `a` and `b`:\n *\n * First stop value: `f(x0) = y0 = a * base^x0 + b`\n * Second stop value: `f(x1) = y1 = a * base^x1 + b`\n * => `y1 - y0 = a(base^x1 - base^x0)`\n * => `a = (y1 - y0)/(base^x1 - base^x0)`\n *\n * Desired value: `f(x) = y = a * base^x + b`\n * => `f(x) = y0 + a * (base^x - base^x0)`\n *\n * From the above, we can replace the `a` in `a * (base^x - base^x0)` and do a\n * little algebra:\n * ```\n * a * (base^x - base^x0) = (y1 - y0)/(base^x1 - base^x0) * (base^x - base^x0)\n * = (y1 - y0) * (base^x - base^x0) / (base^x1 - base^x0)\n * ```\n *\n * If we let `(base^x - base^x0) / (base^x1 base^x0)`, then we have\n * `f(x) = y0 + (y1 - y0) * ratio`. In other words, `ratio` may be treated as\n * an interpolation factor between the two stops' output values.\n *\n * (Note: a slightly different form for `ratio`,\n * `(base^(x-x0) - 1) / (base^(x1-x0) - 1) `, is equivalent, but requires fewer\n * expensive `Math.pow()` operations.)\n *\n * @private\n */\nfunction interpolationFactor(input, base, lowerValue, upperValue) {\n const difference = upperValue - lowerValue;\n const progress = input - lowerValue;\n\n if (difference === 0) {\n return 0;\n } else if (base === 1) {\n return progress / difference;\n } else {\n return (Math.pow(base, progress) - 1) / (Math.pow(base, difference) - 1);\n }\n}\n","// @flow\n\nimport assert from 'assert';\n\nimport extend from '../util/extend.js';\nimport ParsingError from './parsing_error.js';\nimport ParsingContext from './parsing_context.js';\nimport EvaluationContext from './evaluation_context.js';\nimport CompoundExpression from './compound_expression.js';\nimport Step from './definitions/step.js';\nimport Interpolate from './definitions/interpolate.js';\nimport Coalesce from './definitions/coalesce.js';\nimport Let from './definitions/let.js';\nimport definitions from './definitions/index.js';\nimport * as isConstant from './is_constant.js';\nimport RuntimeError from './runtime_error.js';\nimport {success, error} from '../util/result.js';\nimport {supportsPropertyExpression, supportsZoomExpression, supportsInterpolation} from '../util/properties.js';\n\nimport type {Type, EvaluationKind} from './types.js';\nimport type {Value} from './values.js';\nimport type {Expression} from './expression.js';\nimport type {StylePropertySpecification} from '../style-spec.js';\nimport type {Result} from '../util/result.js';\nimport type {InterpolationType} from './definitions/interpolate.js';\nimport type {PropertyValueSpecification} from '../types.js';\nimport type {FormattedSection} from './types/formatted.js';\nimport type Point from '@mapbox/point-geometry';\nimport type {CanonicalTileID} from '../../source/tile_id.js';\nimport type {FeatureDistanceData} from '../feature_filter/index.js';\n\nexport type Feature = {\n +type: 1 | 2 | 3 | 'Unknown' | 'Point' | 'LineString' | 'Polygon',\n +id?: number | null,\n +properties: {[_: string]: any},\n +patterns?: {[_: string]: string},\n +geometry?: Array>\n};\n\nexport type FeatureState = {[_: string]: any};\n\nexport type GlobalProperties = $ReadOnly<{\n zoom: number,\n pitch?: number,\n heatmapDensity?: number,\n lineProgress?: number,\n skyRadialProgress?: number,\n isSupportedScript?: (_: string) => boolean,\n accumulated?: Value\n}>;\n\nexport class StyleExpression {\n expression: Expression;\n\n _evaluator: EvaluationContext;\n _defaultValue: Value;\n _warningHistory: {[key: string]: boolean};\n _enumValues: ?{[_: string]: any};\n\n constructor(expression: Expression, propertySpec: ?StylePropertySpecification) {\n this.expression = expression;\n this._warningHistory = {};\n this._evaluator = new EvaluationContext();\n this._defaultValue = propertySpec ? getDefaultValue(propertySpec) : null;\n this._enumValues = propertySpec && propertySpec.type === 'enum' ? propertySpec.values : null;\n }\n\n evaluateWithoutErrorHandling(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection, featureTileCoord?: Point, featureDistanceData?: FeatureDistanceData): any {\n this._evaluator.globals = globals;\n this._evaluator.feature = feature;\n this._evaluator.featureState = featureState;\n this._evaluator.canonical = canonical || null;\n this._evaluator.availableImages = availableImages || null;\n this._evaluator.formattedSection = formattedSection;\n this._evaluator.featureTileCoord = featureTileCoord || null;\n this._evaluator.featureDistanceData = featureDistanceData || null;\n\n return this.expression.evaluate(this._evaluator);\n }\n\n evaluate(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection, featureTileCoord?: Point, featureDistanceData?: FeatureDistanceData): any {\n this._evaluator.globals = globals;\n this._evaluator.feature = feature || null;\n this._evaluator.featureState = featureState || null;\n this._evaluator.canonical = canonical || null;\n this._evaluator.availableImages = availableImages || null;\n this._evaluator.formattedSection = formattedSection || null;\n this._evaluator.featureTileCoord = featureTileCoord || null;\n this._evaluator.featureDistanceData = featureDistanceData || null;\n\n try {\n const val = this.expression.evaluate(this._evaluator);\n // eslint-disable-next-line no-self-compare\n if (val === null || val === undefined || (typeof val === 'number' && val !== val)) {\n return this._defaultValue;\n }\n if (this._enumValues && !(val in this._enumValues)) {\n throw new RuntimeError(`Expected value to be one of ${Object.keys(this._enumValues).map(v => JSON.stringify(v)).join(', ')}, but found ${JSON.stringify(val)} instead.`);\n }\n return val;\n } catch (e) {\n if (!this._warningHistory[e.message]) {\n this._warningHistory[e.message] = true;\n if (typeof console !== 'undefined') {\n console.warn(e.message);\n }\n }\n return this._defaultValue;\n }\n }\n}\n\nexport function isExpression(expression: mixed): boolean {\n return Array.isArray(expression) && expression.length > 0 &&\n typeof expression[0] === 'string' && expression[0] in definitions;\n}\n\n/**\n * Parse and typecheck the given style spec JSON expression. If\n * options.defaultValue is provided, then the resulting StyleExpression's\n * `evaluate()` method will handle errors by logging a warning (once per\n * message) and returning the default value. Otherwise, it will throw\n * evaluation errors.\n *\n * @private\n */\nexport function createExpression(expression: mixed, propertySpec: ?StylePropertySpecification): Result> {\n const parser = new ParsingContext(definitions, [], propertySpec ? getExpectedType(propertySpec) : undefined);\n\n // For string-valued properties, coerce to string at the top level rather than asserting.\n const parsed = parser.parse(expression, undefined, undefined, undefined,\n propertySpec && propertySpec.type === 'string' ? {typeAnnotation: 'coerce'} : undefined);\n\n if (!parsed) {\n assert(parser.errors.length > 0);\n return error(parser.errors);\n }\n\n return success(new StyleExpression(parsed, propertySpec));\n}\n\nexport class ZoomConstantExpression {\n kind: Kind;\n isStateDependent: boolean;\n _styleExpression: StyleExpression;\n\n constructor(kind: Kind, expression: StyleExpression) {\n this.kind = kind;\n this._styleExpression = expression;\n this.isStateDependent = kind !== ('constant': EvaluationKind) && !isConstant.isStateConstant(expression.expression);\n }\n\n evaluateWithoutErrorHandling(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection): any {\n return this._styleExpression.evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection);\n }\n\n evaluate(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection): any {\n return this._styleExpression.evaluate(globals, feature, featureState, canonical, availableImages, formattedSection);\n }\n}\n\nexport class ZoomDependentExpression {\n kind: Kind;\n zoomStops: Array;\n isStateDependent: boolean;\n\n _styleExpression: StyleExpression;\n interpolationType: ?InterpolationType;\n\n constructor(kind: Kind, expression: StyleExpression, zoomStops: Array, interpolationType?: InterpolationType) {\n this.kind = kind;\n this.zoomStops = zoomStops;\n this._styleExpression = expression;\n this.isStateDependent = kind !== ('camera': EvaluationKind) && !isConstant.isStateConstant(expression.expression);\n this.interpolationType = interpolationType;\n }\n\n evaluateWithoutErrorHandling(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection): any {\n return this._styleExpression.evaluateWithoutErrorHandling(globals, feature, featureState, canonical, availableImages, formattedSection);\n }\n\n evaluate(globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection): any {\n return this._styleExpression.evaluate(globals, feature, featureState, canonical, availableImages, formattedSection);\n }\n\n interpolationFactor(input: number, lower: number, upper: number): number {\n if (this.interpolationType) {\n return Interpolate.interpolationFactor(this.interpolationType, input, lower, upper);\n } else {\n return 0;\n }\n }\n}\n\nexport type ConstantExpression = {\n kind: 'constant',\n +evaluate: (globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array) => any,\n}\n\nexport type SourceExpression = {\n kind: 'source',\n isStateDependent: boolean,\n +evaluate: (globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection) => any,\n};\n\nexport type CameraExpression = {\n kind: 'camera',\n +evaluate: (globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array) => any,\n +interpolationFactor: (input: number, lower: number, upper: number) => number,\n zoomStops: Array,\n interpolationType: ?InterpolationType\n};\n\nexport type CompositeExpression = {\n kind: 'composite',\n isStateDependent: boolean,\n +evaluate: (globals: GlobalProperties, feature?: Feature, featureState?: FeatureState, canonical?: CanonicalTileID, availableImages?: Array, formattedSection?: FormattedSection) => any,\n +interpolationFactor: (input: number, lower: number, upper: number) => number,\n zoomStops: Array,\n interpolationType: ?InterpolationType\n};\n\nexport type StylePropertyExpression =\n | ConstantExpression\n | SourceExpression\n | CameraExpression\n | CompositeExpression;\n\nexport function createPropertyExpression(expression: mixed, propertySpec: StylePropertySpecification): Result> {\n expression = createExpression(expression, propertySpec);\n if (expression.result === 'error') {\n return expression;\n }\n\n const parsed = expression.value.expression;\n\n const isFeatureConstant = isConstant.isFeatureConstant(parsed);\n if (!isFeatureConstant && !supportsPropertyExpression(propertySpec)) {\n return error([new ParsingError('', 'data expressions not supported')]);\n }\n\n const isZoomConstant = isConstant.isGlobalPropertyConstant(parsed, ['zoom', 'pitch', 'distance-from-center']);\n if (!isZoomConstant && !supportsZoomExpression(propertySpec)) {\n return error([new ParsingError('', 'zoom expressions not supported')]);\n }\n\n const zoomCurve = findZoomCurve(parsed);\n if (!zoomCurve && !isZoomConstant) {\n return error([new ParsingError('', '\"zoom\" expression may only be used as input to a top-level \"step\" or \"interpolate\" expression.')]);\n } else if (zoomCurve instanceof ParsingError) {\n return error([zoomCurve]);\n } else if (zoomCurve instanceof Interpolate && !supportsInterpolation(propertySpec)) {\n return error([new ParsingError('', '\"interpolate\" expressions cannot be used with this property')]);\n }\n\n if (!zoomCurve) {\n return success(isFeatureConstant ?\n (new ZoomConstantExpression('constant', expression.value): ConstantExpression) :\n (new ZoomConstantExpression('source', expression.value): SourceExpression));\n }\n\n const interpolationType = zoomCurve instanceof Interpolate ? zoomCurve.interpolation : undefined;\n\n return success(isFeatureConstant ?\n (new ZoomDependentExpression('camera', expression.value, zoomCurve.labels, interpolationType): CameraExpression) :\n (new ZoomDependentExpression('composite', expression.value, zoomCurve.labels, interpolationType): CompositeExpression));\n}\n\nimport {isFunction, createFunction} from '../function/index.js';\nimport {Color} from './values.js';\n\n// serialization wrapper for old-style stop functions normalized to the\n// expression interface\nexport class StylePropertyFunction {\n _parameters: PropertyValueSpecification;\n _specification: StylePropertySpecification;\n\n kind: EvaluationKind;\n evaluate: (globals: GlobalProperties, feature?: Feature) => any;\n interpolationFactor: ?(input: number, lower: number, upper: number) => number;\n zoomStops: ?Array;\n\n constructor(parameters: PropertyValueSpecification, specification: StylePropertySpecification) {\n this._parameters = parameters;\n this._specification = specification;\n extend(this, createFunction(this._parameters, this._specification));\n }\n\n static deserialize(serialized: {_parameters: PropertyValueSpecification, _specification: StylePropertySpecification}): StylePropertyFunction {\n return new StylePropertyFunction(serialized._parameters, serialized._specification);\n }\n\n static serialize(input: StylePropertyFunction): {_parameters: PropertyValueSpecification, _specification: StylePropertySpecification} {\n return {\n _parameters: input._parameters,\n _specification: input._specification\n };\n }\n}\n\nexport function normalizePropertyExpression(value: PropertyValueSpecification, specification: StylePropertySpecification): StylePropertyExpression {\n if (isFunction(value)) {\n return (new StylePropertyFunction(value, specification): any);\n\n } else if (isExpression(value)) {\n const expression = createPropertyExpression(value, specification);\n if (expression.result === 'error') {\n // this should have been caught in validation\n throw new Error(expression.value.map(err => `${err.key}: ${err.message}`).join(', '));\n }\n return expression.value;\n\n } else {\n let constant: any = value;\n if (typeof value === 'string' && specification.type === 'color') {\n constant = Color.parse(value);\n }\n return {\n kind: 'constant',\n evaluate: () => constant\n };\n }\n}\n\n// Zoom-dependent expressions may only use [\"zoom\"] as the input to a top-level \"step\" or \"interpolate\"\n// expression (collectively referred to as a \"curve\"). The curve may be wrapped in one or more \"let\" or\n// \"coalesce\" expressions.\nfunction findZoomCurve(expression: Expression): Step | Interpolate | ParsingError | null {\n let result = null;\n if (expression instanceof Let) {\n result = findZoomCurve(expression.result);\n\n } else if (expression instanceof Coalesce) {\n for (const arg of expression.args) {\n result = findZoomCurve(arg);\n if (result) {\n break;\n }\n }\n\n } else if ((expression instanceof Step || expression instanceof Interpolate) &&\n expression.input instanceof CompoundExpression &&\n expression.input.name === 'zoom') {\n\n result = expression;\n }\n\n if (result instanceof ParsingError) {\n return result;\n }\n\n expression.eachChild((child) => {\n const childResult = findZoomCurve(child);\n if (childResult instanceof ParsingError) {\n result = childResult;\n } else if (!result && childResult) {\n result = new ParsingError('', '\"zoom\" expression may only be used as input to a top-level \"step\" or \"interpolate\" expression.');\n } else if (result && childResult && result !== childResult) {\n result = new ParsingError('', 'Only one zoom-based \"step\" or \"interpolate\" subexpression may be used in an expression.');\n }\n });\n\n return result;\n}\n\nimport {ColorType, StringType, NumberType, BooleanType, ValueType, FormattedType, ResolvedImageType, array} from './types.js';\n\nfunction getExpectedType(spec: StylePropertySpecification): Type {\n const types = {\n color: ColorType,\n string: StringType,\n number: NumberType,\n enum: StringType,\n boolean: BooleanType,\n formatted: FormattedType,\n resolvedImage: ResolvedImageType\n };\n\n if (spec.type === 'array') {\n return array(types[spec.value] || ValueType, spec.length);\n }\n\n return types[spec.type];\n}\n\nfunction getDefaultValue(spec: StylePropertySpecification): Value {\n if (spec.type === 'color' && (isFunction(spec.default) || Array.isArray(spec.default))) {\n // Special case for heatmap-color: it uses the 'default:' to define a\n // default color ramp, but createExpression expects a simple value to fall\n // back to in case of runtime errors\n return new Color(0, 0, 0, 0);\n } else if (spec.type === 'color') {\n return Color.parse(spec.default) || null;\n } else if (spec.default === undefined) {\n return null;\n } else {\n return spec.default;\n }\n}\n","// @flow\n\nimport type {StylePropertySpecification} from '../style-spec.js';\n\nexport function supportsPropertyExpression(spec: StylePropertySpecification): boolean {\n return spec['property-type'] === 'data-driven';\n}\n\nexport function supportsZoomExpression(spec: StylePropertySpecification): boolean {\n return !!spec.expression && spec.expression.parameters.indexOf('zoom') > -1;\n}\n\nexport function supportsInterpolation(spec: StylePropertySpecification): boolean {\n return !!spec.expression && spec.expression.interpolated;\n}\n","// @flow\n\n// Turn jsonlint-lines-primitives objects into primitive objects\nexport function unbundle(value: mixed): mixed {\n if (value instanceof Number || value instanceof String || value instanceof Boolean) {\n return value.valueOf();\n } else {\n return value;\n }\n}\n\nexport function deepUnbundle(value: mixed): mixed {\n if (Array.isArray(value)) {\n return value.map(deepUnbundle);\n } else if (value instanceof Object && !(value instanceof Number || value instanceof String || value instanceof Boolean)) {\n const unbundledValue: { [key: string]: mixed } = {};\n for (const key in value) {\n unbundledValue[key] = deepUnbundle(value[key]);\n }\n return unbundledValue;\n }\n\n return unbundle(value);\n}\n","{\n \"$version\": 8,\n \"$root\": {\n \"version\": {\n \"required\": true,\n \"type\": \"enum\",\n \"values\": [\n 8\n ],\n \"doc\": \"Style specification version number. Must be 8.\",\n \"example\": 8\n },\n \"name\": {\n \"type\": \"string\",\n \"doc\": \"A human-readable name for the style.\",\n \"example\": \"Bright\"\n },\n \"metadata\": {\n \"type\": \"*\",\n \"doc\": \"Arbitrary properties useful to track with the stylesheet, but do not influence rendering. Properties should be prefixed to avoid collisions, like 'mapbox:'.\"\n },\n \"center\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"doc\": \"Default map center in longitude and latitude. The style center will be used only if the map has not been positioned by other means (e.g. map options or user interaction).\",\n \"example\": [\n -73.9749,\n 40.7736\n ]\n },\n \"zoom\": {\n \"type\": \"number\",\n \"doc\": \"Default zoom level. The style zoom will be used only if the map has not been positioned by other means (e.g. map options or user interaction).\",\n \"example\": 12.5\n },\n \"bearing\": {\n \"type\": \"number\",\n \"default\": 0,\n \"period\": 360,\n \"units\": \"degrees\",\n \"doc\": \"Default bearing, in degrees. The bearing is the compass direction that is \\\"up\\\"; for example, a bearing of 90° orients the map so that east is up. This value will be used only if the map has not been positioned by other means (e.g. map options or user interaction).\",\n \"example\": 29\n },\n \"pitch\": {\n \"type\": \"number\",\n \"default\": 0,\n \"units\": \"degrees\",\n \"doc\": \"Default pitch, in degrees. Zero is perpendicular to the surface, for a look straight down at the map, while a greater value like 60 looks ahead towards the horizon. The style pitch will be used only if the map has not been positioned by other means (e.g. map options or user interaction).\",\n \"example\": 50\n },\n \"light\": {\n \"type\": \"light\",\n \"doc\": \"The global light source.\",\n \"example\": {\n \"anchor\": \"viewport\",\n \"color\": \"white\",\n \"intensity\": 0.4\n }\n },\n \"terrain\": {\n \"type\": \"terrain\",\n \"doc\": \"A global modifier that elevates layers and markers based on a DEM data source.\"\n },\n \"fog\": {\n \"type\": \"fog\",\n \"doc\": \"A global effect that fades layers and markers based on their distance to the camera. The fog can be used to approximate the effect of atmosphere on distant objects and enhance the depth perception of the map when used with terrain or 3D features. Note: fog is renamed to atmosphere in the Android and iOS SDKs and planned to be changed in GL-JS v.3.0.0.\"\n },\n \"sources\": {\n \"required\": true,\n \"type\": \"sources\",\n \"doc\": \"Data source specifications.\",\n \"example\": {\n \"mapbox-streets\": {\n \"type\": \"vector\",\n \"url\": \"mapbox://mapbox.mapbox-streets-v6\"\n }\n }\n },\n \"sprite\": {\n \"type\": \"string\",\n \"doc\": \"A base URL for retrieving the sprite image and metadata. The extensions `.png`, `.json` and scale factor `@2x.png` will be automatically appended. This property is required if any layer uses the `background-pattern`, `fill-pattern`, `line-pattern`, `fill-extrusion-pattern`, or `icon-image` properties. The URL must be absolute, containing the [scheme, authority and path components](https://en.wikipedia.org/wiki/URL#Syntax).\",\n \"example\": \"mapbox://sprites/mapbox/bright-v8\"\n },\n \"glyphs\": {\n \"type\": \"string\",\n \"doc\": \"A URL template for loading signed-distance-field glyph sets in PBF format. The URL must include `{fontstack}` and `{range}` tokens. This property is required if any layer uses the `text-field` layout property. The URL must be absolute, containing the [scheme, authority and path components](https://en.wikipedia.org/wiki/URL#Syntax).\",\n \"example\": \"mapbox://fonts/mapbox/{fontstack}/{range}.pbf\"\n },\n \"transition\": {\n \"type\": \"transition\",\n \"doc\": \"A global transition definition to use as a default across properties, to be used for timing transitions between one value and the next when no property-specific transition is set. Collision-based symbol fading is controlled independently of the style's `transition` property.\",\n \"example\": {\n \"duration\": 300,\n \"delay\": 0\n }\n },\n \"projection\": {\n \"type\": \"projection\",\n \"doc\": \"The projection the map should be rendered in. Supported projections are Mercator, Globe, Albers, Equal Earth, Equirectangular (WGS84), Lambert conformal conic, Natural Earth, and Winkel Tripel. Terrain, sky and fog are supported by only Mercator and globe. CustomLayerInterface is not supported outside of Mercator.\",\n \"example\": {\n \"name\": \"albers\",\n \"center\": [-154, 50],\n \"parallels\": [55, 65]\n }\n },\n \"layers\": {\n \"required\": true,\n \"type\": \"array\",\n \"value\": \"layer\",\n \"doc\": \"Layers will be drawn in the order of this array.\",\n \"example\": [\n {\n \"id\": \"water\",\n \"source\": \"mapbox-streets\",\n \"source-layer\": \"water\",\n \"type\": \"fill\",\n \"paint\": {\n \"fill-color\": \"#00ffff\"\n }\n }\n ]\n }\n },\n \"sources\": {\n \"*\": {\n \"type\": \"source\",\n \"doc\": \"Specification of a data source. For vector and raster sources, either TileJSON or a URL to a TileJSON must be provided. For image and video sources, a URL must be provided. For GeoJSON sources, a URL or inline GeoJSON must be provided.\"\n }\n },\n \"source\": [\n \"source_vector\",\n \"source_raster\",\n \"source_raster_dem\",\n \"source_geojson\",\n \"source_video\",\n \"source_image\"\n ],\n \"source_vector\": {\n \"type\": {\n \"required\": true,\n \"type\": \"enum\",\n \"values\": {\n \"vector\": {\n \"doc\": \"A vector tile source.\"\n }\n },\n \"doc\": \"The type of the source.\"\n },\n \"url\": {\n \"type\": \"string\",\n \"doc\": \"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://`.\"\n },\n \"tiles\": {\n \"type\": \"array\",\n \"value\": \"string\",\n \"doc\": \"An array of one or more tile source URLs, as in the TileJSON spec.\"\n },\n \"bounds\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 4,\n \"default\": [\n -180,\n -85.051129,\n 180,\n 85.051129\n ],\n \"doc\": \"An array containing the longitude and latitude of the southwest and northeast corners of the source's bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL.\"\n },\n \"scheme\": {\n \"type\": \"enum\",\n \"values\": {\n \"xyz\": {\n \"doc\": \"Slippy map tilenames scheme.\"\n },\n \"tms\": {\n \"doc\": \"OSGeo spec scheme.\"\n }\n },\n \"default\": \"xyz\",\n \"doc\": \"Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed.\"\n },\n \"minzoom\": {\n \"type\": \"number\",\n \"default\": 0,\n \"doc\": \"Minimum zoom level for which tiles are available, as in the TileJSON spec.\"\n },\n \"maxzoom\": {\n \"type\": \"number\",\n \"default\": 22,\n \"doc\": \"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels.\"\n },\n \"attribution\": {\n \"type\": \"string\",\n \"doc\": \"Contains an attribution to be displayed when the map is shown to a user.\"\n },\n \"promoteId\": {\n \"type\": \"promoteId\",\n \"doc\": \"A property to use as a feature id (for feature state). Either a property name, or an object of the form `{: }`. If specified as a string for a vector tile source, the same property is used across all its source layers. If specified as an object only specified source layers will have id overriden, others will fallback to original feature id\"\n },\n \"volatile\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"A setting to determine whether a source's tiles are cached locally.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"android\": \"9.3.0\",\n \"ios\": \"5.10.0\"\n }\n }\n },\n \"*\": {\n \"type\": \"*\",\n \"doc\": \"Other keys to configure the data source.\"\n }\n },\n \"source_raster\": {\n \"type\": {\n \"required\": true,\n \"type\": \"enum\",\n \"values\": {\n \"raster\": {\n \"doc\": \"A raster tile source.\"\n }\n },\n \"doc\": \"The type of the source.\"\n },\n \"url\": {\n \"type\": \"string\",\n \"doc\": \"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://`.\"\n },\n \"tiles\": {\n \"type\": \"array\",\n \"value\": \"string\",\n \"doc\": \"An array of one or more tile source URLs, as in the TileJSON spec.\"\n },\n \"bounds\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 4,\n \"default\": [\n -180,\n -85.051129,\n 180,\n 85.051129\n ],\n \"doc\": \"An array containing the longitude and latitude of the southwest and northeast corners of the source's bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL.\"\n },\n \"minzoom\": {\n \"type\": \"number\",\n \"default\": 0,\n \"doc\": \"Minimum zoom level for which tiles are available, as in the TileJSON spec.\"\n },\n \"maxzoom\": {\n \"type\": \"number\",\n \"default\": 22,\n \"doc\": \"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels.\"\n },\n \"tileSize\": {\n \"type\": \"number\",\n \"default\": 512,\n \"units\": \"pixels\",\n \"doc\": \"The minimum visual size to display tiles for this layer. Only configurable for raster layers.\"\n },\n \"scheme\": {\n \"type\": \"enum\",\n \"values\": {\n \"xyz\": {\n \"doc\": \"Slippy map tilenames scheme.\"\n },\n \"tms\": {\n \"doc\": \"OSGeo spec scheme.\"\n }\n },\n \"default\": \"xyz\",\n \"doc\": \"Influences the y direction of the tile coordinates. The global-mercator (aka Spherical Mercator) profile is assumed.\"\n },\n \"attribution\": {\n \"type\": \"string\",\n \"doc\": \"Contains an attribution to be displayed when the map is shown to a user.\"\n },\n \"volatile\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"A setting to determine whether a source's tiles are cached locally.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"android\": \"9.3.0\",\n \"ios\": \"5.10.0\"\n }\n }\n },\n \"*\": {\n \"type\": \"*\",\n \"doc\": \"Other keys to configure the data source.\"\n }\n },\n \"source_raster_dem\": {\n \"type\": {\n \"required\": true,\n \"type\": \"enum\",\n \"values\": {\n \"raster-dem\": {\n \"doc\": \"A RGB-encoded raster DEM source\"\n }\n },\n \"doc\": \"The type of the source.\"\n },\n \"url\": {\n \"type\": \"string\",\n \"doc\": \"A URL to a TileJSON resource. Supported protocols are `http:`, `https:`, and `mapbox://`.\"\n },\n \"tiles\": {\n \"type\": \"array\",\n \"value\": \"string\",\n \"doc\": \"An array of one or more tile source URLs, as in the TileJSON spec.\"\n },\n \"bounds\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 4,\n \"default\": [\n -180,\n -85.051129,\n 180,\n 85.051129\n ],\n \"doc\": \"An array containing the longitude and latitude of the southwest and northeast corners of the source's bounding box in the following order: `[sw.lng, sw.lat, ne.lng, ne.lat]`. When this property is included in a source, no tiles outside of the given bounds are requested by Mapbox GL.\"\n },\n \"minzoom\": {\n \"type\": \"number\",\n \"default\": 0,\n \"doc\": \"Minimum zoom level for which tiles are available, as in the TileJSON spec.\"\n },\n \"maxzoom\": {\n \"type\": \"number\",\n \"default\": 22,\n \"doc\": \"Maximum zoom level for which tiles are available, as in the TileJSON spec. Data from tiles at the maxzoom are used when displaying the map at higher zoom levels.\"\n },\n \"tileSize\": {\n \"type\": \"number\",\n \"default\": 512,\n \"units\": \"pixels\",\n \"doc\": \"The minimum visual size to display tiles for this layer. Only configurable for raster layers.\"\n },\n \"attribution\": {\n \"type\": \"string\",\n \"doc\": \"Contains an attribution to be displayed when the map is shown to a user.\"\n },\n \"encoding\": {\n \"type\": \"enum\",\n \"values\": {\n \"terrarium\": {\n \"doc\": \"Terrarium format PNG tiles. See https://aws.amazon.com/es/public-datasets/terrain/ for more info.\"\n },\n \"mapbox\": {\n \"doc\": \"Mapbox Terrain RGB tiles. See https://www.mapbox.com/help/access-elevation-data/#mapbox-terrain-rgb for more info.\"\n }\n },\n \"default\": \"mapbox\",\n \"doc\": \"The encoding used by this source. Mapbox Terrain RGB is used by default\"\n },\n \"volatile\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"A setting to determine whether a source's tiles are cached locally.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"android\": \"9.3.0\",\n \"ios\": \"5.10.0\"\n }\n }\n },\n \"*\": {\n \"type\": \"*\",\n \"doc\": \"Other keys to configure the data source.\"\n }\n },\n \"source_geojson\": {\n \"type\": {\n \"required\": true,\n \"type\": \"enum\",\n \"values\": {\n \"geojson\": {\n \"doc\": \"A GeoJSON data source.\"\n }\n },\n \"doc\": \"The data type of the GeoJSON source.\"\n },\n \"data\": {\n \"type\": \"*\",\n \"doc\": \"A URL to a GeoJSON file, or inline GeoJSON.\"\n },\n \"maxzoom\": {\n \"type\": \"number\",\n \"default\": 18,\n \"doc\": \"Maximum zoom level at which to create vector tiles (higher means greater detail at high zoom levels).\"\n },\n \"attribution\": {\n \"type\": \"string\",\n \"doc\": \"Contains an attribution to be displayed when the map is shown to a user.\"\n },\n \"buffer\": {\n \"type\": \"number\",\n \"default\": 128,\n \"maximum\": 512,\n \"minimum\": 0,\n \"doc\": \"Size of the tile buffer on each side. A value of 0 produces no buffer. A value of 512 produces a buffer as wide as the tile itself. Larger values produce fewer rendering artifacts near tile edges and slower performance.\"\n },\n \"filter\": {\n \"type\": \"*\",\n \"doc\": \"An expression for filtering features prior to processing them for rendering.\"\n },\n \"tolerance\": {\n \"type\": \"number\",\n \"default\": 0.375,\n \"doc\": \"Douglas-Peucker simplification tolerance (higher means simpler geometries and faster performance).\"\n },\n \"cluster\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If the data is a collection of point features, setting this to true clusters the points by radius into groups. Cluster groups become new `Point` features in the source with additional properties:\\n * `cluster` Is `true` if the point is a cluster \\n * `cluster_id` A unqiue id for the cluster to be used in conjunction with the [cluster inspection methods](https://www.mapbox.com/mapbox-gl-js/api/#geojsonsource#getclusterexpansionzoom)\\n * `point_count` Number of original points grouped into this cluster\\n * `point_count_abbreviated` An abbreviated point count\"\n },\n \"clusterRadius\": {\n \"type\": \"number\",\n \"default\": 50,\n \"minimum\": 0,\n \"doc\": \"Radius of each cluster if clustering is enabled. A value of 512 indicates a radius equal to the width of a tile.\"\n },\n \"clusterMaxZoom\": {\n \"type\": \"number\",\n \"doc\": \"Max zoom on which to cluster points if clustering is enabled. Defaults to one zoom less than maxzoom (so that last zoom features are not clustered). Clusters are re-evaluated at integer zoom levels so setting clusterMaxZoom to 14 means the clusters will be displayed until z15.\"\n },\n \"clusterMinPoints\": {\n \"type\": \"number\",\n \"doc\": \"Minimum number of points necessary to form a cluster if clustering is enabled. Defaults to `2`.\"\n },\n \"clusterProperties\": {\n \"type\": \"*\",\n \"doc\": \"An object defining custom properties on the generated clusters if clustering is enabled, aggregating values from clustered points. Has the form `{\\\"property_name\\\": [operator, map_expression]}`. `operator` is any expression function that accepts at least 2 operands (e.g. `\\\"+\\\"` or `\\\"max\\\"`) — it accumulates the property value from clusters/points the cluster contains; `map_expression` produces the value of a single point.\\n\\nExample: `{\\\"sum\\\": [\\\"+\\\", [\\\"get\\\", \\\"scalerank\\\"]]}`.\\n\\nFor more advanced use cases, in place of `operator`, you can use a custom reduce expression that references a special `[\\\"accumulated\\\"]` value, e.g.:\\n`{\\\"sum\\\": [[\\\"+\\\", [\\\"accumulated\\\"], [\\\"get\\\", \\\"sum\\\"]], [\\\"get\\\", \\\"scalerank\\\"]]}`\"\n },\n \"lineMetrics\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"Whether to calculate line distance metrics. This is required for line layers that specify `line-gradient` values.\"\n },\n \"generateId\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"Whether to generate ids for the geojson features. When enabled, the `feature.id` property will be auto assigned based on its index in the `features` array, over-writing any previous values.\"\n },\n \"promoteId\": {\n \"type\": \"promoteId\",\n \"doc\": \"A property to use as a feature id (for feature state). Either a property name, or an object of the form `{: }`.\"\n }\n },\n \"source_video\": {\n \"type\": {\n \"required\": true,\n \"type\": \"enum\",\n \"values\": {\n \"video\": {\n \"doc\": \"A video data source.\"\n }\n },\n \"doc\": \"The data type of the video source.\"\n },\n \"urls\": {\n \"required\": true,\n \"type\": \"array\",\n \"value\": \"string\",\n \"doc\": \"URLs to video content in order of preferred format.\"\n },\n \"coordinates\": {\n \"required\": true,\n \"doc\": \"Corners of video specified in longitude, latitude pairs.\",\n \"type\": \"array\",\n \"length\": 4,\n \"value\": {\n \"type\": \"array\",\n \"length\": 2,\n \"value\": \"number\",\n \"doc\": \"A single longitude, latitude pair.\"\n }\n }\n },\n \"source_image\": {\n \"type\": {\n \"required\": true,\n \"type\": \"enum\",\n \"values\": {\n \"image\": {\n \"doc\": \"An image data source.\"\n }\n },\n \"doc\": \"The data type of the image source.\"\n },\n \"url\": {\n \"required\": true,\n \"type\": \"string\",\n \"doc\": \"URL that points to an image.\"\n },\n \"coordinates\": {\n \"required\": true,\n \"doc\": \"Corners of image specified in longitude, latitude pairs.\",\n \"type\": \"array\",\n \"length\": 4,\n \"value\": {\n \"type\": \"array\",\n \"length\": 2,\n \"value\": \"number\",\n \"doc\": \"A single longitude, latitude pair.\"\n }\n }\n },\n \"layer\": {\n \"id\": {\n \"type\": \"string\",\n \"doc\": \"Unique layer name.\",\n \"required\": true\n },\n \"type\": {\n \"type\": \"enum\",\n \"values\": {\n \"fill\": {\n \"doc\": \"A filled polygon with an optional stroked border.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n }\n },\n \"line\": {\n \"doc\": \"A stroked line.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n }\n },\n \"symbol\": {\n \"doc\": \"An icon or a text label.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n }\n },\n \"circle\": {\n \"doc\": \"A filled circle.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n }\n },\n \"heatmap\": {\n \"doc\": \"A heatmap.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"fill-extrusion\": {\n \"doc\": \"An extruded (3D) polygon.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n }\n },\n \"raster\": {\n \"doc\": \"Raster map textures such as satellite imagery.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n }\n },\n \"hillshade\": {\n \"doc\": \"Client-side hillshading visualization based on DEM data. Currently, the implementation only supports Mapbox Terrain RGB and Mapzen Terrarium tiles.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"background\": {\n \"doc\": \"The background color or pattern of the map.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n }\n },\n \"sky\": {\n \"doc\": \"A spherical dome around the map that is always rendered behind all other layers.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n }\n }\n },\n \"doc\": \"Rendering type of this layer.\",\n \"required\": true\n },\n \"metadata\": {\n \"type\": \"*\",\n \"doc\": \"Arbitrary properties useful to track with the layer, but do not influence rendering. Properties should be prefixed to avoid collisions, like 'mapbox:'.\"\n },\n \"source\": {\n \"type\": \"string\",\n \"doc\": \"Name of a source description to be used for this layer. Required for all layer types except `background`.\"\n },\n \"source-layer\": {\n \"type\": \"string\",\n \"doc\": \"Layer to use from a vector tile source. Required for vector tile sources; prohibited for all other source types, including GeoJSON sources.\"\n },\n \"minzoom\": {\n \"type\": \"number\",\n \"minimum\": 0,\n \"maximum\": 24,\n \"doc\": \"The minimum zoom level for the layer. At zoom levels less than the minzoom, the layer will be hidden.\"\n },\n \"maxzoom\": {\n \"type\": \"number\",\n \"minimum\": 0,\n \"maximum\": 24,\n \"doc\": \"The maximum zoom level for the layer. At zoom levels equal to or greater than the maxzoom, the layer will be hidden.\"\n },\n \"filter\": {\n \"type\": \"filter\",\n \"doc\": \"An expression specifying conditions on source features. Only features that match the filter are displayed. Zoom expressions in filters are only evaluated at integer zoom levels. The `[\\\"feature-state\\\", ...]` expression is not supported in filter expressions. The `[\\\"pitch\\\"]` and `[\\\"distance-from-center\\\"]` expressions are supported only for filter expressions on the symbol layer.\"\n },\n \"layout\": {\n \"type\": \"layout\",\n \"doc\": \"Layout properties for the layer.\"\n },\n \"paint\": {\n \"type\": \"paint\",\n \"doc\": \"Default paint properties for this layer.\"\n }\n },\n \"layout\": [\n \"layout_fill\",\n \"layout_line\",\n \"layout_circle\",\n \"layout_heatmap\",\n \"layout_fill-extrusion\",\n \"layout_symbol\",\n \"layout_raster\",\n \"layout_hillshade\",\n \"layout_background\",\n \"layout_sky\"\n ],\n \"layout_background\": {\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_sky\": {\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_fill\": {\n \"fill-sort-key\": {\n \"type\": \"number\",\n \"doc\": \"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.2.0\",\n \"android\": \"9.1.0\",\n \"ios\": \"5.8.0\",\n \"macos\": \"0.15.0\"\n },\n \"data-driven styling\": {\n \"js\": \"1.2.0\",\n \"android\": \"9.1.0\",\n \"ios\": \"5.8.0\",\n \"macos\": \"0.15.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_circle\": {\n \"circle-sort-key\": {\n \"type\": \"number\",\n \"doc\": \"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.2.0\",\n \"android\": \"9.2.0\",\n \"ios\": \"5.9.0\",\n \"macos\": \"0.16.0\"\n },\n \"data-driven styling\": {\n \"js\": \"1.2.0\",\n \"android\": \"9.2.0\",\n \"ios\": \"5.9.0\",\n \"macos\": \"0.16.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_heatmap\": {\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_fill-extrusion\": {\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"property-type\": \"constant\"\n },\n \"fill-extrusion-edge-radius\": {\n \"type\": \"number\",\n \"private\": true,\n \"default\": 0,\n \"minimum\": 0,\n \"maximum\": 1,\n \"doc\": \"Radius of a fill extrusion edge in meters. If not zero, rounds extrusion edges for a smoother appearance.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"v2.10.0\",\n \"android\": \"10.7.0\",\n \"ios\": \"10.7.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_line\": {\n \"line-cap\": {\n \"type\": \"enum\",\n \"values\": {\n \"butt\": {\n \"doc\": \"A cap with a squared-off end which is drawn to the exact endpoint of the line.\"\n },\n \"round\": {\n \"doc\": \"A cap with a rounded end which is drawn beyond the endpoint of the line at a radius of one-half of the line's width and centered on the endpoint of the line.\"\n },\n \"square\": {\n \"doc\": \"A cap with a squared-off end which is drawn beyond the endpoint of the line at a distance of one-half of the line's width.\"\n }\n },\n \"default\": \"butt\",\n \"doc\": \"The display of line endings.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"2.3.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-join\": {\n \"type\": \"enum\",\n \"values\": {\n \"bevel\": {\n \"doc\": \"A join with a squared-off end which is drawn beyond the endpoint of the line at a distance of one-half of the line's width.\"\n },\n \"round\": {\n \"doc\": \"A join with a rounded end which is drawn beyond the endpoint of the line at a radius of one-half of the line's width and centered on the endpoint of the line.\"\n },\n \"miter\": {\n \"doc\": \"A join with a sharp, angled corner which is drawn with the outer sides beyond the endpoint of the path until they meet.\"\n }\n },\n \"default\": \"miter\",\n \"doc\": \"The display of lines when joining.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.40.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-miter-limit\": {\n \"type\": \"number\",\n \"default\": 2,\n \"doc\": \"Used to automatically convert miter joins to bevel joins for sharp angles.\",\n \"requires\": [\n {\n \"line-join\": \"miter\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"line-round-limit\": {\n \"type\": \"number\",\n \"default\": 1.05,\n \"doc\": \"Used to automatically convert round joins to miter joins for shallow angles.\",\n \"requires\": [\n {\n \"line-join\": \"round\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"line-sort-key\": {\n \"type\": \"number\",\n \"doc\": \"Sorts features in ascending order based on this value. Features with a higher sort key will appear above features with a lower sort key.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.2.0\",\n \"android\": \"9.1.0\",\n \"ios\": \"5.8.0\",\n \"macos\": \"0.15.0\"\n },\n \"data-driven styling\": {\n \"js\": \"1.2.0\",\n \"android\": \"9.1.0\",\n \"ios\": \"5.8.0\",\n \"macos\": \"0.15.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_symbol\": {\n \"symbol-placement\": {\n \"type\": \"enum\",\n \"values\": {\n \"point\": {\n \"doc\": \"The label is placed at the point where the geometry is located.\"\n },\n \"line\": {\n \"doc\": \"The label is placed along the line of the geometry. Can only be used on `LineString` and `Polygon` geometries.\"\n },\n \"line-center\": {\n \"doc\": \"The label is placed at the center of the line of the geometry. Can only be used on `LineString` and `Polygon` geometries. Note that a single feature in a vector tile may contain multiple line geometries.\"\n }\n },\n \"default\": \"point\",\n \"doc\": \"Label placement relative to its geometry.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"`line-center` value\": {\n \"js\": \"0.47.0\",\n \"android\": \"6.4.0\",\n \"ios\": \"4.3.0\",\n \"macos\": \"0.10.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"symbol-spacing\": {\n \"type\": \"number\",\n \"default\": 250,\n \"minimum\": 1,\n \"units\": \"pixels\",\n \"doc\": \"Distance between two symbol anchors.\",\n \"requires\": [\n {\n \"symbol-placement\": \"line\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"symbol-avoid-edges\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, the symbols will not cross tile edges to avoid mutual collisions. Recommended in layers that don't have enough padding in the vector tile to prevent collisions, or if it is a point symbol layer placed after a line symbol layer. When using a client that supports global collision detection, like Mapbox GL JS version 0.42.0 or greater, enabling this property is not needed to prevent clipped labels at tile boundaries.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"symbol-sort-key\": {\n \"type\": \"number\",\n \"doc\": \"Sorts features in ascending order based on this value. Features with lower sort keys are drawn and placed first. When `icon-allow-overlap` or `text-allow-overlap` is `false`, features with a lower sort key will have priority during placement. When `icon-allow-overlap` or `text-allow-overlap` is set to `true`, features with a higher sort key will overlap over features with a lower sort key.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.53.0\",\n \"android\": \"7.4.0\",\n \"ios\": \"4.11.0\",\n \"macos\": \"0.14.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.53.0\",\n \"android\": \"7.4.0\",\n \"ios\": \"4.11.0\",\n \"macos\": \"0.14.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"symbol-z-order\": {\n \"type\": \"enum\",\n \"values\": {\n \"auto\": {\n \"doc\": \"Sorts symbols by `symbol-sort-key` if set. Otherwise, sorts symbols by their y-position relative to the viewport if `icon-allow-overlap` or `text-allow-overlap` is set to `true` or `icon-ignore-placement` or `text-ignore-placement` is `false`.\"\n },\n \"viewport-y\": {\n \"doc\": \"Sorts symbols by their y-position relative to the viewport if `icon-allow-overlap` or `text-allow-overlap` is set to `true` or `icon-ignore-placement` or `text-ignore-placement` is `false`.\"\n },\n \"source\": {\n \"doc\": \"Sorts symbols by `symbol-sort-key` if set. Otherwise, no sorting is applied; symbols are rendered in the same order as the source data.\"\n }\n },\n \"default\": \"auto\",\n \"doc\": \"Determines whether overlapping symbols in the same layer are rendered in the order that they appear in the data source or by their y-position relative to the viewport. To control the order and prioritization of symbols otherwise, use `symbol-sort-key`.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.49.0\",\n \"android\": \"6.6.0\",\n \"ios\": \"4.5.0\",\n \"macos\": \"0.12.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-allow-overlap\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, the icon will be visible even if it collides with other previously drawn symbols.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-ignore-placement\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, other symbols can be visible even if they collide with the icon.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-optional\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, text will display without their corresponding icons when the icon collides with other symbols and the text does not.\",\n \"requires\": [\n \"icon-image\",\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-rotation-alignment\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"When `symbol-placement` is set to `point`, aligns icons east-west. When `symbol-placement` is set to `line` or `line-center`, aligns icon x-axes with the line.\"\n },\n \"viewport\": {\n \"doc\": \"Produces icons whose x-axes are aligned with the x-axis of the viewport, regardless of the value of `symbol-placement`.\"\n },\n \"auto\": {\n \"doc\": \"When `symbol-placement` is set to `point`, this is equivalent to `viewport`. When `symbol-placement` is set to `line` or `line-center`, this is equivalent to `map`.\"\n }\n },\n \"default\": \"auto\",\n \"doc\": \"In combination with `symbol-placement`, determines the rotation behavior of icons.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"`auto` value\": {\n \"js\": \"0.25.0\",\n \"android\": \"4.2.0\",\n \"ios\": \"3.4.0\",\n \"macos\": \"0.3.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-size\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"units\": \"factor of the original icon size\",\n \"doc\": \"Scales the original size of the icon by the provided factor. The new pixel size of the image will be the original pixel size multiplied by `icon-size`. 1 is the original size; 3 triples the size of the image.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.35.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-text-fit\": {\n \"type\": \"enum\",\n \"values\": {\n \"none\": {\n \"doc\": \"The icon is displayed at its intrinsic aspect ratio.\"\n },\n \"width\": {\n \"doc\": \"The icon is scaled in the x-dimension to fit the width of the text.\"\n },\n \"height\": {\n \"doc\": \"The icon is scaled in the y-dimension to fit the height of the text.\"\n },\n \"both\": {\n \"doc\": \"The icon is scaled in both x- and y-dimensions.\"\n }\n },\n \"default\": \"none\",\n \"doc\": \"Scales the icon to fit around the associated text.\",\n \"requires\": [\n \"icon-image\",\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.21.0\",\n \"android\": \"4.2.0\",\n \"ios\": \"3.4.0\",\n \"macos\": \"0.2.1\"\n },\n \"stretchable icons\": {\n \"js\": \"1.6.0\",\n \"android\": \"9.2.0\",\n \"ios\": \"5.8.0\",\n \"macos\": \"0.15.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-text-fit-padding\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 4,\n \"default\": [\n 0,\n 0,\n 0,\n 0\n ],\n \"units\": \"pixels\",\n \"doc\": \"Size of the additional area added to dimensions determined by `icon-text-fit`, in clockwise order: top, right, bottom, left.\",\n \"requires\": [\n \"icon-image\",\n \"text-field\",\n {\n \"icon-text-fit\": [\n \"both\",\n \"width\",\n \"height\"\n ]\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.21.0\",\n \"android\": \"4.2.0\",\n \"ios\": \"3.4.0\",\n \"macos\": \"0.2.1\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-image\": {\n \"type\": \"resolvedImage\",\n \"doc\": \"Name of image in sprite to use for drawing an image background.\",\n \"tokens\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.35.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-rotate\": {\n \"type\": \"number\",\n \"default\": 0,\n \"period\": 360,\n \"units\": \"degrees\",\n \"doc\": \"Rotates the icon clockwise.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.21.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-padding\": {\n \"type\": \"number\",\n \"default\": 2,\n \"minimum\": 0,\n \"units\": \"pixels\",\n \"doc\": \"Size of the additional area around the icon bounding box used for detecting symbol collisions.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-keep-upright\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, the icon may be flipped to prevent it from being rendered upside-down.\",\n \"requires\": [\n \"icon-image\",\n {\n \"icon-rotation-alignment\": \"map\"\n },\n {\n \"symbol-placement\": [\n \"line\",\n \"line-center\"\n ]\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-offset\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"doc\": \"Offset distance of icon from its anchor. Positive values indicate right and down, while negative values indicate left and up. Each component is multiplied by the value of `icon-size` to obtain the final offset in pixels. When combined with `icon-rotate` the offset will be as if the rotated direction was up.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"center\": {\n \"doc\": \"The center of the icon is placed closest to the anchor.\"\n },\n \"left\": {\n \"doc\": \"The left side of the icon is placed closest to the anchor.\"\n },\n \"right\": {\n \"doc\": \"The right side of the icon is placed closest to the anchor.\"\n },\n \"top\": {\n \"doc\": \"The top of the icon is placed closest to the anchor.\"\n },\n \"bottom\": {\n \"doc\": \"The bottom of the icon is placed closest to the anchor.\"\n },\n \"top-left\": {\n \"doc\": \"The top left corner of the icon is placed closest to the anchor.\"\n },\n \"top-right\": {\n \"doc\": \"The top right corner of the icon is placed closest to the anchor.\"\n },\n \"bottom-left\": {\n \"doc\": \"The bottom left corner of the icon is placed closest to the anchor.\"\n },\n \"bottom-right\": {\n \"doc\": \"The bottom right corner of the icon is placed closest to the anchor.\"\n }\n },\n \"default\": \"center\",\n \"doc\": \"Part of the icon placed closest to the anchor.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.40.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.40.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-pitch-alignment\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The icon is aligned to the plane of the map.\"\n },\n \"viewport\": {\n \"doc\": \"The icon is aligned to the plane of the viewport.\"\n },\n \"auto\": {\n \"doc\": \"Automatically matches the value of `icon-rotation-alignment`.\"\n }\n },\n \"default\": \"auto\",\n \"doc\": \"Orientation of icon when map is pitched.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.39.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-pitch-alignment\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The text is aligned to the plane of the map.\"\n },\n \"viewport\": {\n \"doc\": \"The text is aligned to the plane of the viewport.\"\n },\n \"auto\": {\n \"doc\": \"Automatically matches the value of `text-rotation-alignment`.\"\n }\n },\n \"default\": \"auto\",\n \"doc\": \"Orientation of text when map is pitched.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.21.0\",\n \"android\": \"4.2.0\",\n \"ios\": \"3.4.0\",\n \"macos\": \"0.2.1\"\n },\n \"`auto` value\": {\n \"js\": \"0.25.0\",\n \"android\": \"4.2.0\",\n \"ios\": \"3.4.0\",\n \"macos\": \"0.3.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-rotation-alignment\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"When `symbol-placement` is set to `point`, aligns text east-west. When `symbol-placement` is set to `line` or `line-center`, aligns text x-axes with the line.\"\n },\n \"viewport\": {\n \"doc\": \"Produces glyphs whose x-axes are aligned with the x-axis of the viewport, regardless of the value of `symbol-placement`.\"\n },\n \"auto\": {\n \"doc\": \"When `symbol-placement` is set to `point`, this is equivalent to `viewport`. When `symbol-placement` is set to `line` or `line-center`, this is equivalent to `map`.\"\n }\n },\n \"default\": \"auto\",\n \"doc\": \"In combination with `symbol-placement`, determines the rotation behavior of the individual glyphs forming the text.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"`auto` value\": {\n \"js\": \"0.25.0\",\n \"android\": \"4.2.0\",\n \"ios\": \"3.4.0\",\n \"macos\": \"0.3.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-field\": {\n \"type\": \"formatted\",\n \"default\": \"\",\n \"tokens\": true,\n \"doc\": \"Value to use for a text label. If a plain `string` is provided, it will be treated as a `formatted` with default/inherited formatting options. SDF images are not supported in formatted text and will be ignored.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-font\": {\n \"type\": \"array\",\n \"value\": \"string\",\n \"default\": [\n \"Open Sans Regular\",\n \"Arial Unicode MS Regular\"\n ],\n \"doc\": \"Font stack to use for displaying text.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-size\": {\n \"type\": \"number\",\n \"default\": 16,\n \"minimum\": 0,\n \"units\": \"pixels\",\n \"doc\": \"Font size.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.35.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-max-width\": {\n \"type\": \"number\",\n \"default\": 10,\n \"minimum\": 0,\n \"units\": \"ems\",\n \"doc\": \"The maximum line width for text wrapping.\",\n \"requires\": [\n \"text-field\",\n {\n \"symbol-placement\": [\n \"point\"\n ]\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.40.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-line-height\": {\n \"type\": \"number\",\n \"default\": 1.2,\n \"units\": \"ems\",\n \"doc\": \"Text leading value for multi-line text.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"2.3.0\",\n \"android\": \"10.0.0\",\n \"ios\": \"10.0.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-letter-spacing\": {\n \"type\": \"number\",\n \"default\": 0,\n \"units\": \"ems\",\n \"doc\": \"Text tracking amount.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.40.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-justify\": {\n \"type\": \"enum\",\n \"values\": {\n \"auto\": {\n \"doc\": \"The text is aligned towards the anchor position.\"\n },\n \"left\": {\n \"doc\": \"The text is aligned to the left.\"\n },\n \"center\": {\n \"doc\": \"The text is centered.\"\n },\n \"right\": {\n \"doc\": \"The text is aligned to the right.\"\n }\n },\n \"default\": \"center\",\n \"doc\": \"Text justification options.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.39.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n },\n \"auto\": {\n \"js\": \"0.54.0\",\n \"android\": \"7.4.0\",\n \"ios\": \"4.10.0\",\n \"macos\": \"0.14.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-radial-offset\": {\n \"type\": \"number\",\n \"units\": \"ems\",\n \"default\": 0,\n \"doc\": \"Radial offset of text, in the direction of the symbol's anchor. Useful in combination with `text-variable-anchor`, which defaults to using the two-dimensional `text-offset` if present.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.54.0\",\n \"android\": \"7.4.0\",\n \"ios\": \"4.10.0\",\n \"macos\": \"0.14.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.54.0\",\n \"android\": \"7.4.0\",\n \"ios\": \"4.10.0\",\n \"macos\": \"0.14.0\"\n }\n },\n \"requires\": [\n \"text-field\"\n ],\n \"property-type\": \"data-driven\",\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n }\n },\n \"text-variable-anchor\": {\n \"type\": \"array\",\n \"value\": \"enum\",\n \"values\": {\n \"center\": {\n \"doc\": \"The center of the text is placed closest to the anchor.\"\n },\n \"left\": {\n \"doc\": \"The left side of the text is placed closest to the anchor.\"\n },\n \"right\": {\n \"doc\": \"The right side of the text is placed closest to the anchor.\"\n },\n \"top\": {\n \"doc\": \"The top of the text is placed closest to the anchor.\"\n },\n \"bottom\": {\n \"doc\": \"The bottom of the text is placed closest to the anchor.\"\n },\n \"top-left\": {\n \"doc\": \"The top left corner of the text is placed closest to the anchor.\"\n },\n \"top-right\": {\n \"doc\": \"The top right corner of the text is placed closest to the anchor.\"\n },\n \"bottom-left\": {\n \"doc\": \"The bottom left corner of the text is placed closest to the anchor.\"\n },\n \"bottom-right\": {\n \"doc\": \"The bottom right corner of the text is placed closest to the anchor.\"\n }\n },\n \"requires\": [\n \"text-field\",\n {\n \"symbol-placement\": [\n \"point\"\n ]\n }\n ],\n \"doc\": \"To increase the chance of placing high-priority labels on the map, you can provide an array of `text-anchor` locations: the renderer will attempt to place the label at each location, in order, before moving onto the next label. Use `text-justify: auto` to choose justification based on anchor position. To apply an offset, use the `text-radial-offset` or the two-dimensional `text-offset`.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.54.0\",\n \"android\": \"7.4.0\",\n \"ios\": \"4.10.0\",\n \"macos\": \"0.14.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"center\": {\n \"doc\": \"The center of the text is placed closest to the anchor.\"\n },\n \"left\": {\n \"doc\": \"The left side of the text is placed closest to the anchor.\"\n },\n \"right\": {\n \"doc\": \"The right side of the text is placed closest to the anchor.\"\n },\n \"top\": {\n \"doc\": \"The top of the text is placed closest to the anchor.\"\n },\n \"bottom\": {\n \"doc\": \"The bottom of the text is placed closest to the anchor.\"\n },\n \"top-left\": {\n \"doc\": \"The top left corner of the text is placed closest to the anchor.\"\n },\n \"top-right\": {\n \"doc\": \"The top right corner of the text is placed closest to the anchor.\"\n },\n \"bottom-left\": {\n \"doc\": \"The bottom left corner of the text is placed closest to the anchor.\"\n },\n \"bottom-right\": {\n \"doc\": \"The bottom right corner of the text is placed closest to the anchor.\"\n }\n },\n \"default\": \"center\",\n \"doc\": \"Part of the text placed closest to the anchor.\",\n \"requires\": [\n \"text-field\",\n {\n \"!\": \"text-variable-anchor\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.39.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-max-angle\": {\n \"type\": \"number\",\n \"default\": 45,\n \"units\": \"degrees\",\n \"doc\": \"Maximum angle change between adjacent characters.\",\n \"requires\": [\n \"text-field\",\n {\n \"symbol-placement\": [\n \"line\",\n \"line-center\"\n ]\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-writing-mode\": {\n \"type\": \"array\",\n \"value\": \"enum\",\n \"values\": {\n \"horizontal\": {\n \"doc\": \"If a text's language supports horizontal writing mode, symbols would be laid out horizontally.\"\n },\n \"vertical\": {\n \"doc\": \"If a text's language supports vertical writing mode, symbols would be laid out vertically.\"\n }\n },\n \"doc\": \"The property allows control over a symbol's orientation. Note that the property values act as a hint, so that a symbol whose language doesn’t support the provided orientation will be laid out in its natural orientation. Example: English point symbol will be rendered horizontally even if array value contains single 'vertical' enum value. For symbol with point placement, the order of elements in an array define priority order for the placement of an orientation variant. For symbol with line placement, the default text writing mode is either ['horizontal', 'vertical'] or ['vertical', 'horizontal'], the order doesn't affect the placement.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.3.0\",\n \"android\": \"8.3.0\",\n \"ios\": \"5.3.0\",\n \"macos\": \"0.15.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-rotate\": {\n \"type\": \"number\",\n \"default\": 0,\n \"period\": 360,\n \"units\": \"degrees\",\n \"doc\": \"Rotates the text clockwise.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.35.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-padding\": {\n \"type\": \"number\",\n \"default\": 2,\n \"minimum\": 0,\n \"units\": \"pixels\",\n \"doc\": \"Size of the additional area around the text bounding box used for detecting symbol collisions.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-keep-upright\": {\n \"type\": \"boolean\",\n \"default\": true,\n \"doc\": \"If true, the text may be flipped vertically to prevent it from being rendered upside-down.\",\n \"requires\": [\n \"text-field\",\n {\n \"text-rotation-alignment\": \"map\"\n },\n {\n \"symbol-placement\": [\n \"line\",\n \"line-center\"\n ]\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-transform\": {\n \"type\": \"enum\",\n \"values\": {\n \"none\": {\n \"doc\": \"The text is not altered.\"\n },\n \"uppercase\": {\n \"doc\": \"Forces all letters to be displayed in uppercase.\"\n },\n \"lowercase\": {\n \"doc\": \"Forces all letters to be displayed in lowercase.\"\n }\n },\n \"default\": \"none\",\n \"doc\": \"Specifies how to capitalize text, similar to the CSS `text-transform` property.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-offset\": {\n \"type\": \"array\",\n \"doc\": \"Offset distance of text from its anchor. Positive values indicate right and down, while negative values indicate left and up. If used with text-variable-anchor, input values will be taken as absolute values. Offsets along the x- and y-axis will be applied automatically based on the anchor position.\",\n \"value\": \"number\",\n \"units\": \"ems\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"requires\": [\n \"text-field\",\n {\n \"!\": \"text-radial-offset\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.35.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-allow-overlap\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, the text will be visible even if it collides with other previously drawn symbols.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-ignore-placement\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, other symbols can be visible even if they collide with the text.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-optional\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"doc\": \"If true, icons will display without their corresponding text when the text collides with other symbols and the icon does not.\",\n \"requires\": [\n \"text-field\",\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_raster\": {\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"layout_hillshade\": {\n \"visibility\": {\n \"type\": \"enum\",\n \"values\": {\n \"visible\": {\n \"doc\": \"The layer is shown.\"\n },\n \"none\": {\n \"doc\": \"The layer is not shown.\"\n }\n },\n \"default\": \"visible\",\n \"doc\": \"Whether this layer is displayed.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"filter\": {\n \"type\": \"array\",\n \"value\": \"*\",\n \"doc\": \"A filter selects specific features from a layer.\"\n },\n \"filter_symbol\": {\n \"type\": \"boolean\",\n \"doc\": \"Expression which determines whether or not to display a symbol. Symbols support dynamic filtering, meaning this expression can use the `[\\\"pitch\\\"]` and `[\\\"distance-from-center\\\"]` expressions to reference the current state of the view.\",\n \"default\": false,\n \"transition\": false,\n \"property-type\": \"data-driven\",\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\"zoom\", \"feature\", \"pitch\", \"distance-from-center\"]\n }\n },\n \"filter_fill\": {\n \"type\": \"boolean\",\n \"doc\": \"Expression which determines whether or not to display a polygon. Fill layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\\"pitch\\\"]` and `[\\\"distance-from-center\\\"]` expressions to reference the current state of the view.\",\n \"default\": false,\n \"transition\": false,\n \"property-type\": \"data-driven\",\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\"zoom\", \"feature\"]\n }\n },\n \"filter_line\": {\n \"type\": \"boolean\",\n \"doc\": \"Expression which determines whether or not to display a Polygon or LineString. Line layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\\"pitch\\\"]` and `[\\\"distance-from-center\\\"]` expressions to reference the current state of the view.\",\n \"default\": false,\n \"transition\": false,\n \"property-type\": \"data-driven\",\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\"zoom\", \"feature\"]\n }\n },\n \"filter_circle\": {\n \"type\": \"boolean\",\n \"doc\": \"Expression which determines whether or not to display a circle. Circle layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\\"pitch\\\"]` and `[\\\"distance-from-center\\\"]` expressions to reference the current state of the view.\",\n \"default\": false,\n \"transition\": false,\n \"property-type\": \"data-driven\",\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\"zoom\", \"feature\"]\n }\n },\n \"filter_fill-extrusion\": {\n \"type\": \"boolean\",\n \"doc\": \"Expression which determines whether or not to display a Polygon. Fill-extrusion layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\\"pitch\\\"]` and `[\\\"distance-from-center\\\"]` expressions to reference the current state of the view.\",\n \"default\": false,\n \"transition\": false,\n \"property-type\": \"data-driven\",\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\"zoom\", \"feature\"]\n }\n },\n \"filter_heatmap\": {\n \"type\": \"boolean\",\n \"doc\": \"Expression used to determine whether a point is being displayed or not. Heatmap layer does NOT support dynamic filtering, meaning this expression can NOT use the `[\\\"pitch\\\"]` and `[\\\"distance-from-center\\\"]` expressions to reference the current state of the view.\",\n \"default\": false,\n \"transition\": false,\n \"property-type\": \"data-driven\",\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\"zoom\", \"feature\"]\n }\n },\n \"filter_operator\": {\n \"type\": \"enum\",\n \"values\": {\n \"==\": {\n \"doc\": \"`[\\\"==\\\", key, value]` equality: `feature[key] = value`\"\n },\n \"!=\": {\n \"doc\": \"`[\\\"!=\\\", key, value]` inequality: `feature[key] ≠ value`\"\n },\n \">\": {\n \"doc\": \"`[\\\">\\\", key, value]` greater than: `feature[key] > value`\"\n },\n \">=\": {\n \"doc\": \"`[\\\">=\\\", key, value]` greater than or equal: `feature[key] ≥ value`\"\n },\n \"<\": {\n \"doc\": \"`[\\\"<\\\", key, value]` less than: `feature[key] < value`\"\n },\n \"<=\": {\n \"doc\": \"`[\\\"<=\\\", key, value]` less than or equal: `feature[key] ≤ value`\"\n },\n \"in\": {\n \"doc\": \"`[\\\"in\\\", key, v0, ..., vn]` set inclusion: `feature[key] ∈ {v0, ..., vn}`\"\n },\n \"!in\": {\n \"doc\": \"`[\\\"!in\\\", key, v0, ..., vn]` set exclusion: `feature[key] ∉ {v0, ..., vn}`\"\n },\n \"all\": {\n \"doc\": \"`[\\\"all\\\", f0, ..., fn]` logical `AND`: `f0 ∧ ... ∧ fn`\"\n },\n \"any\": {\n \"doc\": \"`[\\\"any\\\", f0, ..., fn]` logical `OR`: `f0 ∨ ... ∨ fn`\"\n },\n \"none\": {\n \"doc\": \"`[\\\"none\\\", f0, ..., fn]` logical `NOR`: `¬f0 ∧ ... ∧ ¬fn`\"\n },\n \"has\": {\n \"doc\": \"`[\\\"has\\\", key]` `feature[key]` exists\"\n },\n \"!has\": {\n \"doc\": \"`[\\\"!has\\\", key]` `feature[key]` does not exist\"\n },\n \"within\": {\n \"doc\": \"`[\\\"within\\\", object]` feature geometry is within object geometry\"\n }\n },\n \"doc\": \"The filter operator.\"\n },\n \"geometry_type\": {\n \"type\": \"enum\",\n \"values\": {\n \"Point\": {\n \"doc\": \"Filter to point geometries.\"\n },\n \"LineString\": {\n \"doc\": \"Filter to line geometries.\"\n },\n \"Polygon\": {\n \"doc\": \"Filter to polygon geometries.\"\n }\n },\n \"doc\": \"The geometry type for the filter to select.\"\n },\n \"function\": {\n \"expression\": {\n \"type\": \"expression\",\n \"doc\": \"An expression.\"\n },\n \"stops\": {\n \"type\": \"array\",\n \"doc\": \"An array of stops.\",\n \"value\": \"function_stop\"\n },\n \"base\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"doc\": \"The exponential base of the interpolation curve. It controls the rate at which the result increases. Higher values make the result increase more towards the high end of the range. With `1` the stops are interpolated linearly.\"\n },\n \"property\": {\n \"type\": \"string\",\n \"doc\": \"The name of a feature property to use as the function input.\",\n \"default\": \"$zoom\"\n },\n \"type\": {\n \"type\": \"enum\",\n \"values\": {\n \"identity\": {\n \"doc\": \"Return the input value as the output value.\"\n },\n \"exponential\": {\n \"doc\": \"Generate an output by interpolating between stops just less than and just greater than the function input.\"\n },\n \"interval\": {\n \"doc\": \"Return the output value of the stop just less than the function input.\"\n },\n \"categorical\": {\n \"doc\": \"Return the output value of the stop equal to the function input.\"\n }\n },\n \"doc\": \"The interpolation strategy to use in function evaluation.\",\n \"default\": \"exponential\"\n },\n \"colorSpace\": {\n \"type\": \"enum\",\n \"values\": {\n \"rgb\": {\n \"doc\": \"Use the RGB color space to interpolate color values\"\n },\n \"lab\": {\n \"doc\": \"Use the LAB color space to interpolate color values.\"\n },\n \"hcl\": {\n \"doc\": \"Use the HCL color space to interpolate color values, interpolating the Hue, Chroma, and Luminance channels individually.\"\n }\n },\n \"doc\": \"The color space in which colors interpolated. Interpolating colors in perceptual color spaces like LAB and HCL tend to produce color ramps that look more consistent and produce colors that can be differentiated more easily than those interpolated in RGB space.\",\n \"default\": \"rgb\"\n },\n \"default\": {\n \"type\": \"*\",\n \"required\": false,\n \"doc\": \"A value to serve as a fallback function result when a value isn't otherwise available. It is used in the following circumstances:\\n* In categorical functions, when the feature value does not match any of the stop domain values.\\n* In property and zoom-and-property functions, when a feature does not contain a value for the specified property.\\n* In identity functions, when the feature value is not valid for the style property (for example, if the function is being used for a `circle-color` property but the feature property value is not a string or not a valid color).\\n* In interval or exponential property and zoom-and-property functions, when the feature value is not numeric.\\nIf no default is provided, the style property's default is used in these circumstances.\"\n }\n },\n \"function_stop\": {\n \"type\": \"array\",\n \"minimum\": 0,\n \"maximum\": 24,\n \"value\": [\n \"number\",\n \"color\"\n ],\n \"length\": 2,\n \"doc\": \"Zoom level and value pair.\"\n },\n \"expression\": {\n \"type\": \"array\",\n \"value\": \"*\",\n \"minimum\": 1,\n \"doc\": \"An expression defines a function that can be used for data-driven style properties or feature filters.\"\n },\n \"expression_name\": {\n \"doc\": \"\",\n \"type\": \"enum\",\n \"values\": {\n \"let\": {\n \"doc\": \"Binds expressions to named variables, which can then be referenced in the result expression using [\\\"var\\\", \\\"variable_name\\\"].\",\n \"group\": \"Variable binding\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"var\": {\n \"doc\": \"References variable bound using \\\"let\\\".\",\n \"group\": \"Variable binding\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"literal\": {\n \"doc\": \"Provides a literal array or object value.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"array\": {\n \"doc\": \"Asserts that the input is an array (optionally with a specific item type and length). If, when the input expression is evaluated, it is not of the asserted type, then this assertion will cause the whole expression to be aborted.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"at\": {\n \"doc\": \"Retrieves an item from an array.\",\n \"group\": \"Lookup\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"in\": {\n \"doc\": \"Determines whether an item exists in an array or a substring exists in a string. In the specific case when the second and third arguments are string literals, you must wrap at least one of them in a [`literal`](#types-literal) expression to hint correct interpretation to the [type system](#type-system).\",\n \"group\": \"Lookup\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.6.0\",\n \"android\": \"9.1.0\",\n \"ios\": \"5.8.0\",\n \"macos\": \"0.15.0\"\n }\n }\n },\n \"index-of\": {\n \"doc\": \"Returns the first position at which an item can be found in an array or a substring can be found in a string, or `-1` if the input cannot be found. Accepts an optional index from where to begin the search.\",\n \"group\": \"Lookup\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.10.0\",\n \"android\": \"10.0.0\",\n \"ios\": \"10.0.0\"\n }\n }\n },\n \"slice\": {\n \"doc\": \"Returns an item from an array or a substring from a string from a specified start index, or between a start index and an end index if set. The return value is inclusive of the start index but not of the end index.\",\n \"group\": \"Lookup\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.10.0\",\n \"android\": \"10.0.0\",\n \"ios\": \"10.0.0\"\n }\n }\n },\n \"case\": {\n \"doc\": \"Selects the first output whose corresponding test condition evaluates to true, or the fallback value otherwise.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"match\": {\n \"doc\": \"Selects the output for which the label value matches the input value, or the fallback value if no match is found. The input can be any expression (for example, `[\\\"get\\\", \\\"building_type\\\"]`). Each label must be unique, and must be either:\\n - a single literal value; or\\n - an array of literal values, the values of which must be all strings or all numbers (for example `[100, 101]` or `[\\\"c\\\", \\\"b\\\"]`).\\n\\nThe input matches if any of the values in the array matches using strict equality, similar to the `\\\"in\\\"` operator.\\nIf the input type does not match the type of the labels, the result will be the fallback value.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"coalesce\": {\n \"doc\": \"Evaluates each expression in turn until the first valid value is obtained. Invalid values are `null` and [`'image'`](#types-image) expressions that are unavailable in the style. If all values are invalid, `coalesce` returns the first value listed.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"step\": {\n \"doc\": \"Produces discrete, stepped results by evaluating a piecewise-constant function defined by pairs of input and output values (\\\"stops\\\"). The `input` may be any numeric expression (e.g., `[\\\"get\\\", \\\"population\\\"]`). Stop inputs must be numeric literals in strictly ascending order. Returns the output value of the stop just less than the input, or the first output if the input is less than the first stop.\",\n \"group\": \"Ramps, scales, curves\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.42.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"interpolate\": {\n \"doc\": \"Produces continuous, smooth results by interpolating between pairs of input and output values (\\\"stops\\\"). The `input` may be any numeric expression (e.g., `[\\\"get\\\", \\\"population\\\"]`). Stop inputs must be numeric literals in strictly ascending order. The output type must be `number`, `array`, or `color`.\\n\\nInterpolation types:\\n- `[\\\"linear\\\"]`: Interpolates linearly between the pair of stops just less than and just greater than the input.\\n- `[\\\"exponential\\\", base]`: Interpolates exponentially between the stops just less than and just greater than the input. `base` controls the rate at which the output increases: higher values make the output increase more towards the high end of the range. With values close to 1 the output increases linearly.\\n- `[\\\"cubic-bezier\\\", x1, y1, x2, y2]`: Interpolates using the cubic bezier curve defined by the given control points.\",\n \"group\": \"Ramps, scales, curves\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.42.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"interpolate-hcl\": {\n \"doc\": \"Produces continuous, smooth results by interpolating between pairs of input and output values (\\\"stops\\\"). Works like `interpolate`, but the output type must be `color`, and the interpolation is performed in the Hue-Chroma-Luminance color space.\",\n \"group\": \"Ramps, scales, curves\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.49.0\"\n }\n }\n },\n \"interpolate-lab\": {\n \"doc\": \"Produces continuous, smooth results by interpolating between pairs of input and output values (\\\"stops\\\"). Works like `interpolate`, but the output type must be `color`, and the interpolation is performed in the CIELAB color space.\",\n \"group\": \"Ramps, scales, curves\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.49.0\"\n }\n }\n },\n \"ln2\": {\n \"doc\": \"Returns mathematical constant ln(2).\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"pi\": {\n \"doc\": \"Returns the mathematical constant pi.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"e\": {\n \"doc\": \"Returns the mathematical constant e.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"typeof\": {\n \"doc\": \"Returns a string describing the type of the given value.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"string\": {\n \"doc\": \"Asserts that the input value is a string. If multiple values are provided, each one is evaluated in order until a string is obtained. If none of the inputs are strings, the expression is an error.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"number\": {\n \"doc\": \"Asserts that the input value is a number. If multiple values are provided, each one is evaluated in order until a number is obtained. If none of the inputs are numbers, the expression is an error.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"boolean\": {\n \"doc\": \"Asserts that the input value is a boolean. If multiple values are provided, each one is evaluated in order until a boolean is obtained. If none of the inputs are booleans, the expression is an error.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"object\": {\n \"doc\": \"Asserts that the input value is an object. If multiple values are provided, each one is evaluated in order until an object is obtained. If none of the inputs are objects, the expression is an error.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"collator\": {\n \"doc\": \"Returns a `collator` for use in locale-dependent comparison operations. The `case-sensitive` and `diacritic-sensitive` options default to `false`. The `locale` argument specifies the IETF language tag of the locale to use. If none is provided, the default locale is used. If the requested locale is not available, the `collator` will use a system-defined fallback locale. Use `resolved-locale` to test the results of locale fallback behavior.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n },\n \"format\": {\n \"doc\": \"Returns a `formatted` string for displaying mixed-format text in the `text-field` property. The input may contain a string literal or expression, including an [`'image'`](#types-image) expression. Strings may be followed by a style override object that supports the following properties:\\n- `\\\"text-font\\\"`: Overrides the font stack specified by the root layout property.\\n- `\\\"text-color\\\"`: Overrides the color specified by the root paint property.\\n- `\\\"font-scale\\\"`: Applies a scaling factor on `text-size` as specified by the root layout property.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.48.0\",\n \"android\": \"6.7.0\",\n \"ios\": \"4.6.0\",\n \"macos\": \"0.12.0\"\n },\n \"text-font\": {\n \"js\": \"0.48.0\",\n \"android\": \"6.7.0\",\n \"ios\": \"4.6.0\",\n \"macos\": \"0.12.0\"\n },\n \"font-scale\": {\n \"js\": \"0.48.0\",\n \"android\": \"6.7.0\",\n \"ios\": \"4.6.0\",\n \"macos\": \"0.12.0\"\n },\n \"text-color\": {\n \"js\": \"1.3.0\",\n \"android\": \"7.3.0\",\n \"ios\": \"4.10.0\",\n \"macos\": \"0.14.0\"\n },\n \"image\": {\n \"js\": \"1.6.0\",\n \"android\": \"8.6.0\",\n \"ios\": \"5.7.0\",\n \"macos\": \"0.15.0\"\n }\n }\n },\n \"image\": {\n \"doc\": \"Returns a [`ResolvedImage`](/mapbox-gl-js/style-spec/types/#resolvedimage) for use in [`icon-image`](/mapbox-gl-js/style-spec/layers/#layout-symbol-icon-image), `*-pattern` entries, and as a section in the [`'format'`](#types-format) expression. A [`'coalesce'`](#coalesce) expression containing `image` expressions will evaluate to the first listed image that is currently in the style. This validation process is synchronous and requires the image to have been added to the style before requesting it in the `'image'` argument.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.4.0\",\n \"android\": \"8.6.0\",\n \"ios\": \"5.7.0\",\n \"macos\": \"0.15.0\"\n }\n }\n },\n \"number-format\": {\n \"doc\": \"Converts the input number into a string representation using the providing formatting rules. If set, the `locale` argument specifies the locale to use, as a BCP 47 language tag. If set, the `currency` argument specifies an ISO 4217 code to use for currency-style formatting. If set, the `unit` argument specifies a [simple ECMAScript unit](https://tc39.es/proposal-unified-intl-numberformat/section6/locales-currencies-tz_proposed_out.html#sec-issanctionedsimpleunitidentifier) to use for unit-style formatting. If set, the `min-fraction-digits` and `max-fraction-digits` arguments specify the minimum and maximum number of fractional digits to include.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.54.0\",\n \"android\" : \"8.4.0\",\n \"ios\": \"5.4.0\",\n \"macos\": \"0.15.0\"\n }\n }\n },\n \"to-string\": {\n \"doc\": \"Converts the input value to a string. If the input is `null`, the result is `\\\"\\\"`. If the input is a [`boolean`](#types-boolean), the result is `\\\"true\\\"` or `\\\"false\\\"`. If the input is a number, it is converted to a string as specified by the [\\\"NumberToString\\\" algorithm](https://tc39.github.io/ecma262/#sec-tostring-applied-to-the-number-type) of the ECMAScript Language Specification. If the input is a [`color`](#color), it is converted to a string of the form `\\\"rgba(r,g,b,a)\\\"`, where `r`, `g`, and `b` are numerals ranging from 0 to 255, and `a` ranges from 0 to 1. If the input is an [`'image'`](#types-image) expression, `'to-string'` returns the image name. Otherwise, the input is converted to a string in the format specified by the [`JSON.stringify`](https://tc39.github.io/ecma262/#sec-json.stringify) function of the ECMAScript Language Specification.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"to-number\": {\n \"doc\": \"Converts the input value to a number, if possible. If the input is `null` or `false`, the result is 0. If the input is `true`, the result is 1. If the input is a string, it is converted to a number as specified by the [\\\"ToNumber Applied to the String Type\\\" algorithm](https://tc39.github.io/ecma262/#sec-tonumber-applied-to-the-string-type) of the ECMAScript Language Specification. If multiple values are provided, each one is evaluated in order until the first successful conversion is obtained. If none of the inputs can be converted, the expression is an error.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"to-boolean\": {\n \"doc\": \"Converts the input value to a boolean. The result is `false` when then input is an empty string, 0, `false`, `null`, or `NaN`; otherwise it is `true`.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"to-rgba\": {\n \"doc\": \"Returns a four-element array containing the input color's red, green, blue, and alpha components, in that order.\",\n \"group\": \"Color\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"to-color\": {\n \"doc\": \"Converts the input value to a color. If multiple values are provided, each one is evaluated in order until the first successful conversion is obtained. If none of the inputs can be converted, the expression is an error.\",\n \"group\": \"Types\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"rgb\": {\n \"doc\": \"Creates a color value from red, green, and blue components, which must range between 0 and 255, and an alpha component of 1. If any component is out of range, the expression is an error.\",\n \"group\": \"Color\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"rgba\": {\n \"doc\": \"Creates a color value from red, green, blue components, which must range between 0 and 255, and an alpha component which must range between 0 and 1. If any component is out of range, the expression is an error.\",\n \"group\": \"Color\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"get\": {\n \"doc\": \"Retrieves a property value from the current feature's properties, or from another object if a second argument is provided. Returns `null` if the requested property is missing.\",\n \"group\": \"Lookup\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"has\": {\n \"doc\": \"Tests for the presence of an property value in the current feature's properties, or from another object if a second argument is provided.\",\n \"group\": \"Lookup\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"length\": {\n \"doc\": \"Returns the length of an array or string.\",\n \"group\": \"Lookup\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"properties\": {\n \"doc\": \"Returns the feature properties object. Note that in some cases, it may be more efficient to use `[\\\"get\\\", \\\"property_name\\\"]` directly.\",\n \"group\": \"Feature data\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"feature-state\": {\n \"doc\": \"Retrieves a property value from the current feature's state. Returns `null` if the requested property is not present on the feature's state. A feature's state is not part of the GeoJSON or vector tile data, and must be set programmatically on each feature. Features are identified by their `id` attribute, which must be an integer or a string that can be cast to an integer. Note that [\\\"feature-state\\\"] can only be used with paint properties that support data-driven styling.\",\n \"group\": \"Feature data\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.46.0\",\n \"android\": \"10.0.0\",\n \"ios\": \"10.0.0\"\n }\n }\n },\n \"geometry-type\": {\n \"doc\": \"Returns the feature's geometry type: `Point`, `LineString` or `Polygon`. `Multi*` feature types return the singular forms.\",\n \"group\": \"Feature data\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"id\": {\n \"doc\": \"Returns the feature's id, if it has one.\",\n \"group\": \"Feature data\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"zoom\": {\n \"doc\": \"Returns the current zoom level. Note that in style layout and paint properties, [\\\"zoom\\\"] may only appear as the input to a top-level \\\"step\\\" or \\\"interpolate\\\" expression.\",\n \"group\": \"Camera\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"pitch\": {\n \"doc\": \"Returns the current pitch in degrees. `[\\\"pitch\\\"]` may only be used in the `filter` expression for a `symbol` layer.\",\n \"group\": \"Camera\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.6.0\",\n \"android\": \"10.9.0\",\n \"ios\": \"10.9.0\"\n }\n }\n },\n \"distance-from-center\": {\n \"doc\": \"Returns the distance of a `symbol` instance from the center of the map. The distance is measured in pixels divided by the height of the map container. It measures 0 at the center, decreases towards the camera and increase away from the camera. For example, if the height of the map is 1000px, a value of -1 means 1000px away from the center towards the camera, and a value of 1 means a distance of 1000px away from the camera from the center. `[\\\"distance-from-center\\\"]` may only be used in the `filter` expression for a `symbol` layer.\",\n \"group\": \"Camera\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.6.0\",\n \"android\": \"10.9.0\",\n \"ios\": \"10.9.0\"\n }\n }\n },\n \"heatmap-density\": {\n \"doc\": \"Returns the kernel density estimation of a pixel in a heatmap layer, which is a relative measure of how many data points are crowded around a particular pixel. Can only be used in the `heatmap-color` property.\",\n \"group\": \"Heatmap\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"line-progress\": {\n \"doc\": \"Returns the progress along a gradient line. Can only be used in the `line-gradient` property.\",\n \"group\": \"Feature data\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.6.0\",\n \"macos\": \"0.12.0\"\n }\n }\n },\n \"sky-radial-progress\": {\n \"doc\": \"Returns the distance of a point on the sky from the sun position. Returns 0 at sun position and 1 when the distance reaches `sky-gradient-radius`. Can only be used in the `sky-gradient` property.\",\n \"group\": \"sky\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n }\n },\n \"accumulated\": {\n \"doc\": \"Returns the value of a cluster property accumulated so far. Can only be used in the `clusterProperties` option of a clustered GeoJSON source.\",\n \"group\": \"Feature data\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.53.0\",\n \"android\": \"8.4.0\",\n \"ios\": \"5.5.0\",\n \"macos\": \"0.15.0\"\n }\n }\n },\n \"+\": {\n \"doc\": \"Returns the sum of the inputs.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"*\": {\n \"doc\": \"Returns the product of the inputs.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"-\": {\n \"doc\": \"For two inputs, returns the result of subtracting the second input from the first. For a single input, returns the result of subtracting it from 0.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"/\": {\n \"doc\": \"Returns the result of floating point division of the first input by the second.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"%\": {\n \"doc\": \"Returns the remainder after integer division of the first input by the second.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"^\": {\n \"doc\": \"Returns the result of raising the first input to the power specified by the second.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"sqrt\": {\n \"doc\": \"Returns the square root of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.42.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"log10\": {\n \"doc\": \"Returns the base-ten logarithm of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"ln\": {\n \"doc\": \"Returns the natural logarithm of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"log2\": {\n \"doc\": \"Returns the base-two logarithm of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"sin\": {\n \"doc\": \"Returns the sine of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"cos\": {\n \"doc\": \"Returns the cosine of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"tan\": {\n \"doc\": \"Returns the tangent of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"asin\": {\n \"doc\": \"Returns the arcsine of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"acos\": {\n \"doc\": \"Returns the arccosine of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"atan\": {\n \"doc\": \"Returns the arctangent of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"min\": {\n \"doc\": \"Returns the minimum value of the inputs.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"max\": {\n \"doc\": \"Returns the maximum value of the inputs.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"round\": {\n \"doc\": \"Rounds the input to the nearest integer. Halfway values are rounded away from zero. For example, `[\\\"round\\\", -1.5]` evaluates to -2.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"abs\": {\n \"doc\": \"Returns the absolute value of the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"ceil\": {\n \"doc\": \"Returns the smallest integer that is greater than or equal to the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"floor\": {\n \"doc\": \"Returns the largest integer that is less than or equal to the input.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"distance\": {\n \"doc\": \"Returns the shortest distance in meters between the evaluated feature and the input geometry. The input value can be a valid GeoJSON of type `Point`, `MultiPoint`, `LineString`, `MultiLineString`, `Polygon`, `MultiPolygon`, `Feature`, or `FeatureCollection`. Distance values returned may vary in precision due to loss in precision from encoding geometries, particularly below zoom level 13.\",\n \"group\": \"Math\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"android\": \"9.2.0\",\n \"ios\": \"5.9.0\",\n \"macos\": \"0.16.0\"\n }\n }\n },\n \"==\": {\n \"doc\": \"Returns `true` if the input values are equal, `false` otherwise. The comparison is strictly typed: values of different runtime types are always considered unequal. Cases where the types are known to be different at parse time are considered invalid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"collator\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n },\n \"!=\": {\n \"doc\": \"Returns `true` if the input values are not equal, `false` otherwise. The comparison is strictly typed: values of different runtime types are always considered unequal. Cases where the types are known to be different at parse time are considered invalid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"collator\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n },\n \">\": {\n \"doc\": \"Returns `true` if the first input is strictly greater than the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"collator\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n },\n \"<\": {\n \"doc\": \"Returns `true` if the first input is strictly less than the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"collator\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n },\n \">=\": {\n \"doc\": \"Returns `true` if the first input is greater than or equal to the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"collator\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n },\n \"<=\": {\n \"doc\": \"Returns `true` if the first input is less than or equal to the second, `false` otherwise. The arguments are required to be either both strings or both numbers; if during evaluation they are not, expression evaluation produces an error. Cases where this constraint is known not to hold at parse time are considered in valid and will produce a parse error. Accepts an optional `collator` argument to control locale-dependent string comparisons.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"collator\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n },\n \"all\": {\n \"doc\": \"Returns `true` if all the inputs are `true`, `false` otherwise. The inputs are evaluated in order, and evaluation is short-circuiting: once an input expression evaluates to `false`, the result is `false` and no further input expressions are evaluated.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"any\": {\n \"doc\": \"Returns `true` if any of the inputs are `true`, `false` otherwise. The inputs are evaluated in order, and evaluation is short-circuiting: once an input expression evaluates to `true`, the result is `true` and no further input expressions are evaluated.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"!\": {\n \"doc\": \"Logical negation. Returns `true` if the input is `false`, and `false` if the input is `true`.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"within\": {\n \"doc\": \"Returns `true` if the evaluated feature is fully contained inside a boundary of the input geometry, `false` otherwise. The input value can be a valid GeoJSON of type `Polygon`, `MultiPolygon`, `Feature`, or `FeatureCollection`. Supported features for evaluation:\\n- `Point`: Returns `false` if a point is on the boundary or falls outside the boundary.\\n- `LineString`: Returns `false` if any part of a line falls outside the boundary, the line intersects the boundary, or a line's endpoint is on the boundary.\",\n \"group\": \"Decision\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"1.9.0\",\n \"android\": \"9.1.0\",\n \"ios\": \"5.8.0\",\n \"macos\": \"0.15.0\"\n }\n }\n },\n \"is-supported-script\": {\n \"doc\": \"Returns `true` if the input string is expected to render legibly. Returns `false` if the input string contains sections that cannot be rendered without potential loss of meaning (e.g. Indic scripts that require complex text shaping, or right-to-left scripts if the the `mapbox-gl-rtl-text` plugin is not in use in Mapbox GL JS).\",\n \"group\": \"String\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.6.0\",\n \"ios\": \"4.1.0\",\n \"macos\": \"0.8.0\"\n }\n }\n },\n \"upcase\": {\n \"doc\": \"Returns the input string converted to uppercase. Follows the Unicode Default Case Conversion algorithm and the locale-insensitive case mappings in the Unicode Character Database.\",\n \"group\": \"String\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"downcase\": {\n \"doc\": \"Returns the input string converted to lowercase. Follows the Unicode Default Case Conversion algorithm and the locale-insensitive case mappings in the Unicode Character Database.\",\n \"group\": \"String\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"concat\": {\n \"doc\": \"Returns a `string` consisting of the concatenation of the inputs. Each input is converted to a string as if by `to-string`.\",\n \"group\": \"String\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n }\n },\n \"resolved-locale\": {\n \"doc\": \"Returns the IETF language tag of the locale being used by the provided `collator`. This can be used to determine the default system locale, or to determine if a requested locale was successfully loaded.\",\n \"group\": \"String\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n }\n }\n }\n },\n \"fog\": {\n \"range\": {\n \"type\": \"array\",\n \"default\": [\n 0.5,\n 10\n ],\n \"minimum\": -20,\n \"maximum\": 20,\n \"length\": 2,\n \"value\": \"number\",\n \"property-type\": \"data-constant\",\n \"transition\": true,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"doc\": \"The start and end distance range in which fog fades from fully transparent to fully opaque. The distance to the point at the center of the map is defined as zero, so that negative range values are closer to the camera, and positive values are farther away.\",\n \"example\": [\n 0.5,\n 10\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.3.0\",\n \"android\": \"10.6.0\",\n \"ios\": \"10.6.0\"\n }\n }\n },\n \"color\": {\n \"type\": \"color\",\n \"property-type\": \"data-constant\",\n \"default\": \"#ffffff\",\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"The color of the atmosphere region immediately below the horizon and within the `range` and above the horizon and within `horizon-blend`. Using opacity is recommended only for smoothly transitioning fog on/off as anything less than 100% opacity results in more tiles loaded and drawn.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.3.0\",\n \"android\": \"10.6.0\",\n \"ios\": \"10.6.0\"\n }\n }\n },\n \"high-color\": {\n \"type\": \"color\",\n \"property-type\": \"data-constant\",\n \"default\": \"#245cdf\",\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"The color of the atmosphere region above the horizon, `high-color` extends further above the horizon than the `color` property and its spread can be controlled with `horizon-blend`. The opacity can be set to `0` to remove the high atmosphere color contribution.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.9.0\",\n \"android\": \"10.6.0\",\n \"ios\": \"10.6.0\"\n }\n }\n },\n \"space-color\": {\n \"type\": \"color\",\n \"property-type\": \"data-constant\",\n\n \"default\":\n [\n \"interpolate\",\n [\n \"linear\"\n ],\n [\n \"zoom\"\n ],\n 4,\n \"#010b19\",\n 7,\n \"#367ab9\"\n ],\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"The color of the region above the horizon and after the end of the `horizon-blend` contribution. The opacity can be set to `0` to have a transparent background.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.9.0\",\n \"android\": \"10.6.0\",\n \"ios\": \"10.6.0\"\n }\n }\n },\n \"horizon-blend\": {\n \"type\": \"number\",\n \"property-type\": \"data-constant\",\n \"default\":\n [\n \"interpolate\",\n [\n \"linear\"\n ],\n [\n \"zoom\"\n ],\n 4,\n 0.2,\n 7,\n 0.1\n ],\n \"minimum\": 0,\n \"maximum\": 1,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"Horizon blend applies a smooth fade from the color of the atmosphere to the color of space. A value of zero leaves a sharp transition from atmosphere to space. Increasing the value blends the color of atmosphere into increasingly high angles of the sky.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.3.0\",\n \"android\": \"10.6.0\",\n \"ios\": \"10.6.0\"\n }\n }\n },\n \"star-intensity\": {\n \"type\": \"number\",\n \"property-type\": \"data-constant\",\n \"default\":\n [\n \"interpolate\",\n [\n \"linear\"\n ],\n [\n \"zoom\"\n ],\n 5,\n 0.35,\n 6,\n 0\n ],\n \"minimum\": 0,\n \"maximum\": 1,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"A value controlling the star intensity where `0` will show no stars and `1` will show stars at their maximum intensity.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.9.0\",\n \"android\": \"10.6.0\",\n \"ios\": \"10.6.0\"\n }\n }\n }\n },\n \"light\": {\n \"anchor\": {\n \"type\": \"enum\",\n \"default\": \"viewport\",\n \"values\": {\n \"map\": {\n \"doc\": \"The position of the light source is aligned to the rotation of the map.\"\n },\n \"viewport\": {\n \"doc\": \"The position of the light source is aligned to the rotation of the viewport.\"\n }\n },\n \"property-type\": \"data-constant\",\n \"transition\": false,\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"doc\": \"Whether extruded geometries are lit relative to the map or viewport.\",\n \"example\": \"map\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n }\n },\n \"position\": {\n \"type\": \"array\",\n \"default\": [\n 1.15,\n 210,\n 30\n ],\n \"length\": 3,\n \"value\": \"number\",\n \"property-type\": \"data-constant\",\n \"transition\": true,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"doc\": \"Position of the light source relative to lit (extruded) geometries, in [r radial coordinate, a azimuthal angle, p polar angle] where r indicates the distance from the center of the base of an object to its light, a indicates the position of the light relative to 0° (0° when `light.anchor` is set to `viewport` corresponds to the top of the viewport, or 0° when `light.anchor` is set to `map` corresponds to due north, and degrees proceed clockwise), and p indicates the height of the light (from 0°, directly above, to 180°, directly below).\",\n \"example\": [\n 1.5,\n 90,\n 80\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n }\n },\n \"color\": {\n \"type\": \"color\",\n \"property-type\": \"data-constant\",\n \"default\": \"#ffffff\",\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"Color tint for lighting extruded geometries.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n }\n },\n \"intensity\": {\n \"type\": \"number\",\n \"property-type\": \"data-constant\",\n \"default\": 0.5,\n \"minimum\": 0,\n \"maximum\": 1,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"Intensity of lighting (on a scale from 0 to 1). Higher numbers will present as more extreme contrast.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n }\n }\n },\n \"projection\": {\n \"name\": {\n \"type\": \"enum\",\n \"values\": {\n \"albers\": {\n \"doc\": \"An Albers equal-area projection centered on the continental United States. You can configure the projection for a different region by setting `center` and `parallels` properties. You may want to set max bounds to constrain the map to the relevant region.\"\n },\n \"equalEarth\": {\n \"doc\": \"An Equal Earth projection.\"\n },\n \"equirectangular\": {\n \"doc\": \"An Equirectangular projection. This projection is very similar to the Plate Carrée projection.\"\n },\n \"lambertConformalConic\": {\n \"doc\": \"A Lambert conformal conic projection. You can configure the projection for a region by setting `center` and `parallels` properties. You may want to set max bounds to constrain the map to the relevant region.\"\n },\n \"mercator\": {\n \"doc\": \"The Mercator projection is the default projection.\"\n },\n \"naturalEarth\": {\n \"doc\": \"A Natural Earth projection.\"\n },\n \"winkelTripel\": {\n \"doc\": \"A Winkel Tripel projection.\"\n },\n \"globe\": {\n \"doc\": \"A globe projection.\"\n }\n },\n \"default\": \"mercator\",\n \"doc\": \"The name of the projection to be used for rendering the map.\",\n \"required\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.6.0\"\n }\n }\n },\n \"center\": {\n \"type\": \"array\",\n \"length\": 2,\n \"value\": \"number\",\n \"property-type\": \"data-constant\",\n \"minimum\": [-180, -90],\n \"maximum\": [180, 90],\n \"transition\": false,\n \"doc\": \"The reference longitude and latitude of the projection. `center` takes the form of [lng, lat]. This property is only configurable for conic projections (Albers and Lambert Conformal Conic). All other projections are centered on [0, 0].\",\n \"example\": [\n -96,\n 37.5\n ],\n \"requires\": [\n {\n \"name\": [\n \"albers\",\n \"lambertConformalConic\"\n ]\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.6.0\"\n }\n }\n },\n \"parallels\": {\n \"type\": \"array\",\n \"length\": 2,\n \"value\": \"number\",\n \"property-type\": \"data-constant\",\n \"minimum\": [-90, -90],\n \"maximum\": [90, 90],\n \"transition\": false,\n \"doc\": \"The standard parallels of the projection, denoting the desired latitude range with minimal distortion. `parallels` takes the form of [lat0, lat1]. This property is only configurable for conic projections (Albers and Lambert Conformal Conic).\",\n \"example\": [\n 29.5,\n 45.5\n ],\n \"requires\": [\n {\n \"name\": [\n \"albers\",\n \"lambertConformalConic\"\n ]\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.6.0\"\n }\n }\n }\n },\n \"terrain\" : {\n \"source\": {\n \"type\": \"string\",\n \"doc\": \"Name of a source of `raster_dem` type to be used for terrain elevation.\",\n \"required\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n }\n },\n \"exaggeration\": {\n \"type\": \"number\",\n \"property-type\": \"data-constant\",\n \"default\": 1.0,\n \"minimum\": 0,\n \"maximum\": 1000,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"Exaggerates the elevation of the terrain by multiplying the data from the DEM with this value.\",\n \"requires\": [\n \"source\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n }\n }\n },\n \"paint\": [\n \"paint_fill\",\n \"paint_line\",\n \"paint_circle\",\n \"paint_heatmap\",\n \"paint_fill-extrusion\",\n \"paint_symbol\",\n \"paint_raster\",\n \"paint_hillshade\",\n \"paint_background\",\n \"paint_sky\"\n ],\n \"paint_fill\": {\n \"fill-antialias\": {\n \"type\": \"boolean\",\n \"default\": true,\n \"doc\": \"Whether or not the fill should be antialiased.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"fill-opacity\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"doc\": \"The opacity of the entire fill layer. In contrast to the `fill-color`, this value will also affect the 1px stroke around the fill, if the stroke is used.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.21.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"fill-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"doc\": \"The color of the filled part of this layer. This color can be specified as `rgba` with an alpha component and the color's opacity will not affect the opacity of the 1px stroke, if it is used.\",\n \"transition\": true,\n \"requires\": [\n {\n \"!\": \"fill-pattern\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.19.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"fill-outline-color\": {\n \"type\": \"color\",\n \"doc\": \"The outline color of the fill. Matches the value of `fill-color` if unspecified.\",\n \"transition\": true,\n \"requires\": [\n {\n \"!\": \"fill-pattern\"\n },\n {\n \"fill-antialias\": true\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.19.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"fill-translate\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"The geometry's offset. Values are [x, y] where negatives indicate left and up, respectively.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"fill-translate-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The fill is translated relative to the map.\"\n },\n \"viewport\": {\n \"doc\": \"The fill is translated relative to the viewport.\"\n }\n },\n \"doc\": \"Controls the frame of reference for `fill-translate`.\",\n \"default\": \"map\",\n \"requires\": [\n \"fill-translate\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"fill-pattern\": {\n \"type\": \"resolvedImage\",\n \"transition\": false,\n \"doc\": \"Name of image in sprite to use for drawing image fills. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.49.0\",\n \"android\": \"6.5.0\",\n \"macos\": \"0.11.0\",\n \"ios\": \"4.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n }\n },\n \"paint_fill-extrusion\": {\n \"fill-extrusion-opacity\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"doc\": \"The opacity of the entire fill extrusion layer. This is rendered on a per-layer, not per-feature, basis, and data-driven styling is not available.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"fill-extrusion-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"doc\": \"The base color of the extruded fill. The extrusion's surfaces will be shaded differently based on this color in combination with the root `light` settings. If this color is specified as `rgba` with an alpha component, the alpha component will be ignored; use `fill-extrusion-opacity` to set layer opacity.\",\n \"transition\": true,\n \"requires\": [\n {\n \"!\": \"fill-extrusion-pattern\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"fill-extrusion-translate\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"The geometry's offset. Values are [x, y] where negatives indicate left and up (on the flat plane), respectively.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"fill-extrusion-translate-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The fill extrusion is translated relative to the map.\"\n },\n \"viewport\": {\n \"doc\": \"The fill extrusion is translated relative to the viewport.\"\n }\n },\n \"doc\": \"Controls the frame of reference for `fill-extrusion-translate`.\",\n \"default\": \"map\",\n \"requires\": [\n \"fill-extrusion-translate\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"fill-extrusion-pattern\": {\n \"type\": \"resolvedImage\",\n \"transition\": false,\n \"doc\": \"Name of image in sprite to use for drawing images on extruded fills. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.49.0\",\n \"android\": \"6.5.0\",\n \"macos\": \"0.11.0\",\n \"ios\": \"4.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"fill-extrusion-height\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"units\": \"meters\",\n \"doc\": \"The height with which to extrude this layer.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"fill-extrusion-base\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"units\": \"meters\",\n \"doc\": \"The height with which to extrude the base of this layer. Must be less than or equal to `fill-extrusion-height`.\",\n \"transition\": true,\n \"requires\": [\n \"fill-extrusion-height\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.27.0\",\n \"android\": \"5.1.0\",\n \"ios\": \"3.6.0\",\n \"macos\": \"0.5.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"fill-extrusion-vertical-gradient\": {\n \"type\": \"boolean\",\n \"default\": true,\n \"doc\": \"Whether to apply a vertical gradient to the sides of a fill-extrusion layer. If true, sides will be shaded slightly darker farther down.\",\n \"transition\": false,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.50.0\",\n \"android\": \"7.0.0\",\n \"ios\": \"4.7.0\",\n \"macos\": \"0.13.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"fill-extrusion-ambient-occlusion-intensity\": {\n \"property-type\": \"data-constant\",\n \"type\": \"number\",\n \"private\": true,\n \"default\": 0.0,\n \"minimum\": 0,\n \"maximum\": 1,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"Controls the intensity of shading near ground and concave angles between walls. Default value 0.0 disables ambient occlusion and values around 0.3 provide the most plausible results for buildings.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.10.0\",\n \"android\": \"10.7.0\",\n \"ios\": \"10.7.0\"\n }\n }\n },\n \"fill-extrusion-ambient-occlusion-radius\": {\n \"property-type\": \"data-constant\",\n \"type\": \"number\",\n \"private\": true,\n \"default\": 3.0,\n \"minimum\": 0,\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"transition\": true,\n \"doc\": \"Shades area near ground and concave angles between walls where the radius defines only vertical impact. Default value 3.0 corresponds to height of one floor and brings the most plausible results for buildings.\",\n \"requires\": [\n \"fill-extrusion-edge-radius\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.10.0\",\n \"android\": \"10.7.0\",\n \"ios\": \"10.7.0\"\n }\n }\n }\n },\n \"paint_line\": {\n \"line-opacity\": {\n \"type\": \"number\",\n \"doc\": \"The opacity at which the line will be drawn.\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-color\": {\n \"type\": \"color\",\n \"doc\": \"The color with which the line will be drawn.\",\n \"default\": \"#000000\",\n \"transition\": true,\n \"requires\": [\n {\n \"!\": \"line-pattern\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.23.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-translate\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"The geometry's offset. Values are [x, y] where negatives indicate left and up, respectively.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"line-translate-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The line is translated relative to the map.\"\n },\n \"viewport\": {\n \"doc\": \"The line is translated relative to the viewport.\"\n }\n },\n \"doc\": \"Controls the frame of reference for `line-translate`.\",\n \"default\": \"map\",\n \"requires\": [\n \"line-translate\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"line-width\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Stroke thickness.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.39.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-gap-width\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"doc\": \"Draws a line casing outside of a line's actual path. Value indicates the width of the inner gap.\",\n \"transition\": true,\n \"units\": \"pixels\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-offset\": {\n \"type\": \"number\",\n \"default\": 0,\n \"doc\": \"The line's offset. For linear features, a positive value offsets the line to the right, relative to the direction of the line, and a negative value to the left. For polygon features, a positive value results in an inset, and a negative value results in an outset.\",\n \"transition\": true,\n \"units\": \"pixels\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.12.1\",\n \"android\": \"3.0.0\",\n \"ios\": \"3.1.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-blur\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Blur applied to the line, in pixels.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-dasharray\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"doc\": \"Specifies the lengths of the alternating dashes and gaps that form the dash pattern. The lengths are later scaled by the line width. To convert a dash length to pixels, multiply the length by the current line width. Note that GeoJSON sources with `lineMetrics: true` specified won't render dashed lines to the expected scale. Also note that zoom-dependent expressions will be evaluated only at integer zoom levels.\",\n \"minimum\": 0,\n \"transition\": false,\n \"units\": \"line widths\",\n \"requires\": [\n {\n \"!\": \"line-pattern\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"2.3.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-pattern\": {\n \"type\": \"resolvedImage\",\n \"transition\": false,\n \"doc\": \"Name of image in sprite to use for drawing image lines. For seamless patterns, image width must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.49.0\",\n \"android\": \"6.5.0\",\n \"macos\": \"0.11.0\",\n \"ios\": \"4.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\",\n \"feature\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"line-gradient\": {\n \"type\": \"color\",\n \"doc\": \"Defines a gradient with which to color a line feature. Can only be used with GeoJSON sources that specify `\\\"lineMetrics\\\": true`.\",\n \"transition\": false,\n \"requires\": [\n {\n \"!\": \"line-pattern\"\n },\n {\n \"source\": \"geojson\",\n \"has\": {\n \"lineMetrics\": true\n }\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.45.0\",\n \"android\": \"6.5.0\",\n \"ios\": \"4.4.0\",\n \"macos\": \"0.11.0\"\n },\n \"data-driven styling\": {}\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"line-progress\"\n ]\n },\n \"property-type\": \"color-ramp\"\n },\n \"line-trim-offset\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"doc\": \"The line part between [trim-start, trim-end] will be marked as transparent to make a route vanishing effect. The line trim-off offset is based on the whole line range [0.0, 1.0].\",\n \"length\": 2,\n \"default\": [0.0, 0.0],\n \"minimum\": [0.0, 0.0],\n \"maximum\": [1.0, 1.0],\n \"transition\": false,\n \"requires\": [\n {\n \"source\": \"geojson\",\n \"has\": {\n \"lineMetrics\": true\n }\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.9.0\",\n \"android\": \"10.5.0\",\n \"ios\": \"10.5.0\",\n \"macos\": \"10.5.0\"\n }\n },\n \"property-type\": \"constant\"\n }\n },\n \"paint_circle\": {\n \"circle-radius\": {\n \"type\": \"number\",\n \"default\": 5,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Circle radius.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.18.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"circle-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"doc\": \"The fill color of the circle.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.18.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"circle-blur\": {\n \"type\": \"number\",\n \"default\": 0,\n \"doc\": \"Amount to blur the circle. 1 blurs the circle such that only the centerpoint is full opacity.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.20.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"circle-opacity\": {\n \"type\": \"number\",\n \"doc\": \"The opacity at which the circle will be drawn.\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.20.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"circle-translate\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"The geometry's offset. Values are [x, y] where negatives indicate left and up, respectively.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"circle-translate-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The circle is translated relative to the map.\"\n },\n \"viewport\": {\n \"doc\": \"The circle is translated relative to the viewport.\"\n }\n },\n \"doc\": \"Controls the frame of reference for `circle-translate`.\",\n \"default\": \"map\",\n \"requires\": [\n \"circle-translate\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"circle-pitch-scale\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"Circles are scaled according to their apparent distance to the camera.\"\n },\n \"viewport\": {\n \"doc\": \"Circles are not scaled.\"\n }\n },\n \"default\": \"map\",\n \"doc\": \"Controls the scaling behavior of the circle when the map is pitched.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.21.0\",\n \"android\": \"4.2.0\",\n \"ios\": \"3.4.0\",\n \"macos\": \"0.2.1\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"circle-pitch-alignment\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The circle is aligned to the plane of the map.\"\n },\n \"viewport\": {\n \"doc\": \"The circle is aligned to the plane of the viewport.\"\n }\n },\n \"default\": \"viewport\",\n \"doc\": \"Orientation of circle when map is pitched.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.39.0\",\n \"android\": \"5.2.0\",\n \"ios\": \"3.7.0\",\n \"macos\": \"0.6.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"circle-stroke-width\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"The width of the circle's stroke. Strokes are placed outside of the `circle-radius`.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"circle-stroke-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"doc\": \"The stroke color of the circle.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"circle-stroke-opacity\": {\n \"type\": \"number\",\n \"doc\": \"The opacity of the circle's stroke.\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.29.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n }\n },\n \"paint_heatmap\": {\n \"heatmap-radius\": {\n \"type\": \"number\",\n \"default\": 30,\n \"minimum\": 1,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Radius of influence of one heatmap point in pixels. Increasing the value makes the heatmap smoother, but less detailed. `queryRenderedFeatures` on heatmap layers will return points within this radius.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"heatmap-weight\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"transition\": false,\n \"doc\": \"A measure of how much an individual point contributes to the heatmap. A value of 10 would be equivalent to having 10 points of weight 1 in the same spot. Especially useful when combined with clustering.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"heatmap-intensity\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"transition\": true,\n \"doc\": \"Similar to `heatmap-weight` but controls the intensity of the heatmap globally. Primarily used for adjusting the heatmap based on zoom level.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"heatmap-color\": {\n \"type\": \"color\",\n \"default\": [\n \"interpolate\",\n [\n \"linear\"\n ],\n [\n \"heatmap-density\"\n ],\n 0,\n \"rgba(0, 0, 255, 0)\",\n 0.1,\n \"royalblue\",\n 0.3,\n \"cyan\",\n 0.5,\n \"lime\",\n 0.7,\n \"yellow\",\n 1,\n \"red\"\n ],\n \"doc\": \"Defines the color of each pixel based on its density value in a heatmap. Should be an expression that uses `[\\\"heatmap-density\\\"]` as input.\",\n \"transition\": false,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n },\n \"data-driven styling\": {}\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"heatmap-density\"\n ]\n },\n \"property-type\": \"color-ramp\"\n },\n \"heatmap-opacity\": {\n \"type\": \"number\",\n \"doc\": \"The global opacity at which the heatmap layer will be drawn.\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.41.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n }\n },\n \"paint_symbol\": {\n \"icon-opacity\": {\n \"doc\": \"The opacity at which the icon will be drawn.\",\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"transition\": true,\n \"doc\": \"The color of the icon. This can only be used with [SDF icons](/help/troubleshooting/using-recolorable-images-in-mapbox-maps/).\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-halo-color\": {\n \"type\": \"color\",\n \"default\": \"rgba(0, 0, 0, 0)\",\n \"transition\": true,\n \"doc\": \"The color of the icon's halo. Icon halos can only be used with [SDF icons](/help/troubleshooting/using-recolorable-images-in-mapbox-maps/).\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-halo-width\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Distance of halo to the icon outline.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-halo-blur\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Fade out the halo towards the outside.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"icon-translate\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Distance that the icon's anchor is moved from its original placement. Positive values indicate right and down, while negative values indicate left and up.\",\n \"requires\": [\n \"icon-image\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"icon-translate-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"Icons are translated relative to the map.\"\n },\n \"viewport\": {\n \"doc\": \"Icons are translated relative to the viewport.\"\n }\n },\n \"doc\": \"Controls the frame of reference for `icon-translate`.\",\n \"default\": \"map\",\n \"requires\": [\n \"icon-image\",\n \"icon-translate\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-opacity\": {\n \"type\": \"number\",\n \"doc\": \"The opacity at which the text will be drawn.\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-color\": {\n \"type\": \"color\",\n \"doc\": \"The color with which the text will be drawn.\",\n \"default\": \"#000000\",\n \"transition\": true,\n \"overridable\": true,\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-halo-color\": {\n \"type\": \"color\",\n \"default\": \"rgba(0, 0, 0, 0)\",\n \"transition\": true,\n \"doc\": \"The color of the text's halo, which helps it stand out from backgrounds.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-halo-width\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Distance of halo to the font outline. Max text halo width is 1/4 of the font-size.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-halo-blur\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"The halo's fadeout distance towards the outside.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n },\n \"data-driven styling\": {\n \"js\": \"0.33.0\",\n \"android\": \"5.0.0\",\n \"ios\": \"3.5.0\",\n \"macos\": \"0.4.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\",\n \"feature\",\n \"feature-state\"\n ]\n },\n \"property-type\": \"data-driven\"\n },\n \"text-translate\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"default\": [\n 0,\n 0\n ],\n \"transition\": true,\n \"units\": \"pixels\",\n \"doc\": \"Distance that the text's anchor is moved from its original placement. Positive values indicate right and down, while negative values indicate left and up.\",\n \"requires\": [\n \"text-field\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"text-translate-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The text is translated relative to the map.\"\n },\n \"viewport\": {\n \"doc\": \"The text is translated relative to the viewport.\"\n }\n },\n \"doc\": \"Controls the frame of reference for `text-translate`.\",\n \"default\": \"map\",\n \"requires\": [\n \"text-field\",\n \"text-translate\"\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n }\n },\n \"paint_raster\": {\n \"raster-opacity\": {\n \"type\": \"number\",\n \"doc\": \"The opacity at which the image will be drawn.\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"raster-hue-rotate\": {\n \"type\": \"number\",\n \"default\": 0,\n \"period\": 360,\n \"transition\": true,\n \"units\": \"degrees\",\n \"doc\": \"Rotates hues around the color wheel.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"raster-brightness-min\": {\n \"type\": \"number\",\n \"doc\": \"Increase or reduce the brightness of the image. The value is the minimum brightness.\",\n \"default\": 0,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"raster-brightness-max\": {\n \"type\": \"number\",\n \"doc\": \"Increase or reduce the brightness of the image. The value is the maximum brightness.\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"raster-saturation\": {\n \"type\": \"number\",\n \"doc\": \"Increase or reduce the saturation of the image.\",\n \"default\": 0,\n \"minimum\": -1,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"raster-contrast\": {\n \"type\": \"number\",\n \"doc\": \"Increase or reduce the contrast of the image.\",\n \"default\": 0,\n \"minimum\": -1,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"raster-resampling\": {\n \"type\": \"enum\",\n \"doc\": \"The resampling/interpolation method to use for overscaling, also known as texture magnification filter\",\n \"values\": {\n \"linear\": {\n \"doc\": \"(Bi)linear filtering interpolates pixel values using the weighted average of the four closest original source pixels creating a smooth but blurry look when overscaled\"\n },\n \"nearest\": {\n \"doc\": \"Nearest neighbor filtering interpolates pixel values using the nearest original source pixel creating a sharp but pixelated look when overscaled\"\n }\n },\n \"default\": \"linear\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.47.0\",\n \"android\": \"6.3.0\",\n \"ios\": \"4.2.0\",\n \"macos\": \"0.9.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"raster-fade-duration\": {\n \"type\": \"number\",\n \"default\": 300,\n \"minimum\": 0,\n \"transition\": false,\n \"units\": \"milliseconds\",\n \"doc\": \"Fade duration when a new tile is added.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n }\n },\n \"paint_hillshade\": {\n \"hillshade-illumination-direction\": {\n \"type\": \"number\",\n \"default\": 335,\n \"minimum\": 0,\n \"maximum\": 359,\n \"doc\": \"The direction of the light source used to generate the hillshading with 0 as the top of the viewport if `hillshade-illumination-anchor` is set to `viewport` and due north if `hillshade-illumination-anchor` is set to `map`.\",\n \"transition\": false,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"hillshade-illumination-anchor\": {\n \"type\": \"enum\",\n \"values\": {\n \"map\": {\n \"doc\": \"The hillshade illumination is relative to the north direction.\"\n },\n \"viewport\": {\n \"doc\": \"The hillshade illumination is relative to the top of the viewport.\"\n }\n },\n \"default\": \"viewport\",\n \"doc\": \"Direction of light source when map is rotated.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"hillshade-exaggeration\": {\n \"type\": \"number\",\n \"doc\": \"Intensity of the hillshade\",\n \"default\": 0.5,\n \"minimum\": 0,\n \"maximum\": 1,\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"hillshade-shadow-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"doc\": \"The shading color of areas that face away from the light source.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"hillshade-highlight-color\": {\n \"type\": \"color\",\n \"default\": \"#FFFFFF\",\n \"doc\": \"The shading color of areas that faces towards the light source.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"hillshade-accent-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"doc\": \"The shading color used to accentuate rugged terrain like sharp cliffs and gorges.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.43.0\",\n \"android\": \"6.0.0\",\n \"ios\": \"4.0.0\",\n \"macos\": \"0.7.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n }\n },\n \"paint_background\": {\n \"background-color\": {\n \"type\": \"color\",\n \"default\": \"#000000\",\n \"doc\": \"The color with which the background will be drawn.\",\n \"transition\": true,\n \"requires\": [\n {\n \"!\": \"background-pattern\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"background-pattern\": {\n \"type\": \"resolvedImage\",\n \"transition\": false,\n \"doc\": \"Name of image in sprite to use for drawing an image background. For seamless patterns, image width and height must be a factor of two (2, 4, 8, ..., 512). Note that zoom-dependent expressions will be evaluated only at integer zoom levels.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"background-opacity\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"doc\": \"The opacity at which the background will be drawn.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"0.10.0\",\n \"android\": \"2.0.1\",\n \"ios\": \"2.0.0\",\n \"macos\": \"0.1.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n }\n },\n \"paint_sky\": {\n \"sky-type\": {\n \"type\": \"enum\",\n \"values\": {\n \"gradient\": {\n \"doc\": \"Renders the sky with a gradient that can be configured with `sky-gradient-radius` and `sky-gradient`.\"\n },\n \"atmosphere\": {\n \"doc\": \"Renders the sky with a simulated atmospheric scattering algorithm, the sun direction can be attached to the light position or explicitly set through `sky-atmosphere-sun`.\"\n }\n },\n \"default\": \"atmosphere\",\n \"doc\": \"The type of the sky\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"sky-atmosphere-sun\": {\n \"type\": \"array\",\n \"value\": \"number\",\n \"length\": 2,\n \"units\": \"degrees\",\n \"minimum\": [0, 0],\n \"maximum\": [360, 180],\n \"transition\": false,\n \"doc\": \"Position of the sun center [a azimuthal angle, p polar angle]. The azimuthal angle indicates the position of the sun relative to 0° north, where degrees proceed clockwise. The polar angle indicates the height of the sun, where 0° is directly above, at zenith, and 90° at the horizon. When this property is ommitted, the sun center is directly inherited from the light position.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"requires\": [\n {\n \"sky-type\": \"atmosphere\"\n }\n ],\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"sky-atmosphere-sun-intensity\": {\n \"type\": \"number\",\n \"requires\": [\n {\n \"sky-type\": \"atmosphere\"\n }\n ],\n \"default\": 10,\n \"minimum\": 0,\n \"maximum\": 100,\n \"transition\": false,\n \"doc\": \"Intensity of the sun as a light source in the atmosphere (on a scale from 0 to a 100). Setting higher values will brighten up the sky.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"property-type\": \"data-constant\"\n },\n \"sky-gradient-center\": {\n \"type\": \"array\",\n \"requires\": [\n {\n \"sky-type\": \"gradient\"\n }\n ],\n \"value\": \"number\",\n \"default\": [\n 0,\n 0\n ],\n \"length\": 2,\n \"units\": \"degrees\",\n \"minimum\": [0, 0],\n \"maximum\": [360, 180],\n \"transition\": false,\n \"doc\": \"Position of the gradient center [a azimuthal angle, p polar angle]. The azimuthal angle indicates the position of the gradient center relative to 0° north, where degrees proceed clockwise. The polar angle indicates the height of the gradient center, where 0° is directly above, at zenith, and 90° at the horizon.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"sky-gradient-radius\": {\n \"type\": \"number\",\n \"requires\": [\n {\n \"sky-type\": \"gradient\"\n }\n ],\n \"default\": 90,\n \"minimum\": 0,\n \"maximum\": 180,\n \"transition\": false,\n \"doc\": \"The angular distance (measured in degrees) from `sky-gradient-center` up to which the gradient extends. A value of 180 causes the gradient to wrap around to the opposite direction from `sky-gradient-center`.\",\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"expression\": {\n \"interpolated\": false,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n },\n \"sky-gradient\": {\n \"type\": \"color\",\n \"default\": [\n \"interpolate\",\n [\n \"linear\"\n ],\n [\n \"sky-radial-progress\"\n ],\n 0.8,\n \"#87ceeb\",\n 1,\n \"white\"\n ],\n \"doc\": \"Defines a radial color gradient with which to color the sky. The color values can be interpolated with an expression using `sky-radial-progress`. The range [0, 1] for the interpolant covers a radial distance (in degrees) of [0, `sky-gradient-radius`] centered at the position specified by `sky-gradient-center`.\",\n \"transition\": false,\n \"requires\": [\n {\n \"sky-type\": \"gradient\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n },\n \"data-driven styling\": {}\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"sky-radial-progress\"\n ]\n },\n \"property-type\": \"color-ramp\"\n },\n \"sky-atmosphere-halo-color\": {\n \"type\": \"color\",\n \"default\": \"white\",\n \"doc\": \"A color applied to the atmosphere sun halo. The alpha channel describes how strongly the sun halo is represented in an atmosphere sky layer.\",\n \"transition\": false,\n \"requires\": [\n {\n \"sky-type\": \"atmosphere\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"property-type\": \"data-constant\"\n },\n \"sky-atmosphere-color\": {\n \"type\": \"color\",\n \"default\": \"white\",\n \"doc\": \"A color used to tweak the main atmospheric scattering coefficients. Using white applies the default coefficients giving the natural blue color to the atmosphere. This color affects how heavily the corresponding wavelength is represented during scattering. The alpha channel describes the density of the atmosphere, with 1 maximum density and 0 no density.\",\n \"transition\": false,\n \"requires\": [\n {\n \"sky-type\": \"atmosphere\"\n }\n ],\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"property-type\": \"data-constant\"\n },\n \"sky-opacity\": {\n \"type\": \"number\",\n \"default\": 1,\n \"minimum\": 0,\n \"maximum\": 1,\n \"doc\": \"The opacity of the entire sky layer.\",\n \"transition\": true,\n \"sdk-support\": {\n \"basic functionality\": {\n \"js\": \"2.0.0\",\n \"ios\": \"10.0.0\",\n \"android\": \"10.0.0\"\n }\n },\n \"expression\": {\n \"interpolated\": true,\n \"parameters\": [\n \"zoom\"\n ]\n },\n \"property-type\": \"data-constant\"\n }\n },\n \"transition\": {\n \"duration\": {\n \"type\": \"number\",\n \"default\": 300,\n \"minimum\": 0,\n \"units\": \"milliseconds\",\n \"doc\": \"Time allotted for transitions to complete.\"\n },\n \"delay\": {\n \"type\": \"number\",\n \"default\": 0,\n \"minimum\": 0,\n \"units\": \"milliseconds\",\n \"doc\": \"Length of time before a transition begins.\"\n }\n },\n \"property-type\": {\n \"data-driven\": {\n \"type\": \"property-type\",\n \"doc\": \"Property is interpolable and can be represented using a property expression.\"\n },\n \"color-ramp\": {\n \"type\": \"property-type\",\n \"doc\": \"Property should be specified using a color ramp from which the output color can be sampled based on a property calculation.\"\n },\n \"data-constant\": {\n \"type\": \"property-type\",\n \"doc\": \"Property is interpolable but cannot be represented using a property expression.\"\n },\n \"constant\": {\n \"type\": \"property-type\",\n \"doc\": \"Property is constant across all zoom levels and property values.\"\n }\n },\n \"promoteId\": {\n \"*\": {\n \"type\": \"string\",\n \"doc\": \"A name of a feature property to use as ID for feature state.\"\n }\n }\n}\n","// @flow\n\nimport {createExpression} from '../expression/index.js';\nimport {isFeatureConstant} from '../expression/is_constant.js';\nimport {deepUnbundle} from '../util/unbundle_jsonlint.js';\nimport latest from '../reference/latest.js';\nimport type {GlobalProperties, Feature} from '../expression/index.js';\nimport type {CanonicalTileID} from '../../source/tile_id.js';\nimport type Point from '@mapbox/point-geometry';\n\nexport type FeatureDistanceData = {bearing: [number, number], center: [number, number], scale: number};\nexport type FilterExpression = (globalProperties: GlobalProperties, feature: Feature, canonical?: CanonicalTileID, featureTileCoord?: Point, featureDistanceData?: FeatureDistanceData) => boolean;\nexport type FeatureFilter = {filter: FilterExpression, dynamicFilter?: FilterExpression, needGeometry: boolean, needFeature: boolean};\n\nexport default createFilter;\nexport {isExpressionFilter, isDynamicFilter, extractStaticFilter};\n\nfunction isExpressionFilter(filter: any): boolean {\n if (filter === true || filter === false) {\n return true;\n }\n\n if (!Array.isArray(filter) || filter.length === 0) {\n return false;\n }\n switch (filter[0]) {\n case 'has':\n return filter.length >= 2 && filter[1] !== '$id' && filter[1] !== '$type';\n\n case 'in':\n return filter.length >= 3 && (typeof filter[1] !== 'string' || Array.isArray(filter[2]));\n\n case '!in':\n case '!has':\n case 'none':\n return false;\n\n case '==':\n case '!=':\n case '>':\n case '>=':\n case '<':\n case '<=':\n return filter.length !== 3 || (Array.isArray(filter[1]) || Array.isArray(filter[2]));\n\n case 'any':\n case 'all':\n for (const f of filter.slice(1)) {\n if (!isExpressionFilter(f) && typeof f !== 'boolean') {\n return false;\n }\n }\n return true;\n\n default:\n return true;\n }\n}\n\n/**\n * Given a filter expressed as nested arrays, return a new function\n * that evaluates whether a given feature (with a .properties or .tags property)\n * passes its test.\n *\n * @private\n * @param {Array} filter mapbox gl filter\n * @param {string} layerType the type of the layer this filter will be applied to.\n * @returns {Function} filter-evaluating function\n */\nfunction createFilter(filter: any, layerType?: string = 'fill'): FeatureFilter {\n if (filter === null || filter === undefined) {\n return {filter: () => true, needGeometry: false, needFeature: false};\n }\n\n if (!isExpressionFilter(filter)) {\n filter = convertFilter(filter);\n }\n const filterExp = ((filter: any): string[] | string | boolean);\n\n let staticFilter = true;\n try {\n staticFilter = extractStaticFilter(filterExp);\n } catch (e) {\n console.warn(\n`Failed to extract static filter. Filter will continue working, but at higher memory usage and slower framerate.\nThis is most likely a bug, please report this via https://github.com/mapbox/mapbox-gl-js/issues/new?assignees=&labels=&template=Bug_report.md\nand paste the contents of this message in the report.\nThank you!\nFilter Expression:\n${JSON.stringify(filterExp, null, 2)}\n `);\n }\n\n // Compile the static component of the filter\n const filterSpec = latest[`filter_${layerType}`];\n const compiledStaticFilter = createExpression(staticFilter, filterSpec);\n\n let filterFunc = null;\n if (compiledStaticFilter.result === 'error') {\n throw new Error(compiledStaticFilter.value.map(err => `${err.key}: ${err.message}`).join(', '));\n } else {\n filterFunc = (globalProperties: GlobalProperties, feature: Feature, canonical?: CanonicalTileID) => compiledStaticFilter.value.evaluate(globalProperties, feature, {}, canonical);\n }\n\n // If the static component is not equal to the entire filter then we have a dynamic component\n // Compile the dynamic component separately\n let dynamicFilterFunc = null;\n let needFeature = null;\n if (staticFilter !== filterExp) {\n const compiledDynamicFilter = createExpression(filterExp, filterSpec);\n\n if (compiledDynamicFilter.result === 'error') {\n throw new Error(compiledDynamicFilter.value.map(err => `${err.key}: ${err.message}`).join(', '));\n } else {\n dynamicFilterFunc = (globalProperties: GlobalProperties, feature: Feature, canonical?: CanonicalTileID, featureTileCoord?: Point, featureDistanceData?: FeatureDistanceData) => compiledDynamicFilter.value.evaluate(globalProperties, feature, {}, canonical, undefined, undefined, featureTileCoord, featureDistanceData);\n needFeature = !isFeatureConstant(compiledDynamicFilter.value.expression);\n }\n }\n\n filterFunc = ((filterFunc: any): FilterExpression);\n const needGeometry = geometryNeeded(staticFilter);\n\n return {\n filter: filterFunc,\n dynamicFilter: dynamicFilterFunc ? dynamicFilterFunc : undefined,\n needGeometry,\n needFeature: !!needFeature\n };\n}\n\nfunction extractStaticFilter(filter: any): any {\n if (!isDynamicFilter(filter)) {\n return filter;\n }\n\n // Shallow copy so we can replace expressions in-place\n let result = deepUnbundle(filter);\n\n // 1. Union branches\n unionDynamicBranches(result);\n\n // 2. Collapse dynamic conditions to `true`\n result = collapseDynamicBooleanExpressions(result);\n\n return result;\n}\n\nfunction collapseDynamicBooleanExpressions(expression: any): any {\n if (!Array.isArray(expression)) {\n return expression;\n }\n\n const collapsed = collapsedExpression(expression);\n if (collapsed === true) {\n return collapsed;\n } else {\n return collapsed.map((subExpression) => collapseDynamicBooleanExpressions(subExpression));\n }\n}\n\n/**\n * Traverses the expression and replaces all instances of branching on a\n * `dynamic` conditional (such as `['pitch']` or `['distance-from-center']`)\n * into an `any` expression.\n * This ensures that all possible outcomes of a `dynamic` branch are considered\n * when evaluating the expression upfront during filtering.\n *\n * @param {Array} filter the filter expression mutated in-place.\n */\nfunction unionDynamicBranches(filter: any) {\n let isBranchingDynamically = false;\n const branches = [];\n\n if (filter[0] === 'case') {\n for (let i = 1; i < filter.length - 1; i += 2) {\n isBranchingDynamically = isBranchingDynamically || isDynamicFilter(filter[i]);\n branches.push(filter[i + 1]);\n }\n\n branches.push(filter[filter.length - 1]);\n } else if (filter[0] === 'match') {\n isBranchingDynamically = isBranchingDynamically || isDynamicFilter(filter[1]);\n\n for (let i = 2; i < filter.length - 1; i += 2) {\n branches.push(filter[i + 1]);\n }\n branches.push(filter[filter.length - 1]);\n } else if (filter[0] === 'step') {\n isBranchingDynamically = isBranchingDynamically || isDynamicFilter(filter[1]);\n\n for (let i = 1; i < filter.length - 1; i += 2) {\n branches.push(filter[i + 1]);\n }\n }\n\n if (isBranchingDynamically) {\n filter.length = 0;\n filter.push('any', ...branches);\n }\n\n // traverse and recurse into children\n for (let i = 1; i < filter.length; i++) {\n unionDynamicBranches(filter[i]);\n }\n}\n\nfunction isDynamicFilter(filter: any): boolean {\n // Base Cases\n if (!Array.isArray(filter)) {\n return false;\n }\n if (isRootExpressionDynamic(filter[0])) {\n return true;\n }\n\n for (let i = 1; i < filter.length; i++) {\n const child = filter[i];\n if (isDynamicFilter(child)) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction isRootExpressionDynamic(expression: string): boolean {\n return expression === 'pitch' ||\n expression === 'distance-from-center';\n}\n\nconst dynamicConditionExpressions = new Set([\n 'in',\n '==',\n '!=',\n '>',\n '>=',\n '<',\n '<=',\n 'to-boolean'\n]);\n\nfunction collapsedExpression(expression: any): any {\n if (dynamicConditionExpressions.has(expression[0])) {\n\n for (let i = 1; i < expression.length; i++) {\n const param = expression[i];\n if (isDynamicFilter(param)) {\n return true;\n }\n }\n }\n return expression;\n}\n\n// Comparison function to sort numbers and strings\nfunction compare(a, b) {\n return a < b ? -1 : a > b ? 1 : 0;\n}\n\nfunction geometryNeeded(filter) {\n if (!Array.isArray(filter)) return false;\n if (filter[0] === 'within') return true;\n for (let index = 1; index < filter.length; index++) {\n if (geometryNeeded(filter[index])) return true;\n }\n return false;\n}\n\nfunction convertFilter(filter: ?Array): mixed {\n if (!filter) return true;\n const op = filter[0];\n if (filter.length <= 1) return (op !== 'any');\n const converted =\n op === '==' ? convertComparisonOp(filter[1], filter[2], '==') :\n op === '!=' ? convertNegation(convertComparisonOp(filter[1], filter[2], '==')) :\n op === '<' ||\n op === '>' ||\n op === '<=' ||\n op === '>=' ? convertComparisonOp(filter[1], filter[2], op) :\n op === 'any' ? convertDisjunctionOp(filter.slice(1)) :\n op === 'all' ? ['all'].concat(filter.slice(1).map(convertFilter)) :\n op === 'none' ? ['all'].concat(filter.slice(1).map(convertFilter).map(convertNegation)) :\n op === 'in' ? convertInOp(filter[1], filter.slice(2)) :\n op === '!in' ? convertNegation(convertInOp(filter[1], filter.slice(2))) :\n op === 'has' ? convertHasOp(filter[1]) :\n op === '!has' ? convertNegation(convertHasOp(filter[1])) :\n op === 'within' ? filter :\n true;\n return converted;\n}\n\nfunction convertComparisonOp(property: string, value: any, op: string) {\n switch (property) {\n case '$type':\n return [`filter-type-${op}`, value];\n case '$id':\n return [`filter-id-${op}`, value];\n default:\n return [`filter-${op}`, property, value];\n }\n}\n\nfunction convertDisjunctionOp(filters: Array>) {\n return ['any'].concat(filters.map(convertFilter));\n}\n\nfunction convertInOp(property: string, values: Array) {\n if (values.length === 0) { return false; }\n switch (property) {\n case '$type':\n return [`filter-type-in`, ['literal', values]];\n case '$id':\n return [`filter-id-in`, ['literal', values]];\n default:\n if (values.length > 200 && !values.some(v => typeof v !== typeof values[0])) {\n return ['filter-in-large', property, ['literal', values.sort(compare)]];\n } else {\n return ['filter-in-small', property, ['literal', values]];\n }\n }\n}\n\nfunction convertHasOp(property: string) {\n switch (property) {\n case '$type':\n return true;\n case '$id':\n return [`filter-has-id`];\n default:\n return [`filter-has`, property];\n }\n}\n\nfunction convertNegation(filter: mixed) {\n return ['!', filter];\n}\n","// @flow\nexport default ['type', 'source', 'source-layer', 'minzoom', 'maxzoom', 'filter', 'layout'];\n","// @flow\n\nimport refProperties from './util/ref_properties.js';\n\nimport type {LayerSpecification} from './types.js';\n\nfunction deref(layer: LayerSpecification, parent: LayerSpecification): LayerSpecification {\n const result = {};\n\n for (const k in layer) {\n if (k !== 'ref') {\n result[k] = layer[k];\n }\n }\n\n refProperties.forEach((k) => {\n if (k in parent) {\n result[k] = (parent: any)[k];\n }\n });\n\n return ((result: any): LayerSpecification);\n}\n\n/**\n * Given an array of layers, some of which may contain `ref` properties\n * whose value is the `id` of another property, return a new array where\n * such layers have been augmented with the 'type', 'source', etc. properties\n * from the parent layer, and the `ref` property has been removed.\n *\n * The input is not modified. The output may contain references to portions\n * of the input.\n *\n * @private\n * @param {Array} layers\n * @returns {Array}\n */\nexport default function derefLayers(layers: Array): Array {\n layers = layers.slice();\n\n const map = Object.create(null);\n for (let i = 0; i < layers.length; i++) {\n map[layers[i].id] = layers[i];\n }\n\n for (let i = 0; i < layers.length; i++) {\n if ('ref' in layers[i]) {\n layers[i] = deref(layers[i], map[(layers[i]: any).ref]);\n }\n }\n\n return layers;\n}\n","var fontWeights = {\n thin: 100,\n hairline: 100,\n 'ultra-light': 200,\n 'extra-light': 200,\n light: 300,\n book: 300,\n regular: 400,\n normal: 400,\n plain: 400,\n roman: 400,\n standard: 400,\n medium: 500,\n 'semi-bold': 600,\n 'demi-bold': 600,\n bold: 700,\n 'extra-bold': 800,\n 'ultra-bold': 800,\n heavy: 900,\n black: 900,\n 'heavy-black': 900,\n fat: 900,\n poster: 900,\n 'ultra-black': 950,\n 'extra-black': 950\n};\nvar sp = ' ';\nvar italicRE = /(italic|oblique)$/i;\n\nvar fontCache = {};\n\nmodule.exports = function(fonts, size, lineHeight) {\n var cssData = fontCache[fonts];\n if (!cssData) {\n if (!Array.isArray(fonts)) {\n fonts = [fonts];\n }\n var weight = 400;\n var style = 'normal';\n var fontFamilies = [];\n var haveWeight, haveStyle;\n for (var i = 0, ii = fonts.length; i < ii; ++i) {\n var font = fonts[i];\n var parts = font.split(' ');\n var maybeWeight = parts[parts.length - 1].toLowerCase();\n if (maybeWeight == 'normal' || maybeWeight == 'italic' || maybeWeight == 'oblique') {\n style = haveStyle ? style : maybeWeight;\n haveStyle = true;\n parts.pop();\n maybeWeight = parts[parts.length - 1].toLowerCase();\n } else if (italicRE.test(maybeWeight)) {\n maybeWeight = maybeWeight.replace(italicRE, '');\n style = haveStyle ? style : parts[parts.length - 1].replace(maybeWeight, '');\n haveStyle = true;\n }\n for (var w in fontWeights) {\n var previousPart = parts.length > 1 ? parts[parts.length - 2].toLowerCase() : '';\n if (maybeWeight == w || maybeWeight == w.replace('-', '') || previousPart + '-' + maybeWeight == w) {\n weight = haveWeight ? weight : fontWeights[w];\n parts.pop();\n if (previousPart && w.startsWith(previousPart)) {\n parts.pop();\n }\n break;\n }\n }\n if (!haveWeight && typeof maybeWeight == 'number') {\n weight = maybeWeight;\n haveWeight = true;\n }\n var fontFamily = parts.join(sp)\n .replace('Klokantech Noto Sans', 'Noto Sans');\n if (fontFamily.indexOf(sp) !== -1) {\n fontFamily = '\"' + fontFamily + '\"';\n }\n fontFamilies.push(fontFamily);\n }\n // CSS font property: font-style font-weight font-size/line-height font-family\n cssData = fontCache[fonts] = [style, weight, fontFamilies];\n }\n return cssData[0] + sp + cssData[1] + sp + size + 'px' + (lineHeight ? '/' + lineHeight : '') + sp + cssData[2];\n};\n","const mapboxBaseUrl = 'https://api.mapbox.com';\n\n/**\n * Gets the path from a mapbox:// URL.\n * @param {string} url The Mapbox URL.\n * @return {string} The path.\n * @private\n */\nexport function getMapboxPath(url) {\n const startsWith = 'mapbox://';\n if (url.indexOf(startsWith) !== 0) {\n return '';\n }\n return url.slice(startsWith.length);\n}\n\n/**\n * Turns mapbox:// sprite URLs into resolvable URLs.\n * @param {string} url The sprite URL.\n * @param {string} token The access token.\n * @param {string} styleUrl The style URL.\n * @return {string} A resolvable URL.\n * @private\n */\nexport function normalizeSpriteUrl(url, token, styleUrl) {\n const mapboxPath = getMapboxPath(url);\n if (!mapboxPath) {\n return decodeURI(new URL(url, styleUrl).href);\n }\n const startsWith = 'sprites/';\n if (mapboxPath.indexOf(startsWith) !== 0) {\n throw new Error(`unexpected sprites url: ${url}`);\n }\n const sprite = mapboxPath.slice(startsWith.length);\n\n return `${mapboxBaseUrl}/styles/v1/${sprite}/sprite?access_token=${token}`;\n}\n\n/**\n * Turns mapbox:// style URLs into resolvable URLs.\n * @param {string} url The style URL.\n * @param {string} token The access token.\n * @return {string} A resolvable URL.\n * @private\n */\nexport function normalizeStyleUrl(url, token) {\n const mapboxPath = getMapboxPath(url);\n if (!mapboxPath) {\n return decodeURI(new URL(url, location.href).href);\n }\n const startsWith = 'styles/';\n if (mapboxPath.indexOf(startsWith) !== 0) {\n throw new Error(`unexpected style url: ${url}`);\n }\n const style = mapboxPath.slice(startsWith.length);\n\n return `${mapboxBaseUrl}/styles/v1/${style}?&access_token=${token}`;\n}\n\nconst mapboxSubdomains = ['a', 'b', 'c', 'd'];\n\n/**\n * Turns mapbox:// source URLs into vector tile URL templates.\n * @param {string} url The source URL.\n * @param {string} token The access token.\n * @param {string} tokenParam The access token key.\n * @param {string} styleUrl The style URL.\n * @return {Array} A vector tile template.\n * @private\n */\nexport function normalizeSourceUrl(url, token, tokenParam, styleUrl) {\n const urlObject = new URL(url, styleUrl);\n const mapboxPath = getMapboxPath(url);\n if (!mapboxPath) {\n if (!token) {\n return [decodeURI(urlObject.href)];\n }\n if (!urlObject.searchParams.has(tokenParam)) {\n urlObject.searchParams.set(tokenParam, token);\n }\n return [decodeURI(urlObject.href)];\n }\n\n if (mapboxPath === 'mapbox.satellite') {\n const sizeFactor = window.devicePixelRatio >= 1.5 ? '@2x' : '';\n return [\n `https://api.mapbox.com/v4/${mapboxPath}/{z}/{x}/{y}${sizeFactor}.webp?access_token=${token}`,\n ];\n }\n return mapboxSubdomains.map(\n (sub) =>\n `https://${sub}.tiles.mapbox.com/v4/${mapboxPath}/{z}/{x}/{y}.vector.pbf?access_token=${token}`,\n );\n}\n","import TileState from 'ol/TileState.js';\nimport {VectorTile} from 'ol';\nimport {getUid} from 'ol/util.js';\nimport {normalizeSourceUrl, normalizeStyleUrl} from './mapbox.js';\nimport {toPromise} from 'ol/functions.js';\n\n/** @typedef {'Style'|'Source'|'Sprite'|'SpriteImage'|'Tiles'|'GeoJSON'} ResourceType */\n\n/** @typedef {import(\"ol\").Map} Map */\n/** @typedef {import(\"ol/layer\").Layer} Layer */\n/** @typedef {import(\"ol/layer\").Group} LayerGroup */\n/** @typedef {import(\"ol/layer\").Vector} VectorLayer */\n/** @typedef {import(\"ol/layer\").VectorTile} VectorTileLayer */\n/** @typedef {import(\"ol/source\").Source} Source */\n\nconst functionCacheByStyleId = {};\nconst filterCacheByStyleId = {};\n\nlet styleId = 0;\nexport function getStyleId(glStyle) {\n if (!glStyle.id) {\n glStyle.id = styleId++;\n }\n return glStyle.id;\n}\n\nexport function getStyleFunctionKey(glStyle, olLayer) {\n return getStyleId(glStyle) + '.' + getUid(olLayer);\n}\n\n/**\n * @param {Object} glStyle Mapboox style object.\n * @return {Object} Function cache.\n */\nexport function getFunctionCache(glStyle) {\n let functionCache = functionCacheByStyleId[glStyle.id];\n if (!functionCache) {\n functionCache = {};\n functionCacheByStyleId[getStyleId(glStyle)] = functionCache;\n }\n return functionCache;\n}\n\nexport function clearFunctionCache() {\n for (const key in functionCacheByStyleId) {\n delete functionCacheByStyleId[key];\n }\n}\n\n/**\n * @param {Object} glStyle Mapboox style object.\n * @return {Object} Filter cache.\n */\nexport function getFilterCache(glStyle) {\n let filterCache = filterCacheByStyleId[glStyle.id];\n if (!filterCache) {\n filterCache = {};\n filterCacheByStyleId[getStyleId(glStyle)] = filterCache;\n }\n return filterCache;\n}\n\nexport function deg2rad(degrees) {\n return (degrees * Math.PI) / 180;\n}\n\nexport const defaultResolutions = (function () {\n const resolutions = [];\n for (let res = 78271.51696402048; resolutions.length <= 24; res /= 2) {\n resolutions.push(res);\n }\n return resolutions;\n})();\n\n/**\n * @param {number} width Width of the canvas.\n * @param {number} height Height of the canvas.\n * @return {HTMLCanvasElement} Canvas.\n */\nexport function createCanvas(width, height) {\n if (typeof WorkerGlobalScope !== 'undefined' && self instanceof WorkerGlobalScope && typeof OffscreenCanvas !== 'undefined') { // eslint-disable-line\n return /** @type {?} */ (new OffscreenCanvas(width, height));\n }\n const canvas = document.createElement('canvas');\n canvas.width = width;\n canvas.height = height;\n return canvas;\n}\n\nexport function getZoomForResolution(resolution, resolutions) {\n let i = 0;\n const ii = resolutions.length;\n for (; i < ii; ++i) {\n const candidate = resolutions[i];\n if (candidate < resolution && i + 1 < ii) {\n const zoomFactor = resolutions[i] / resolutions[i + 1];\n return i + Math.log(resolutions[i] / resolution) / Math.log(zoomFactor);\n }\n }\n return ii - 1;\n}\n\nexport function getResolutionForZoom(zoom, resolutions) {\n const base = Math.floor(zoom);\n const factor = Math.pow(2, zoom - base);\n return resolutions[base] / factor;\n}\n\nconst pendingRequests = {};\n/**\n * @param {ResourceType} resourceType Type of resource to load.\n * @param {string} url Url of the resource.\n * @param {Options} [options={}] Options.\n * @param {{request?: Request}} [metadata] Object to be filled with the request.\n * @return {Promise} Promise that resolves with the loaded resource\n * or rejects with the Response object.\n * @private\n */\nexport function fetchResource(resourceType, url, options = {}, metadata) {\n if (url in pendingRequests) {\n if (metadata) {\n metadata.request = pendingRequests[url][0];\n }\n return pendingRequests[url][1];\n }\n const transformedRequest = options.transformRequest\n ? options.transformRequest(url, resourceType) || url\n : url;\n const pendingRequest = toPromise(() => transformedRequest).then(\n (transformedRequest) => {\n if (!(transformedRequest instanceof Request)) {\n transformedRequest = new Request(transformedRequest);\n }\n if (!transformedRequest.headers.get('Accept')) {\n transformedRequest.headers.set('Accept', 'application/json');\n }\n if (metadata) {\n metadata.request = transformedRequest;\n }\n return fetch(transformedRequest)\n .then(function (response) {\n delete pendingRequests[url];\n return response.ok\n ? response.json()\n : Promise.reject(new Error('Error fetching source ' + url));\n })\n .catch(function (error) {\n delete pendingRequests[url];\n return Promise.reject(new Error('Error fetching source ' + url));\n });\n },\n );\n pendingRequests[url] = [transformedRequest, pendingRequest];\n return pendingRequest;\n}\n\nexport function getGlStyle(glStyleOrUrl, options) {\n if (typeof glStyleOrUrl === 'string') {\n if (glStyleOrUrl.trim().startsWith('{')) {\n try {\n const glStyle = JSON.parse(glStyleOrUrl);\n return Promise.resolve(glStyle);\n } catch (error) {\n return Promise.reject(error);\n }\n } else {\n glStyleOrUrl = normalizeStyleUrl(glStyleOrUrl, options.accessToken);\n return fetchResource('Style', glStyleOrUrl, options);\n }\n } else {\n return Promise.resolve(glStyleOrUrl);\n }\n}\n\nconst tilejsonCache = {};\n/**\n * @param {Object} glSource glStyle source object.\n * @param {string} styleUrl Style URL.\n * @param {Options} options Options.\n * @return {Promise<{tileJson: Object, tileLoadFunction: import('ol/Tile.js').LoadFunction}?>} TileJson and load function\n */\nexport function getTileJson(glSource, styleUrl, options = {}) {\n const cacheKey = [styleUrl, JSON.stringify(glSource)].toString();\n let promise = tilejsonCache[cacheKey];\n if (!promise || options.transformRequest) {\n let tileLoadFunction;\n if (options.transformRequest) {\n tileLoadFunction = (tile, src) => {\n const transformedRequest = options.transformRequest\n ? options.transformRequest(src, 'Tiles') || src\n : src;\n if (tile instanceof VectorTile) {\n tile.setLoader((extent, resolution, projection) => {\n toPromise(() => transformedRequest).then((transformedRequest) => {\n fetch(transformedRequest)\n .then((response) => response.arrayBuffer())\n .then((data) => {\n const format = tile.getFormat();\n const features = format.readFeatures(data, {\n extent: extent,\n featureProjection: projection,\n });\n // @ts-ignore\n tile.setFeatures(features);\n })\n .catch((e) => tile.setState(TileState.ERROR));\n });\n });\n } else {\n const img = tile.getImage();\n toPromise(() => transformedRequest).then((transformedRequest) => {\n if (transformedRequest instanceof Request) {\n fetch(transformedRequest)\n .then((response) => response.blob())\n .then((blob) => {\n const url = URL.createObjectURL(blob);\n img.addEventListener('load', () => URL.revokeObjectURL(url));\n img.addEventListener('error', () => URL.revokeObjectURL(url));\n img.src = url;\n })\n .catch((e) => tile.setState(TileState.ERROR));\n } else {\n img.src = transformedRequest;\n }\n });\n }\n };\n }\n const url = glSource.url;\n if (url && !glSource.tiles) {\n const normalizedSourceUrl = normalizeSourceUrl(\n url,\n options.accessToken,\n options.accessTokenParam || 'access_token',\n styleUrl || location.href,\n );\n if (url.startsWith('mapbox://')) {\n promise = Promise.resolve({\n tileJson: Object.assign({}, glSource, {\n url: undefined,\n tiles: normalizedSourceUrl,\n }),\n tileLoadFunction,\n });\n } else {\n const metadata = {};\n promise = fetchResource(\n 'Source',\n normalizedSourceUrl[0],\n options,\n metadata,\n ).then(function (tileJson) {\n tileJson.tiles = tileJson.tiles.map(function (tileUrl) {\n if (tileJson.scheme === 'tms') {\n tileUrl = tileUrl.replace('{y}', '{-y}');\n }\n return normalizeSourceUrl(\n tileUrl,\n options.accessToken,\n options.accessTokenParam || 'access_token',\n metadata.request.url,\n )[0];\n });\n return Promise.resolve({tileJson, tileLoadFunction});\n });\n }\n } else {\n glSource = Object.assign({}, glSource, {\n tiles: glSource.tiles.map(function (tileUrl) {\n if (glSource.scheme === 'tms') {\n tileUrl = tileUrl.replace('{y}', '{-y}');\n }\n return normalizeSourceUrl(\n tileUrl,\n options.accessToken,\n options.accessTokenParam || 'access_token',\n styleUrl || location.href,\n )[0];\n }),\n });\n promise = Promise.resolve({\n tileJson: Object.assign({}, glSource),\n tileLoadFunction,\n });\n }\n tilejsonCache[cacheKey] = promise;\n }\n return promise;\n}\n\n/**\n * @param {HTMLImageElement|HTMLCanvasElement} spriteImage Sprite image id.\n * @param {{x: number, y: number, width: number, height: number, pixelRatio: number}} spriteImageData Sprite image data.\n * @param {number} haloWidth Halo width.\n * @param {{r: number, g: number, b: number, a: number}} haloColor Halo color.\n * @return {HTMLCanvasElement} Canvas element with the halo.\n */\nexport function drawIconHalo(\n spriteImage,\n spriteImageData,\n haloWidth,\n haloColor,\n) {\n const imgSize = [\n 2 * haloWidth * spriteImageData.pixelRatio + spriteImageData.width,\n 2 * haloWidth * spriteImageData.pixelRatio + spriteImageData.height,\n ];\n const imageCanvas = createCanvas(imgSize[0], imgSize[1]);\n const imageContext = imageCanvas.getContext('2d');\n imageContext.drawImage(\n spriteImage,\n spriteImageData.x,\n spriteImageData.y,\n spriteImageData.width,\n spriteImageData.height,\n haloWidth * spriteImageData.pixelRatio,\n haloWidth * spriteImageData.pixelRatio,\n spriteImageData.width,\n spriteImageData.height,\n );\n const imageData = imageContext.getImageData(0, 0, imgSize[0], imgSize[1]);\n imageContext.globalCompositeOperation = 'destination-over';\n imageContext.fillStyle = `rgba(${haloColor.r * 255},${haloColor.g * 255},${\n haloColor.b * 255\n },${haloColor.a})`;\n const data = imageData.data;\n for (let i = 0, ii = imageData.width; i < ii; ++i) {\n for (let j = 0, jj = imageData.height; j < jj; ++j) {\n const index = (j * ii + i) * 4;\n const alpha = data[index + 3];\n if (alpha > 0) {\n imageContext.arc(\n i,\n j,\n haloWidth * spriteImageData.pixelRatio,\n 0,\n 2 * Math.PI,\n );\n }\n }\n }\n imageContext.fill();\n return imageCanvas;\n}\n\nfunction smoothstep(min, max, value) {\n const x = Math.max(0, Math.min(1, (value - min) / (max - min)));\n return x * x * (3 - 2 * x);\n}\n\n/**\n * @param {HTMLImageElement} image SDF image\n * @param {{x: number, y: number, width: number, height: number}} area Area to unSDF\n * @param {{r: number, g: number, b: number, a: number}} color Color to use\n * @return {HTMLCanvasElement} Regular image\n */\nexport function drawSDF(image, area, color) {\n const imageCanvas = createCanvas(area.width, area.height);\n const imageContext = imageCanvas.getContext('2d');\n imageContext.drawImage(\n image,\n area.x,\n area.y,\n area.width,\n area.height,\n 0,\n 0,\n area.width,\n area.height,\n );\n const imageData = imageContext.getImageData(0, 0, area.width, area.height);\n const data = imageData.data;\n for (let i = 0, ii = imageData.width; i < ii; ++i) {\n for (let j = 0, jj = imageData.height; j < jj; ++j) {\n const index = (j * ii + i) * 4;\n const dist = data[index + 3] / 255;\n\n const buffer = 0.75;\n const gamma = 0.1;\n\n const alpha = smoothstep(buffer - gamma, buffer + gamma, dist);\n if (alpha > 0) {\n data[index + 0] = Math.round(255 * color.r * alpha);\n data[index + 1] = Math.round(255 * color.g * alpha);\n data[index + 2] = Math.round(255 * color.b * alpha);\n data[index + 3] = Math.round(255 * alpha);\n } else {\n data[index + 3] = 0;\n }\n }\n }\n imageContext.putImageData(imageData, 0, 0);\n return imageCanvas;\n}\n\n/**\n * @typedef {import(\"./apply.js\").Options} Options\n * @private\n */\n","import mb2css from 'mapbox-to-css-font';\nimport {checkedFonts, registerFont} from 'ol/render/canvas.js';\nimport {createCanvas} from './util.js';\n\nconst hairSpacePool = Array(256).join('\\u200A');\nexport function applyLetterSpacing(text, letterSpacing) {\n if (letterSpacing >= 0.05) {\n let textWithLetterSpacing = '';\n const lines = text.split('\\n');\n const joinSpaceString = hairSpacePool.slice(\n 0,\n Math.round(letterSpacing / 0.1),\n );\n for (let l = 0, ll = lines.length; l < ll; ++l) {\n if (l > 0) {\n textWithLetterSpacing += '\\n';\n }\n textWithLetterSpacing += lines[l].split('').join(joinSpaceString);\n }\n return textWithLetterSpacing;\n }\n return text;\n}\n\nlet measureContext;\nfunction getMeasureContext() {\n if (!measureContext) {\n measureContext = createCanvas(1, 1).getContext('2d');\n }\n return measureContext;\n}\n\nfunction measureText(text, letterSpacing) {\n return (\n getMeasureContext().measureText(text).width +\n (text.length - 1) * letterSpacing\n );\n}\n\nconst measureCache = {};\nexport function wrapText(text, font, em, letterSpacing) {\n if (text.indexOf('\\n') !== -1) {\n const hardLines = text.split('\\n');\n const lines = [];\n for (let i = 0, ii = hardLines.length; i < ii; ++i) {\n lines.push(wrapText(hardLines[i], font, em, letterSpacing));\n }\n return lines.join('\\n');\n }\n const key = em + ',' + font + ',' + text + ',' + letterSpacing;\n let wrappedText = measureCache[key];\n if (!wrappedText) {\n const words = text.split(' ');\n if (words.length > 1) {\n const ctx = getMeasureContext();\n ctx.font = font;\n const oneEm = ctx.measureText('M').width;\n const maxWidth = oneEm * em;\n let line = '';\n const lines = [];\n // Pass 1 - wrap lines to not exceed maxWidth\n for (let i = 0, ii = words.length; i < ii; ++i) {\n const word = words[i];\n const testLine = line + (line ? ' ' : '') + word;\n if (measureText(testLine, letterSpacing) <= maxWidth) {\n line = testLine;\n } else {\n if (line) {\n lines.push(line);\n }\n line = word;\n }\n }\n if (line) {\n lines.push(line);\n }\n // Pass 2 - add lines with a width of less than 30% of maxWidth to the previous or next line\n for (let i = 0, ii = lines.length; i < ii && ii > 1; ++i) {\n const line = lines[i];\n if (measureText(line, letterSpacing) < maxWidth * 0.35) {\n const prevWidth =\n i > 0 ? measureText(lines[i - 1], letterSpacing) : Infinity;\n const nextWidth =\n i < ii - 1 ? measureText(lines[i + 1], letterSpacing) : Infinity;\n lines.splice(i, 1);\n ii -= 1;\n if (prevWidth < nextWidth) {\n lines[i - 1] += ' ' + line;\n i -= 1;\n } else {\n lines[i] = line + ' ' + lines[i];\n }\n }\n }\n // Pass 3 - try to fill 80% of maxWidth for each line\n for (let i = 0, ii = lines.length - 1; i < ii; ++i) {\n const line = lines[i];\n const next = lines[i + 1];\n if (\n measureText(line, letterSpacing) > maxWidth * 0.7 &&\n measureText(next, letterSpacing) < maxWidth * 0.6\n ) {\n const lineWords = line.split(' ');\n const lastWord = lineWords.pop();\n if (measureText(lastWord, letterSpacing) < maxWidth * 0.2) {\n lines[i] = lineWords.join(' ');\n lines[i + 1] = lastWord + ' ' + next;\n }\n ii -= 1;\n }\n }\n wrappedText = lines.join('\\n');\n } else {\n wrappedText = text;\n }\n wrappedText = applyLetterSpacing(wrappedText, letterSpacing);\n measureCache[key] = wrappedText;\n }\n return wrappedText;\n}\n\nconst fontFamilyRegEx = /font-family: ?([^;]*);/;\nconst stripQuotesRegEx = /(\"|')/g;\nlet loadedFontFamilies;\nfunction hasFontFamily(family) {\n if (!loadedFontFamilies) {\n loadedFontFamilies = {};\n const styleSheets = document.styleSheets;\n for (let i = 0, ii = styleSheets.length; i < ii; ++i) {\n const styleSheet = /** @type {CSSStyleSheet} */ (styleSheets[i]);\n try {\n const cssRules = styleSheet.rules || styleSheet.cssRules;\n if (cssRules) {\n for (let j = 0, jj = cssRules.length; j < jj; ++j) {\n const cssRule = cssRules[j];\n if (cssRule.type == 5) {\n const match = cssRule.cssText.match(fontFamilyRegEx);\n loadedFontFamilies[match[1].replace(stripQuotesRegEx, '')] = true;\n }\n }\n }\n } catch (e) {\n // empty catch block\n }\n }\n }\n return family in loadedFontFamilies;\n}\n\nconst processedFontFamilies = {};\n\n/**\n * @param {Array} fonts Fonts.\n * @param {string} [templateUrl] Template URL.\n * @return {Array} Processed fonts.\n * @private\n */\nexport function getFonts(\n fonts,\n templateUrl = 'https://cdn.jsdelivr.net/npm/@fontsource/{font-family}/{fontweight}{-fontstyle}.css',\n) {\n const fontsKey = fonts.toString();\n if (fontsKey in processedFontFamilies) {\n return processedFontFamilies[fontsKey];\n }\n const fontDescriptions = [];\n for (let i = 0, ii = fonts.length; i < ii; ++i) {\n fonts[i] = fonts[i].replace('Arial Unicode MS', 'Arial');\n const font = fonts[i];\n const cssFont = mb2css(font, 1);\n registerFont(cssFont);\n const parts = cssFont.split(' ');\n fontDescriptions.push([\n parts.slice(3).join(' ').replace(/\"/g, ''),\n parts[1],\n parts[0],\n ]);\n }\n for (let i = 0, ii = fontDescriptions.length; i < ii; ++i) {\n const fontDescription = fontDescriptions[i];\n const family = fontDescription[0];\n if (!hasFontFamily(family)) {\n if (\n checkedFonts.get(\n `${fontDescription[2]}\\n${fontDescription[1]} \\n${family}`,\n ) !== 100\n ) {\n const fontUrl = templateUrl\n .replace('{font-family}', family.replace(/ /g, '-').toLowerCase())\n .replace('{Font+Family}', family.replace(/ /g, '+'))\n .replace('{fontweight}', fontDescription[1])\n .replace(\n '{-fontstyle}',\n fontDescription[2].replace('normal', '').replace(/(.+)/, '-$1'),\n )\n .replace('{fontstyle}', fontDescription[2]);\n if (!document.querySelector('link[href=\"' + fontUrl + '\"]')) {\n const markup = document.createElement('link');\n markup.href = fontUrl;\n markup.rel = 'stylesheet';\n document.head.appendChild(markup);\n }\n }\n }\n }\n processedFontFamilies[fontsKey] = fonts;\n return fonts;\n}\n","/*\nol-mapbox-style - Use Mapbox/MapLibre Style objects with OpenLayers\nCopyright 2016-present ol-mapbox-style contributors\nLicense: https://raw.githubusercontent.com/openlayers/ol-mapbox-style/master/LICENSE\n*/\n\nimport Circle from 'ol/style/Circle.js';\nimport Fill from 'ol/style/Fill.js';\nimport Icon from 'ol/style/Icon.js';\nimport RenderFeature from 'ol/render/Feature.js';\nimport Stroke from 'ol/style/Stroke.js';\nimport Style from 'ol/style/Style.js';\nimport Text from 'ol/style/Text.js';\nimport {toPromise} from 'ol/functions.js';\n\nimport Color from '@mapbox/mapbox-gl-style-spec/util/color.js';\nimport convertFunction from '@mapbox/mapbox-gl-style-spec/function/convert.js';\nimport createFilter from '@mapbox/mapbox-gl-style-spec/feature_filter/index.js';\nimport derefLayers from '@mapbox/mapbox-gl-style-spec/deref.js';\nimport mb2css from 'mapbox-to-css-font';\nimport spec from '@mapbox/mapbox-gl-style-spec/reference/v8.json';\nimport {applyLetterSpacing, wrapText} from './text.js';\nimport {\n clearFunctionCache,\n createCanvas,\n defaultResolutions,\n deg2rad,\n drawIconHalo,\n drawSDF,\n getFilterCache,\n getFunctionCache,\n getStyleFunctionKey,\n getZoomForResolution,\n} from './util.js';\nimport {\n createPropertyExpression,\n isExpression,\n} from '@mapbox/mapbox-gl-style-spec/expression/index.js';\nimport {isFunction} from '@mapbox/mapbox-gl-style-spec/function/index.js';\n\n/**\n * @typedef {import(\"ol/layer/Vector\").default} VectorLayer\n * @typedef {import(\"ol/layer/VectorTile\").default} VectorTileLayer\n * @typedef {import(\"ol/style/Style\").StyleFunction} StyleFunction\n * @typedef {import('./util.js').ResourceType} ResourceType\n */\n\nconst types = {\n 'Point': 1,\n 'MultiPoint': 1,\n 'LineString': 2,\n 'MultiLineString': 2,\n 'Polygon': 3,\n 'MultiPolygon': 3,\n};\nconst anchor = {\n 'center': [0.5, 0.5],\n 'left': [0, 0.5],\n 'right': [1, 0.5],\n 'top': [0.5, 0],\n 'bottom': [0.5, 1],\n 'top-left': [0, 0],\n 'top-right': [1, 0],\n 'bottom-left': [0, 1],\n 'bottom-right': [1, 1],\n};\n\nconst expressionData = function (rawExpression, propertySpec) {\n const compiledExpression = createPropertyExpression(\n rawExpression,\n propertySpec,\n );\n if (compiledExpression.result === 'error') {\n throw new Error(\n compiledExpression.value\n .map((err) => `${err.key}: ${err.message}`)\n .join(', '),\n );\n }\n return compiledExpression.value;\n};\n\nconst emptyObj = {};\nconst zoomObj = {zoom: 0};\nlet renderFeatureCoordinates, renderFeature;\n\n/**\n * @private\n * @param {Object} layer Gl object layer.\n * @param {string} layoutOrPaint 'layout' or 'paint'.\n * @param {string} property Feature property.\n * @param {number} zoom Zoom.\n * @param {Object} feature Gl feature.\n * @param {Object} [functionCache] Function cache.\n * @param {Object} [featureState] Feature state.\n * @return {?} Value.\n */\nexport function getValue(\n layer,\n layoutOrPaint,\n property,\n zoom,\n feature,\n functionCache,\n featureState,\n) {\n const layerId = layer.id;\n if (!functionCache) {\n functionCache = {};\n console.warn('No functionCache provided to getValue()'); //eslint-disable-line no-console\n }\n if (!functionCache[layerId]) {\n functionCache[layerId] = {};\n }\n const functions = functionCache[layerId];\n if (!functions[property]) {\n let value = (layer[layoutOrPaint] || emptyObj)[property];\n const propertySpec = spec[`${layoutOrPaint}_${layer.type}`][property];\n if (value === undefined) {\n value = propertySpec.default;\n }\n let isExpr = isExpression(value);\n if (!isExpr && isFunction(value)) {\n value = convertFunction(value, propertySpec);\n isExpr = true;\n }\n if (isExpr) {\n const compiledExpression = expressionData(value, propertySpec);\n functions[property] =\n compiledExpression.evaluate.bind(compiledExpression);\n } else {\n if (propertySpec.type == 'color') {\n value = Color.parse(value);\n }\n functions[property] = function () {\n return value;\n };\n }\n }\n zoomObj.zoom = zoom;\n return functions[property](zoomObj, feature, featureState);\n}\n\n/**\n * @private\n * @param {Object} layer Gl object layer.\n * @param {number} zoom Zoom.\n * @param {Object} feature Gl feature.\n * @param {\"icon\"|\"text\"} prefix Style property prefix.\n * @param {Object} [functionCache] Function cache.\n * @return {\"declutter\"|\"obstacle\"|\"none\"} Value.\n */\nfunction getDeclutterMode(layer, zoom, feature, prefix, functionCache) {\n const allowOverlap = getValue(\n layer,\n 'layout',\n `${prefix}-allow-overlap`,\n zoom,\n feature,\n functionCache,\n );\n if (!allowOverlap) {\n return 'declutter';\n }\n const ignorePlacement = getValue(\n layer,\n 'layout',\n `${prefix}-ignore-placement`,\n zoom,\n feature,\n functionCache,\n );\n if (!ignorePlacement) {\n return 'obstacle';\n }\n return 'none';\n}\n\n/**\n * @private\n * @param {string} layerId Layer id.\n * @param {?} filter Filter.\n * @param {Object} feature Feature.\n * @param {number} zoom Zoom.\n * @param {Object} [filterCache] Filter cache.\n * @return {boolean} Filter result.\n */\nfunction evaluateFilter(layerId, filter, feature, zoom, filterCache) {\n if (!filterCache) {\n console.warn('No filterCache provided to evaluateFilter()'); //eslint-disable-line no-console\n }\n if (!(layerId in filterCache)) {\n filterCache[layerId] = createFilter(filter).filter;\n }\n zoomObj.zoom = zoom;\n return filterCache[layerId](zoomObj, feature);\n}\n\nlet renderTransparentEnabled = false;\n\n/**\n * Configure whether features with a transparent style should be rendered. When\n * set to `true`, it will be possible to hit detect content that is not visible,\n * like transparent fills of polygons, using `ol/layer/Layer#getFeatures()` or\n * `ol/Map#getFeaturesAtPixel()`\n * @param {boolean} enabled Rendering of transparent elements is enabled.\n * Default is `false`.\n */\nexport function renderTransparent(enabled) {\n if (enabled !== renderTransparentEnabled) {\n clearFunctionCache();\n renderTransparentEnabled = enabled;\n }\n}\n\n/**\n * @private\n * @param {?} color Color.\n * @param {number} [opacity] Opacity.\n * @return {string} Color.\n */\nfunction colorWithOpacity(color, opacity) {\n if (color) {\n if (!renderTransparentEnabled && (color.a === 0 || opacity === 0)) {\n return undefined;\n }\n const a = color.a;\n opacity = opacity === undefined ? 1 : opacity;\n return a === 0\n ? 'transparent'\n : 'rgba(' +\n Math.round((color.r * 255) / a) +\n ',' +\n Math.round((color.g * 255) / a) +\n ',' +\n Math.round((color.b * 255) / a) +\n ',' +\n a * opacity +\n ')';\n }\n return color;\n}\n\nconst templateRegEx = /\\{[^{}}]*\\}/g;\n\n/**\n * @private\n * @param {string} text Text.\n * @param {Object} properties Properties.\n * @return {string} Text.\n */\nfunction fromTemplate(text, properties) {\n return text.replace(templateRegEx, function (match) {\n return properties[match.slice(1, -1)] || '';\n });\n}\n\nlet recordLayer = false;\n\n/**\n * Turns recording of the Mapbox/MapLibre Style's `layer` on and off. When turned on,\n * the layer that a rendered feature belongs to will be set as the feature's\n * `mapbox-layer` property.\n * @param {boolean} record Recording of the style layer is on.\n */\nexport function recordStyleLayer(record = false) {\n recordLayer = record;\n}\n\nexport const styleFunctionArgs = {};\n\n/**\n * Creates a style function from the `glStyle` object for all layers that use\n * the specified `source`, which needs to be a `\"type\": \"vector\"` or\n * `\"type\": \"geojson\"` source and applies it to the specified OpenLayers layer.\n *\n * Two additional properties will be set on the provided layer:\n *\n * * `mapbox-source`: The `id` of the Mapbox/MapLibre Style document's source that the\n * OpenLayers layer was created from. Usually `apply()` creates one\n * OpenLayers layer per Mapbox/MapLibre Style source, unless the layer stack has\n * layers from different sources in between.\n * * `mapbox-layers`: The `id`s of the Mapbox/MapLibre Style document's layers that are\n * included in the OpenLayers layer.\n *\n * This function also works in a web worker. In worker mode, the main thread needs\n * to listen to messages from the worker and respond with another message to make\n * sure that sprite image loading works:\n *\n * ```js\n * worker.addEventListener('message', event => {\n * if (event.data.action === 'loadImage') {\n * const image = new Image();\n * image.crossOrigin = 'anonymous';\n * image.addEventListener('load', function() {\n * createImageBitmap(image, 0, 0, image.width, image.height).then(imageBitmap => {\n * worker.postMessage({\n * action: 'imageLoaded',\n * image: imageBitmap,\n * src: event.data.src\n * }, [imageBitmap]);\n * });\n * });\n * image.src = event.data.src;\n * }\n * });\n * ```\n *\n * @param {VectorLayer|VectorTileLayer} olLayer OpenLayers layer to\n * apply the style to. In addition to the style, the layer will get two\n * properties: `mapbox-source` will be the `id` of the `glStyle`'s source used\n * for the layer, and `mapbox-layers` will be an array of the `id`s of the\n * `glStyle`'s layers.\n * @param {string|Object} glStyle Mapbox/MapLibre Style object.\n * @param {string|Array} sourceOrLayers `source` key or an array of layer `id`s\n * from the Mapbox/MapLibre Style object. When a `source` key is provided, all layers for\n * the specified source will be included in the style function. When layer `id`s\n * are provided, they must be from layers that use the same source.\n * @param {Array} resolutions\n * Resolutions for mapping resolution to zoom level.\n * @param {Object} spriteData Sprite data from the url specified in\n * the Mapbox/MapLibre Style object's `sprite` property. Only required if a `sprite`\n * property is specified in the Mapbox/MapLibre Style object.\n * @param {string|Request|Promise} spriteImageUrl Sprite image url for the sprite\n * specified in the Mapbox/MapLibre Style object's `sprite` property. Only required if a\n * `sprite` property is specified in the Mapbox/MapLibre Style object.\n * @param {function(Array, string=):Array} getFonts Function that\n * receives a font stack and the url template from the GL style's `metadata['ol:webfonts']`\n * property (if set) as arguments, and returns a (modified) font stack that\n * is available. Font names are the names used in the Mapbox/MapLibre Style object. If\n * not provided, the font stack will be used as-is. This function can also be\n * used for loading web fonts.\n * @param {function(VectorLayer|VectorTileLayer, string):HTMLImageElement|HTMLCanvasElement|string|undefined} [getImage=undefined]\n * Function that returns an image or a URL for an image name. If the result is an HTMLImageElement, it must already be\n * loaded. The layer can be used to call layer.changed() when the loading and processing of the image has finished.\n * This function can be used for icons not in the sprite or to override sprite icons.\n * @return {StyleFunction} Style function for use in\n * `ol.layer.Vector` or `ol.layer.VectorTile`.\n */\nexport function stylefunction(\n olLayer,\n glStyle,\n sourceOrLayers,\n resolutions = defaultResolutions,\n spriteData = undefined,\n spriteImageUrl = undefined,\n getFonts = undefined,\n getImage = undefined,\n) {\n if (typeof glStyle == 'string') {\n glStyle = JSON.parse(glStyle);\n }\n if (glStyle.version != 8) {\n throw new Error('glStyle version 8 required.');\n }\n styleFunctionArgs[getStyleFunctionKey(glStyle, olLayer)] =\n Array.from(arguments);\n\n let spriteImage, spriteImageSize;\n let spriteImageUnSDFed;\n\n if (spriteImageUrl) {\n if (typeof Image !== 'undefined') {\n const img = new Image();\n let blobUrl;\n toPromise(() => spriteImageUrl).then((spriteImageUrl) => {\n if (spriteImageUrl instanceof Request) {\n fetch(spriteImageUrl)\n .then((response) => response.blob())\n .then((blob) => {\n blobUrl = URL.createObjectURL(blob);\n img.src = blobUrl;\n })\n .catch(() => {});\n } else {\n img.crossOrigin = 'anonymous';\n img.src = spriteImageUrl;\n if (blobUrl) {\n URL.revokeObjectURL(blobUrl);\n }\n }\n });\n img.onload = function () {\n spriteImage = img;\n spriteImageSize = [img.width, img.height];\n olLayer.changed();\n img.onload = null;\n };\n } else if (typeof WorkerGlobalScope !== 'undefined' && self instanceof WorkerGlobalScope) { //eslint-disable-line\n const worker = /** @type {*} */ (self);\n // Main thread needs to handle 'loadImage' and dispatch 'imageLoaded'\n worker.postMessage({\n action: 'loadImage',\n src: spriteImageUrl,\n });\n worker.addEventListener('message', function handler(event) {\n if (\n event.data.action === 'imageLoaded' &&\n event.data.src === spriteImageUrl\n ) {\n spriteImage = event.data.image;\n spriteImageSize = [spriteImage.width, spriteImage.height];\n }\n });\n }\n }\n\n const allLayers = derefLayers(glStyle.layers);\n\n const layersBySourceLayer = {};\n const mapboxLayers = [];\n\n const iconImageCache = {};\n const patternCache = {};\n const functionCache = getFunctionCache(glStyle);\n const filterCache = getFilterCache(glStyle);\n\n let mapboxSource;\n for (let i = 0, ii = allLayers.length; i < ii; ++i) {\n const layer = allLayers[i];\n const layerId = layer.id;\n if (\n (typeof sourceOrLayers == 'string' && layer.source == sourceOrLayers) ||\n (Array.isArray(sourceOrLayers) && sourceOrLayers.indexOf(layerId) !== -1)\n ) {\n const sourceLayer = layer['source-layer'];\n if (!mapboxSource) {\n mapboxSource = layer.source;\n const source = glStyle.sources[mapboxSource];\n if (!source) {\n throw new Error(`Source \"${mapboxSource}\" is not defined`);\n }\n const type = source.type;\n if (type !== 'vector' && type !== 'geojson') {\n throw new Error(\n `Source \"${mapboxSource}\" is not of type \"vector\" or \"geojson\", but \"${type}\"`,\n );\n }\n } else if (layer.source !== mapboxSource) {\n throw new Error(\n `Layer \"${layerId}\" does not use source \"${mapboxSource}`,\n );\n }\n let layers = layersBySourceLayer[sourceLayer];\n if (!layers) {\n layers = [];\n layersBySourceLayer[sourceLayer] = layers;\n }\n layers.push({\n layer: layer,\n index: i,\n });\n mapboxLayers.push(layerId);\n }\n }\n\n const textHalo = new Stroke();\n const textColor = new Fill();\n\n const styles = [];\n\n /**\n * @param {import(\"ol/Feature\").default|import(\"ol/render/Feature\").default} feature Feature.\n * @param {number} resolution Resolution.\n * @param {string} [onlyLayer] Calculate style for this layer only.\n * @return {Array} Style.\n */\n const styleFunction = function (feature, resolution, onlyLayer) {\n const properties = feature.getProperties();\n const layers = layersBySourceLayer[properties.layer];\n if (!layers) {\n return undefined;\n }\n let zoom = resolutions.indexOf(resolution);\n if (zoom == -1) {\n zoom = getZoomForResolution(resolution, resolutions);\n }\n const type = types[feature.getGeometry().getType()];\n const f = {\n id: feature.getId(),\n properties: properties,\n type: type,\n };\n const featureState = olLayer.get('mapbox-featurestate')[feature.getId()];\n let stylesLength = -1;\n let featureBelongsToLayer;\n for (let i = 0, ii = layers.length; i < ii; ++i) {\n const layerData = layers[i];\n const layer = layerData.layer;\n const layerId = layer.id;\n if (onlyLayer !== undefined && onlyLayer !== layerId) {\n continue;\n }\n\n const layout = layer.layout || emptyObj;\n const paint = layer.paint || emptyObj;\n if (\n layout.visibility === 'none' ||\n ('minzoom' in layer && zoom < layer.minzoom) ||\n ('maxzoom' in layer && zoom >= layer.maxzoom)\n ) {\n continue;\n }\n const filter = layer.filter;\n if (!filter || evaluateFilter(layerId, filter, f, zoom, filterCache)) {\n featureBelongsToLayer = layer;\n let color, opacity, fill, stroke, strokeColor, style;\n const index = layerData.index;\n if (\n type == 3 &&\n (layer.type == 'fill' || layer.type == 'fill-extrusion')\n ) {\n opacity = getValue(\n layer,\n 'paint',\n layer.type + '-opacity',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (layer.type + '-pattern' in paint) {\n const fillIcon = getValue(\n layer,\n 'paint',\n layer.type + '-pattern',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (fillIcon) {\n const icon =\n typeof fillIcon === 'string'\n ? fromTemplate(fillIcon, properties)\n : fillIcon.toString();\n if (spriteImage && spriteData && spriteData[icon]) {\n ++stylesLength;\n style = styles[stylesLength];\n if (\n !style ||\n !style.getFill() ||\n style.getStroke() ||\n style.getText()\n ) {\n style = new Style({\n fill: new Fill(),\n });\n styles[stylesLength] = style;\n }\n fill = style.getFill();\n style.setZIndex(index);\n const icon_cache_key = icon + '.' + opacity;\n let pattern = patternCache[icon_cache_key];\n if (!pattern) {\n const spriteImageData = spriteData[icon];\n const canvas = createCanvas(\n spriteImageData.width,\n spriteImageData.height,\n );\n const ctx = /** @type {CanvasRenderingContext2D} */ (\n canvas.getContext('2d')\n );\n ctx.globalAlpha = opacity;\n ctx.drawImage(\n spriteImage,\n spriteImageData.x,\n spriteImageData.y,\n spriteImageData.width,\n spriteImageData.height,\n 0,\n 0,\n spriteImageData.width,\n spriteImageData.height,\n );\n pattern = ctx.createPattern(canvas, 'repeat');\n patternCache[icon_cache_key] = pattern;\n }\n fill.setColor(pattern);\n }\n }\n } else {\n color = colorWithOpacity(\n getValue(\n layer,\n 'paint',\n layer.type + '-color',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n opacity,\n );\n if (layer.type + '-outline-color' in paint) {\n strokeColor = colorWithOpacity(\n getValue(\n layer,\n 'paint',\n layer.type + '-outline-color',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n opacity,\n );\n }\n if (!strokeColor) {\n strokeColor = color;\n }\n if (color || strokeColor) {\n ++stylesLength;\n style = styles[stylesLength];\n if (\n !style ||\n (color && !style.getFill()) ||\n (!color && style.getFill()) ||\n (strokeColor && !style.getStroke()) ||\n (!strokeColor && style.getStroke()) ||\n style.getText()\n ) {\n style = new Style({\n fill: color ? new Fill() : undefined,\n stroke: strokeColor ? new Stroke() : undefined,\n });\n styles[stylesLength] = style;\n }\n if (color) {\n fill = style.getFill();\n fill.setColor(color);\n }\n if (strokeColor) {\n stroke = style.getStroke();\n stroke.setColor(strokeColor);\n stroke.setWidth(0.5);\n }\n style.setZIndex(index);\n }\n }\n }\n if (type != 1 && layer.type == 'line') {\n if (!('line-pattern' in paint)) {\n color = colorWithOpacity(\n getValue(\n layer,\n 'paint',\n 'line-color',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n getValue(\n layer,\n 'paint',\n 'line-opacity',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n } else {\n color = undefined;\n }\n const width = getValue(\n layer,\n 'paint',\n 'line-width',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (color && width > 0) {\n ++stylesLength;\n style = styles[stylesLength];\n if (\n !style ||\n !style.getStroke() ||\n style.getFill() ||\n style.getText()\n ) {\n style = new Style({\n stroke: new Stroke(),\n });\n styles[stylesLength] = style;\n }\n stroke = style.getStroke();\n stroke.setLineCap(\n getValue(\n layer,\n 'layout',\n 'line-cap',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n stroke.setLineJoin(\n getValue(\n layer,\n 'layout',\n 'line-join',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n stroke.setMiterLimit(\n getValue(\n layer,\n 'layout',\n 'line-miter-limit',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n stroke.setColor(color);\n stroke.setWidth(width);\n stroke.setLineDash(\n paint['line-dasharray']\n ? getValue(\n layer,\n 'paint',\n 'line-dasharray',\n zoom,\n f,\n functionCache,\n featureState,\n ).map(function (x) {\n return x * width;\n })\n : null,\n );\n style.setZIndex(index);\n }\n }\n\n let hasImage = false;\n let text = null;\n let placementAngle = 0;\n let icon, iconImg, skipLabel;\n if ((type == 1 || type == 2) && 'icon-image' in layout) {\n const iconImage = getValue(\n layer,\n 'layout',\n 'icon-image',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (iconImage) {\n icon =\n typeof iconImage === 'string'\n ? fromTemplate(iconImage, properties)\n : iconImage.toString();\n let styleGeom = undefined;\n const imageElement = getImage ? getImage(olLayer, icon) : undefined;\n if (\n (spriteImage && spriteData && spriteData[icon]) ||\n imageElement\n ) {\n const iconRotationAlignment = getValue(\n layer,\n 'layout',\n 'icon-rotation-alignment',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (type == 2) {\n const geom = /** @type {*} */ (feature.getGeometry());\n // ol package and ol-debug.js only\n if (geom.getFlatMidpoint || geom.getFlatMidpoints) {\n const extent = geom.getExtent();\n const size = Math.sqrt(\n Math.max(\n Math.pow((extent[2] - extent[0]) / resolution, 2),\n Math.pow((extent[3] - extent[1]) / resolution, 2),\n ),\n );\n if (size > 150) {\n //FIXME Do not hard-code a size of 150\n const midpoint =\n geom.getType() === 'MultiLineString'\n ? geom.getFlatMidpoints()\n : geom.getFlatMidpoint();\n if (!renderFeature) {\n renderFeatureCoordinates = [NaN, NaN];\n renderFeature = new RenderFeature(\n 'Point',\n renderFeatureCoordinates,\n [],\n 2,\n {},\n undefined,\n );\n }\n styleGeom = renderFeature;\n renderFeatureCoordinates[0] = midpoint[0];\n renderFeatureCoordinates[1] = midpoint[1];\n const placement = getValue(\n layer,\n 'layout',\n 'symbol-placement',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (\n placement === 'line' &&\n iconRotationAlignment === 'map'\n ) {\n const stride = geom.getStride();\n const coordinates = geom.getFlatCoordinates();\n for (\n let i = 0, ii = coordinates.length - stride;\n i < ii;\n i += stride\n ) {\n const x1 = coordinates[i];\n const y1 = coordinates[i + 1];\n const x2 = coordinates[i + stride];\n const y2 = coordinates[i + stride + 1];\n const minX = Math.min(x1, x2);\n const maxX = Math.max(x1, x2);\n const xM = midpoint[0];\n const yM = midpoint[1];\n const dotProduct =\n (y2 - y1) * (xM - x1) - (x2 - x1) * (yM - y1);\n if (\n Math.abs(dotProduct) < 0.001 && //midpoint is aligned with the segment\n xM <= maxX &&\n xM >= minX //midpoint is on the segment and not outside it\n ) {\n placementAngle = Math.atan2(y1 - y2, x2 - x1);\n break;\n }\n }\n }\n }\n }\n }\n if (type !== 2 || styleGeom) {\n const iconSize = getValue(\n layer,\n 'layout',\n 'icon-size',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const iconColor =\n paint['icon-color'] !== undefined\n ? getValue(\n layer,\n 'paint',\n 'icon-color',\n zoom,\n f,\n functionCache,\n featureState,\n )\n : null;\n if (!iconColor || iconColor.a !== 0) {\n const haloColor = getValue(\n layer,\n 'paint',\n 'icon-halo-color',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const haloWidth = getValue(\n layer,\n 'paint',\n 'icon-halo-width',\n zoom,\n f,\n functionCache,\n featureState,\n );\n let iconCacheKey = `${icon}.${iconSize}.${haloWidth}.${haloColor}`;\n if (iconColor !== null) {\n iconCacheKey += `.${iconColor}`;\n }\n iconImg = iconImageCache[iconCacheKey];\n if (!iconImg) {\n const declutterMode = getDeclutterMode(\n layer,\n zoom,\n f,\n 'icon',\n functionCache,\n );\n let displacement;\n if ('icon-offset' in layout) {\n displacement = getValue(\n layer,\n 'layout',\n 'icon-offset',\n zoom,\n f,\n functionCache,\n featureState,\n ).slice(0);\n displacement[0] *= iconSize;\n displacement[1] *= -iconSize;\n }\n let color = iconColor\n ? [\n iconColor.r * 255,\n iconColor.g * 255,\n iconColor.b * 255,\n iconColor.a,\n ]\n : undefined;\n if (imageElement) {\n const iconOptions = {\n color: color,\n rotateWithView: iconRotationAlignment === 'map',\n displacement: displacement,\n declutterMode: declutterMode,\n scale: iconSize,\n };\n if (typeof imageElement === 'string') {\n // it is a src URL\n iconOptions.src = imageElement;\n } else {\n iconOptions.img = imageElement;\n iconOptions.imgSize = [\n imageElement.width,\n imageElement.height,\n ];\n }\n iconImg = new Icon(iconOptions);\n } else {\n const spriteImageData = spriteData[icon];\n let img, size, offset;\n if (haloWidth) {\n if (spriteImageData.sdf) {\n img = drawIconHalo(\n drawSDF(\n spriteImage,\n spriteImageData,\n iconColor || [0, 0, 0, 1],\n ),\n {\n x: 0,\n y: 0,\n width: spriteImageData.width,\n height: spriteImageData.height,\n pixelRatio: spriteImageData.pixelRatio,\n },\n haloWidth,\n haloColor,\n );\n color = undefined; // do not tint haloed icons\n } else {\n img = drawIconHalo(\n spriteImage,\n spriteImageData,\n haloWidth,\n haloColor,\n );\n }\n } else {\n if (spriteImageData.sdf) {\n if (!spriteImageUnSDFed) {\n spriteImageUnSDFed = drawSDF(\n spriteImage,\n {\n x: 0,\n y: 0,\n width: spriteImageSize[0],\n height: spriteImageSize[1],\n },\n {r: 1, g: 1, b: 1, a: 1},\n );\n }\n img = spriteImageUnSDFed;\n } else {\n img = spriteImage;\n }\n size = [spriteImageData.width, spriteImageData.height];\n offset = [spriteImageData.x, spriteImageData.y];\n }\n iconImg = new Icon({\n color: color,\n img: img,\n // @ts-ignore\n imgSize: spriteImageSize,\n size: size,\n offset: offset,\n rotateWithView: iconRotationAlignment === 'map',\n scale: iconSize / spriteImageData.pixelRatio,\n displacement: displacement,\n declutterMode: declutterMode,\n });\n }\n iconImageCache[iconCacheKey] = iconImg;\n }\n }\n if (iconImg) {\n ++stylesLength;\n style = styles[stylesLength];\n if (\n !style ||\n !style.getImage() ||\n style.getFill() ||\n style.getStroke()\n ) {\n style = new Style();\n styles[stylesLength] = style;\n }\n style.setGeometry(styleGeom);\n iconImg.setRotation(\n placementAngle +\n deg2rad(\n getValue(\n layer,\n 'layout',\n 'icon-rotate',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n ),\n );\n iconImg.setOpacity(\n getValue(\n layer,\n 'paint',\n 'icon-opacity',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n iconImg.setAnchor(\n anchor[\n getValue(\n layer,\n 'layout',\n 'icon-anchor',\n zoom,\n f,\n functionCache,\n featureState,\n )\n ],\n );\n style.setImage(iconImg);\n text = style.getText();\n style.setText(undefined);\n style.setZIndex(index);\n hasImage = true;\n skipLabel = false;\n }\n } else {\n skipLabel = true;\n }\n }\n }\n }\n\n if (type == 1 && layer.type === 'circle') {\n ++stylesLength;\n style = styles[stylesLength];\n if (\n !style ||\n !style.getImage() ||\n style.getFill() ||\n style.getStroke()\n ) {\n style = new Style();\n styles[stylesLength] = style;\n }\n const circleRadius =\n 'circle-radius' in paint\n ? getValue(\n layer,\n 'paint',\n 'circle-radius',\n zoom,\n f,\n functionCache,\n featureState,\n )\n : 5;\n const circleStrokeColor = colorWithOpacity(\n getValue(\n layer,\n 'paint',\n 'circle-stroke-color',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n getValue(\n layer,\n 'paint',\n 'circle-stroke-opacity',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n\n const circleTranslate = getValue(\n layer,\n 'paint',\n 'circle-translate',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const circleColor = colorWithOpacity(\n getValue(\n layer,\n 'paint',\n 'circle-color',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n getValue(\n layer,\n 'paint',\n 'circle-opacity',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n const circleStrokeWidth = getValue(\n layer,\n 'paint',\n 'circle-stroke-width',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const cache_key =\n circleRadius +\n '.' +\n circleStrokeColor +\n '.' +\n circleColor +\n '.' +\n circleStrokeWidth +\n '.' +\n circleTranslate[0] +\n '.' +\n circleTranslate[1];\n\n iconImg = iconImageCache[cache_key];\n if (!iconImg) {\n iconImg = new Circle({\n radius: circleRadius,\n displacement: [circleTranslate[0], -circleTranslate[1]],\n stroke:\n circleStrokeColor && circleStrokeWidth > 0\n ? new Stroke({\n width: circleStrokeWidth,\n color: circleStrokeColor,\n })\n : undefined,\n fill: circleColor\n ? new Fill({\n color: circleColor,\n })\n : undefined,\n declutterMode: 'none',\n });\n iconImageCache[cache_key] = iconImg;\n }\n style.setImage(iconImg);\n text = style.getText();\n style.setText(undefined);\n style.setGeometry(undefined);\n style.setZIndex(index);\n hasImage = true;\n }\n\n let label, font, textLineHeight, textSize, letterSpacing, maxTextWidth;\n if ('text-field' in layout) {\n textSize = Math.round(\n getValue(\n layer,\n 'layout',\n 'text-size',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n );\n const fontArray = getValue(\n layer,\n 'layout',\n 'text-font',\n zoom,\n f,\n functionCache,\n featureState,\n );\n textLineHeight = getValue(\n layer,\n 'layout',\n 'text-line-height',\n zoom,\n f,\n functionCache,\n featureState,\n );\n font = mb2css(\n getFonts\n ? getFonts(\n fontArray,\n glStyle.metadata\n ? glStyle.metadata['ol:webfonts']\n : undefined,\n )\n : fontArray,\n textSize,\n textLineHeight,\n );\n if (!font.includes('sans-serif')) {\n font += ',sans-serif';\n }\n letterSpacing = getValue(\n layer,\n 'layout',\n 'text-letter-spacing',\n zoom,\n f,\n functionCache,\n featureState,\n );\n maxTextWidth = getValue(\n layer,\n 'layout',\n 'text-max-width',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const textField = getValue(\n layer,\n 'layout',\n 'text-field',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (typeof textField === 'object' && textField.sections) {\n if (textField.sections.length === 1) {\n label = textField.toString();\n } else {\n label = textField.sections.reduce((acc, chunk, i) => {\n const fonts = chunk.fontStack\n ? chunk.fontStack.split(',')\n : fontArray;\n const chunkFont = mb2css(\n getFonts ? getFonts(fonts) : fonts,\n textSize * (chunk.scale || 1),\n textLineHeight,\n );\n let text = chunk.text;\n if (text === '\\n') {\n acc.push('\\n', '');\n return acc;\n }\n if (type == 2) {\n acc.push(applyLetterSpacing(text, letterSpacing), chunkFont);\n return acc;\n }\n text = wrapText(\n text,\n chunkFont,\n maxTextWidth,\n letterSpacing,\n ).split('\\n');\n for (let i = 0, ii = text.length; i < ii; ++i) {\n if (i > 0) {\n acc.push('\\n', '');\n }\n acc.push(text[i], chunkFont);\n }\n return acc;\n }, []);\n }\n } else {\n label = fromTemplate(textField, properties).trim();\n }\n opacity = getValue(\n layer,\n 'paint',\n 'text-opacity',\n zoom,\n f,\n functionCache,\n featureState,\n );\n }\n if (label && opacity && !skipLabel) {\n if (!hasImage) {\n ++stylesLength;\n style = styles[stylesLength];\n if (\n !style ||\n !style.getText() ||\n style.getFill() ||\n style.getStroke()\n ) {\n style = new Style();\n styles[stylesLength] = style;\n }\n style.setImage(undefined);\n style.setGeometry(undefined);\n }\n const declutterMode = getDeclutterMode(\n layer,\n zoom,\n f,\n 'text',\n functionCache,\n );\n if (!style.getText()) {\n style.setText(text);\n }\n text = style.getText();\n if (\n !text ||\n ('getDeclutterMode' in text &&\n text.getDeclutterMode() !== declutterMode)\n ) {\n text = new Text({\n padding: [2, 2, 2, 2],\n // @ts-ignore\n declutterMode: declutterMode,\n });\n style.setText(text);\n }\n const textTransform = getValue(\n layer,\n 'layout',\n 'text-transform',\n zoom,\n f,\n functionCache,\n featureState,\n );\n if (textTransform == 'uppercase') {\n label = Array.isArray(label)\n ? label.map((t, i) => (i % 2 ? t : t.toUpperCase()))\n : label.toUpperCase();\n } else if (textTransform == 'lowercase') {\n label = Array.isArray(label)\n ? label.map((t, i) => (i % 2 ? t : t.toLowerCase()))\n : label.toLowerCase();\n }\n const wrappedLabel = Array.isArray(label)\n ? label\n : type == 2\n ? applyLetterSpacing(label, letterSpacing)\n : wrapText(label, font, maxTextWidth, letterSpacing);\n text.setText(wrappedLabel);\n text.setFont(font);\n text.setRotation(\n deg2rad(\n getValue(\n layer,\n 'layout',\n 'text-rotate',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n ),\n );\n if (typeof text.setKeepUpright === 'function') {\n const keepUpright = getValue(\n layer,\n 'layout',\n 'text-keep-upright',\n zoom,\n f,\n functionCache,\n featureState,\n );\n text.setKeepUpright(keepUpright);\n }\n const textAnchor = getValue(\n layer,\n 'layout',\n 'text-anchor',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const placement =\n hasImage || type == 1\n ? 'point'\n : getValue(\n layer,\n 'layout',\n 'symbol-placement',\n zoom,\n f,\n functionCache,\n featureState,\n );\n let textAlign;\n if (placement === 'line-center') {\n text.setPlacement('line');\n textAlign = 'center';\n } else {\n text.setPlacement(placement);\n }\n if (placement === 'line' && typeof text.setRepeat === 'function') {\n const symbolSpacing = getValue(\n layer,\n 'layout',\n 'symbol-spacing',\n zoom,\n f,\n functionCache,\n featureState,\n );\n text.setRepeat(symbolSpacing * 2);\n }\n text.setOverflow(placement === 'point');\n let textHaloWidth = getValue(\n layer,\n 'paint',\n 'text-halo-width',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const textOffset = getValue(\n layer,\n 'layout',\n 'text-offset',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const textTranslate = getValue(\n layer,\n 'paint',\n 'text-translate',\n zoom,\n f,\n functionCache,\n featureState,\n );\n // Text offset has to take halo width and line height into account\n let vOffset = 0;\n let hOffset = 0;\n if (placement == 'point') {\n textAlign = 'center';\n if (textAnchor.indexOf('left') !== -1) {\n textAlign = 'left';\n hOffset = textHaloWidth;\n } else if (textAnchor.indexOf('right') !== -1) {\n textAlign = 'right';\n hOffset = -textHaloWidth;\n }\n const textRotationAlignment = getValue(\n layer,\n 'layout',\n 'text-rotation-alignment',\n zoom,\n f,\n functionCache,\n featureState,\n );\n text.setRotateWithView(textRotationAlignment == 'map');\n } else {\n text.setMaxAngle(\n (deg2rad(\n getValue(\n layer,\n 'layout',\n 'text-max-angle',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n ) *\n label.length) /\n wrappedLabel.length,\n );\n text.setRotateWithView(false);\n }\n text.setTextAlign(textAlign);\n let textBaseline = 'middle';\n if (textAnchor.indexOf('bottom') == 0) {\n textBaseline = 'bottom';\n vOffset = -textHaloWidth - 0.5 * (textLineHeight - 1) * textSize;\n } else if (textAnchor.indexOf('top') == 0) {\n textBaseline = 'top';\n vOffset = textHaloWidth + 0.5 * (textLineHeight - 1) * textSize;\n }\n text.setTextBaseline(textBaseline);\n const textJustify = getValue(\n layer,\n 'layout',\n 'text-justify',\n zoom,\n f,\n functionCache,\n featureState,\n );\n text.setJustify(textJustify === 'auto' ? undefined : textJustify);\n text.setOffsetX(\n textOffset[0] * textSize + hOffset + textTranslate[0],\n );\n text.setOffsetY(\n textOffset[1] * textSize + vOffset + textTranslate[1],\n );\n textColor.setColor(\n colorWithOpacity(\n getValue(\n layer,\n 'paint',\n 'text-color',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n opacity,\n ),\n );\n text.setFill(textColor);\n const haloColor = colorWithOpacity(\n getValue(\n layer,\n 'paint',\n 'text-halo-color',\n zoom,\n f,\n functionCache,\n featureState,\n ),\n opacity,\n );\n if (haloColor && textHaloWidth > 0) {\n textHalo.setColor(haloColor);\n // spec here : https://docs.mapbox.com/mapbox-gl-js/style-spec/#paint-symbol-text-halo-width\n // Halo width must be doubled because it is applied around the center of the text outline\n textHaloWidth *= 2;\n // 1/4 of text size (spec) x 2\n const halfTextSize = 0.5 * textSize;\n textHalo.setWidth(\n textHaloWidth <= halfTextSize ? textHaloWidth : halfTextSize,\n );\n text.setStroke(textHalo);\n } else {\n text.setStroke(undefined);\n }\n const textPadding = getValue(\n layer,\n 'layout',\n 'text-padding',\n zoom,\n f,\n functionCache,\n featureState,\n );\n const padding = text.getPadding();\n if (textPadding !== padding[0]) {\n padding[0] = textPadding;\n padding[1] = textPadding;\n padding[2] = textPadding;\n padding[3] = textPadding;\n }\n style.setZIndex(index);\n }\n }\n }\n\n if (stylesLength > -1) {\n styles.length = stylesLength + 1;\n if (recordLayer) {\n if ('set' in feature) {\n // ol/Feature\n feature.set('mapbox-layer', featureBelongsToLayer);\n } else {\n // ol/render/Feature\n feature.getProperties()['mapbox-layer'] = featureBelongsToLayer;\n }\n }\n return styles;\n }\n return undefined;\n };\n\n olLayer.setStyle(styleFunction);\n olLayer.set('mapbox-source', mapboxSource);\n olLayer.set('mapbox-layers', mapboxLayers);\n olLayer.set('mapbox-featurestate', olLayer.get('mapbox-featurestate') || {});\n return styleFunction;\n}\n\n/**\n * Get the the style for a specific Mapbox layer only. This can be useful for creating a legend.\n * @param {import(\"ol/Feature\").default|import(\"ol/render/Feature\").default} feature OpenLayers feature.\n * @param {number} resolution View resolution.\n * @param {import(\"ol/layer\").Vector|import(\"ol/layer\").VectorTile} olLayer OpenLayers layer.\n * @param {string} layerId Id of the Mapbox layer to get the style for\n * @return {Array} Styles for the provided Mapbox layer.\n */\nexport function getStyleForLayer(feature, resolution, olLayer, layerId) {\n const evaluateStyle = olLayer.getStyleFunction();\n if (evaluateStyle.length === 3) {\n // @ts-ignore\n return evaluateStyle(feature, resolution, layerId);\n }\n return undefined;\n}\n\nexport {\n colorWithOpacity as _colorWithOpacity,\n evaluateFilter as _evaluateFilter,\n fromTemplate as _fromTemplate,\n getValue as _getValue,\n};\n","/**\n * Generates a shaded relief image given elevation data. Uses a 3x3\n * neighborhood for determining slope and aspect.\n * @param {Array} inputs Array of input images.\n * @param {Object} data Data added in the \"beforeoperations\" event.\n * @return {ImageData} Output image.\n */\nexport function hillshade(inputs, data) {\n const elevationImage = inputs[0];\n const width = elevationImage.width;\n const height = elevationImage.height;\n const elevationData = elevationImage.data;\n const shadeData = new Uint8ClampedArray(elevationData.length);\n const dp = data.resolution * 2;\n const maxX = width - 1;\n const maxY = height - 1;\n const pixel = [0, 0, 0, 0];\n const twoPi = 2 * Math.PI;\n const halfPi = Math.PI / 2;\n const sunEl = (Math.PI * data.sunEl) / 180;\n const sunAz = (Math.PI * data.sunAz) / 180;\n const cosSunEl = Math.cos(sunEl);\n const sinSunEl = Math.sin(sunEl);\n const highlightColor = data.highlightColor;\n const shadowColor = data.shadowColor;\n const accentColor = data.accentColor;\n const encoding = data.encoding;\n\n let pixelX,\n pixelY,\n x0,\n x1,\n y0,\n y1,\n offset,\n z0,\n z1,\n dzdx,\n dzdy,\n slope,\n aspect,\n accent,\n scaled,\n shade,\n scaledAccentColor,\n compositeShadeColor,\n clamp,\n slopeScaleBase,\n scaledSlope,\n cosIncidence;\n\n function calculateElevation(pixel, encoding = 'mapbox') {\n // The method used to extract elevations from the DEM.\n //\n // The supported methods are the Mapbox format\n // (red * 256 * 256 + green * 256 + blue) * 0.1 - 10000\n // and the Terrarium format\n // (red * 256 + green + blue / 256) - 32768\n //\n if (encoding === 'mapbox') {\n return (pixel[0] * 256 * 256 + pixel[1] * 256 + pixel[2]) * 0.1 - 10000;\n }\n if (encoding === 'terrarium') {\n return pixel[0] * 256 + pixel[1] + pixel[2] / 256 - 32768;\n }\n }\n for (pixelY = 0; pixelY <= maxY; ++pixelY) {\n y0 = pixelY === 0 ? 0 : pixelY - 1;\n y1 = pixelY === maxY ? maxY : pixelY + 1;\n for (pixelX = 0; pixelX <= maxX; ++pixelX) {\n x0 = pixelX === 0 ? 0 : pixelX - 1;\n x1 = pixelX === maxX ? maxX : pixelX + 1;\n\n // determine elevation for (x0, pixelY)\n offset = (pixelY * width + x0) * 4;\n pixel[0] = elevationData[offset];\n pixel[1] = elevationData[offset + 1];\n pixel[2] = elevationData[offset + 2];\n pixel[3] = elevationData[offset + 3];\n z0 = data.vert * calculateElevation(pixel, encoding);\n\n // determine elevation for (x1, pixelY)\n offset = (pixelY * width + x1) * 4;\n pixel[0] = elevationData[offset];\n pixel[1] = elevationData[offset + 1];\n pixel[2] = elevationData[offset + 2];\n pixel[3] = elevationData[offset + 3];\n z1 = data.vert * calculateElevation(pixel, encoding);\n\n dzdx = (z1 - z0) / dp;\n\n // determine elevation for (pixelX, y0)\n offset = (y0 * width + pixelX) * 4;\n pixel[0] = elevationData[offset];\n pixel[1] = elevationData[offset + 1];\n pixel[2] = elevationData[offset + 2];\n pixel[3] = elevationData[offset + 3];\n z0 = data.vert * calculateElevation(pixel, encoding);\n\n // determine elevation for (pixelX, y1)\n offset = (y1 * width + pixelX) * 4;\n pixel[0] = elevationData[offset];\n pixel[1] = elevationData[offset + 1];\n pixel[2] = elevationData[offset + 2];\n pixel[3] = elevationData[offset + 3];\n z1 = data.vert * calculateElevation(pixel, encoding);\n\n dzdy = (z1 - z0) / dp;\n\n aspect = Math.atan2(dzdy, -dzdx);\n if (aspect < 0) {\n aspect = halfPi - aspect;\n } else if (aspect > halfPi) {\n aspect = twoPi - aspect + halfPi;\n } else {\n aspect = halfPi - aspect;\n }\n\n // Bootstrap slope and corresponding incident values\n slope = Math.atan(Math.sqrt(dzdx * dzdx + dzdy * dzdy));\n cosIncidence =\n sinSunEl * Math.cos(slope) +\n cosSunEl * Math.sin(slope) * Math.cos(sunAz - aspect);\n accent = Math.cos(slope);\n // 255 for Hex colors\n scaled = 255 * cosIncidence;\n\n /*\n * The following is heavily inspired\n * by [Maplibre's equivalent WebGL shader](https://github.com/maplibre/maplibre-gl-js/blob/main/src/shaders/hillshade.fragment.glsl)\n */\n\n // Forces given value to stay between two given extremes\n clamp = Math.min(Math.max(2 * data.sunEl, 0), 1);\n\n // Intensity basis for hillshade opacity\n slopeScaleBase = 1.875 - data.opacity * 1.75;\n // Intensity interpolation so that higher intensity values create more opaque hillshading\n scaledSlope =\n data.opacity !== 0.5\n ? halfPi *\n ((Math.pow(slopeScaleBase, slope) - 1) /\n (Math.pow(slopeScaleBase, halfPi) - 1))\n : slope;\n\n // Accent hillshade color with given accentColor to emphasize rougher terrain\n scaledAccentColor = {\n r: (1 - accent) * accentColor.r * clamp * 255,\n g: (1 - accent) * accentColor.g * clamp * 255,\n b: (1 - accent) * accentColor.b * clamp * 255,\n a: (1 - accent) * accentColor.a * clamp * 255,\n };\n\n // Allows highlight vs shadow discrimination\n shade = Math.abs((((aspect + sunAz) / Math.PI + 0.5) % 2) - 1);\n // Creates a composite color mix between highlight & shadow colors to emphasize slopes\n compositeShadeColor = {\n r: (highlightColor.r * (1 - shade) + shadowColor.r * shade) * scaled,\n g: (highlightColor.g * (1 - shade) + shadowColor.g * shade) * scaled,\n b: (highlightColor.b * (1 - shade) + shadowColor.b * shade) * scaled,\n a: (highlightColor.a * (1 - shade) + shadowColor.a * shade) * scaled,\n };\n\n // Fill in result color value\n offset = (pixelY * width + pixelX) * 4;\n shadeData[offset] =\n scaledAccentColor.r * (1 - shade) + compositeShadeColor.r;\n shadeData[offset + 1] =\n scaledAccentColor.g * (1 - shade) + compositeShadeColor.g;\n shadeData[offset + 2] =\n scaledAccentColor.b * (1 - shade) + compositeShadeColor.b;\n // Key opacity on the scaledSlope to improve legibility by increasing higher elevation rates' contrast\n shadeData[offset + 3] =\n elevationData[offset + 3] *\n data.opacity *\n clamp *\n Math.sin(scaledSlope);\n }\n }\n\n return new ImageData(shadeData, width, height);\n}\n","/*\nol-mapbox-style - Use Mapbox/MapLibre Style objects with OpenLayers\nCopyright 2016-present ol-mapbox-style contributors\nLicense: https://raw.githubusercontent.com/openlayers/ol-mapbox-style/master/LICENSE\n*/\n\nimport GeoJSON from 'ol/format/GeoJSON.js';\nimport ImageLayer from 'ol/layer/Image.js';\nimport Layer from 'ol/layer/Layer.js';\nimport LayerGroup from 'ol/layer/Group.js';\nimport MVT from 'ol/format/MVT.js';\nimport Map from 'ol/Map.js';\nimport Raster from 'ol/source/Raster.js';\nimport Source from 'ol/source/Source.js';\nimport TileGrid from 'ol/tilegrid/TileGrid.js';\nimport TileJSON from 'ol/source/TileJSON.js';\nimport TileLayer from 'ol/layer/Tile.js';\nimport VectorLayer from 'ol/layer/Vector.js';\nimport VectorSource from 'ol/source/Vector.js';\nimport VectorTileLayer from 'ol/layer/VectorTile.js';\nimport VectorTileSource, {defaultLoadFunction} from 'ol/source/VectorTile.js';\nimport View from 'ol/View.js';\nimport derefLayers from '@mapbox/mapbox-gl-style-spec/deref.js';\nimport {METERS_PER_UNIT} from 'ol/proj/Units.js';\nimport {\n _colorWithOpacity,\n stylefunction as applyStylefunction,\n getValue,\n styleFunctionArgs,\n} from './stylefunction.js';\nimport {bbox as bboxStrategy} from 'ol/loadingstrategy.js';\nimport {createXYZ} from 'ol/tilegrid.js';\nimport {\n defaultResolutions,\n fetchResource,\n getFilterCache,\n getFunctionCache,\n getGlStyle,\n getResolutionForZoom,\n getStyleFunctionKey,\n getTileJson,\n getZoomForResolution,\n} from './util.js';\nimport {\n equivalent,\n fromLonLat,\n getPointResolution,\n get as getProjection,\n getUserProjection,\n} from 'ol/proj.js';\nimport {getCenter, getTopLeft} from 'ol/extent.js';\nimport {getFonts} from './text.js';\nimport {hillshade} from './shaders.js';\nimport {\n normalizeSourceUrl,\n normalizeSpriteUrl,\n normalizeStyleUrl,\n} from './mapbox.js';\n\n/**\n * @typedef {Object} FeatureIdentifier\n * @property {string|number} id The feature id.\n * @property {string} source The source id.\n */\n\n/**\n * @typedef {Object} Options\n * @property {string} [accessToken] Access token for 'mapbox://' urls.\n * @property {function(string, import(\"./util.js\").ResourceType): (Request|string|Promise|void)} [transformRequest]\n * Function for controlling how `ol-mapbox-style` fetches resources. Can be used for modifying\n * the url, adding headers or setting credentials options. Called with the url and the resource\n * type as arguments, this function is supposed to return a `Request` or a url `string`, or a promise tehereof.\n * Without a return value the original request will not be modified.\n * @property {string} [projection='EPSG:3857'] Only useful when working with non-standard projections.\n * Code of a projection registered with OpenLayers. All sources of the style must be provided in this\n * projection. The projection must also have a valid extent defined, which will be used to determine the\n * origin and resolutions of the tile grid for all tiled sources of the style. When provided, the bbox\n * placeholder in tile and geojson urls changes: the default is `{bbox-epsg-3857}`, when projection is e.g.\n * set to `EPSG:4326`, the bbox placeholder will be `{bbox-epsg-4326}`.\n * @property {Array} [resolutions] Only useful when working with non-standard projections.\n * Resolutions for mapping resolution to the `zoom` used in the Mapbox/MapLibre style.\n * @property {string} [styleUrl] URL of the Mapbox GL style. Required for styles that were provided\n * as object, when they contain a relative sprite url, or sources referencing data by relative url.\n * @property {string} [webfonts] Template for resolving webfonts. Can be used to specify where to fetch\n * web fonts when no `ol:webfonts` metadata is set in the style object. See `getFonts()` and the\n * \"Font handling\" section in `README.md` for details.\n * @property {function(VectorLayer|VectorTileLayer, string):HTMLImageElement|HTMLCanvasElement|string|undefined} [getImage=undefined]\n * Function that returns an image for an icon name. If the result is an HTMLImageElement, it must already be\n * loaded. The layer can be used to call layer.changed() when the loading and processing of the image has finished.\n * This function be used for icons not in the sprite or to override sprite icons.\n * @property {string} [accessTokenParam='access_token'] Access token param. For internal use.\n */\n\n/**\n * @typedef {Object} ApplyStyleOptions\n * @property {string} [source=''] Source. Default is `''`, which causes the first source in the\n * style to be used.\n * @property {Array} [layers] Layers. If no source is provided, the layers with the\n * provided ids will be used from the style's `layers` array. All layers need to use the same source.\n * @property {boolean} [updateSource=true] Update or create vector (tile) layer source with parameters\n * specified for the source in the mapbox style definition.\n */\n\n/**\n * @param {import(\"ol/proj/Projection.js\").default} projection Projection.\n * @param {number} [tileSize=512] Tile size.\n * @return {Array} Resolutions.\n */\nfunction getTileResolutions(projection, tileSize = 512) {\n return projection.getExtent()\n ? createXYZ({\n extent: projection.getExtent(),\n tileSize: tileSize,\n maxZoom: 22,\n }).getResolutions()\n : defaultResolutions;\n}\n\n/**\n * @param {string} styleUrl Style URL.\n * @param {Options} options Options.\n * @return {Options} Completed options with accessToken and accessTokenParam.\n */\nfunction completeOptions(styleUrl, options) {\n if (!options.accessToken) {\n options = Object.assign({}, options);\n const searchParams = new URL(styleUrl).searchParams;\n // The last search parameter is the access token\n searchParams.forEach((value, key) => {\n options.accessToken = value;\n options.accessTokenParam = key;\n });\n }\n return options;\n}\n\n/**\n * Applies a style function to an `ol/layer/VectorTile` or `ol/layer/Vector`\n * with an `ol/source/VectorTile` or an `ol/source/Vector`. If the layer does not have a source\n * yet, it will be created and populated from the information in the `glStyle` (unless `updateSource` is\n * set to `false`).\n *\n * **Example:**\n * ```js\n * import {applyStyle} from 'ol-mapbox-style';\n * import {VectorTile} from 'ol/layer.js';\n *\n * const layer = new VectorTile({declutter: true});\n * applyStyle(layer, 'https://api.maptiler.com/maps/basic/style.json?key=YOUR_OPENMAPTILES_TOKEN');\n * ```\n *\n * The style function will render all layers from the `glStyle` object that use the source\n * of the first layer, the specified `source`, or a subset of layers from the same source. The\n * source needs to be a `\"type\": \"vector\"` or `\"type\": \"geojson\"` source.\n *\n * Two additional properties will be set on the provided layer:\n *\n * * `mapbox-source`: The `id` of the Mapbox/MapLibre Style document's source that the\n * OpenLayers layer was created from. Usually `apply()` creates one\n * OpenLayers layer per Mapbox/MapLibre Style source, unless the layer stack has\n * layers from different sources in between.\n * * `mapbox-layers`: The `id`s of the Mapbox/MapLibre Style document's layers that are\n * included in the OpenLayers layer.\n *\n * @param {VectorTileLayer|VectorLayer} layer OpenLayers layer. When the layer has a source configured,\n * it will be modified to use the configuration from the glStyle's `source`. Options specified on the\n * layer's source will override those from the glStyle's `source`, except for `url` and\n * `tileUrlFunction`. When the source projection is the default (`EPSG:3857`), the `tileGrid` will\n * also be overridden. If you'd rather not have ol-mapbox-style modify the source, configure `applyStyle()`\n * with the `updateSource: false` option.\n * @param {string|Object} glStyle Mapbox/MapLibre Style object.\n * @param {string|Array|Options&ApplyStyleOptions} [sourceOrLayersOrOptions] Options or\n * `source` key or an array of layer `id`s from the Mapbox/MapLibre Style object. When a `source` key is\n * provided, all layers for the specified source will be included in the style function. When layer\n * `id`s are provided, they must be from layers that use the same source. When not provided or a falsey\n * value, all layers using the first source specified in the glStyle will be rendered.\n * @param {Options&ApplyStyleOptions|string} [optionsOrPath] **Deprecated**. Options. Alternatively the path of the style file\n * (only required when a relative path is used for the `\"sprite\"` property of the style).\n * @param {Array} [resolutions] **Deprecated**. Resolutions for mapping resolution to zoom level.\n * Only needed when working with non-standard tile grids or projections, can also be supplied with\n * options.\n * @return {Promise} Promise which will be resolved when the style can be used\n * for rendering.\n */\nexport function applyStyle(\n layer,\n glStyle,\n sourceOrLayersOrOptions = '',\n optionsOrPath = {},\n resolutions = undefined,\n) {\n let styleUrl, sourceId;\n /** @type {Options&ApplyStyleOptions} */\n let options;\n let sourceOrLayers;\n let updateSource = true;\n if (\n typeof sourceOrLayersOrOptions !== 'string' &&\n !Array.isArray(sourceOrLayersOrOptions)\n ) {\n options = sourceOrLayersOrOptions;\n sourceOrLayers = options.source || options.layers;\n optionsOrPath = options;\n } else {\n sourceOrLayers = sourceOrLayersOrOptions;\n }\n if (typeof optionsOrPath === 'string') {\n styleUrl = optionsOrPath;\n options = {};\n } else {\n styleUrl = optionsOrPath.styleUrl;\n options = optionsOrPath;\n }\n if (options.updateSource === false) {\n updateSource = false;\n }\n if (!resolutions) {\n resolutions = options.resolutions;\n }\n if (\n !styleUrl &&\n typeof glStyle === 'string' &&\n !glStyle.trim().startsWith('{')\n ) {\n styleUrl = glStyle;\n }\n if (styleUrl) {\n styleUrl = styleUrl.startsWith('data:')\n ? location.href\n : normalizeStyleUrl(styleUrl, options.accessToken);\n options = completeOptions(styleUrl, options);\n }\n\n return new Promise(function (resolve, reject) {\n // TODO: figure out where best place to check source type is\n // Note that the source arg is an array of gl layer ids and each must be\n // dereferenced to get source type to validate\n getGlStyle(glStyle, options)\n .then(function (glStyle) {\n if (glStyle.version != 8) {\n return reject(new Error('glStyle version 8 required.'));\n }\n if (\n !(layer instanceof VectorLayer || layer instanceof VectorTileLayer)\n ) {\n return reject(\n new Error('Can only apply to VectorLayer or VectorTileLayer'),\n );\n }\n\n const type = layer instanceof VectorTileLayer ? 'vector' : 'geojson';\n if (!sourceOrLayers) {\n sourceId = Object.keys(glStyle.sources).find(function (key) {\n return glStyle.sources[key].type === type;\n });\n sourceOrLayers = sourceId;\n } else if (Array.isArray(sourceOrLayers)) {\n sourceId = glStyle.layers.find(function (layer) {\n return layer.id === sourceOrLayers[0];\n }).source;\n } else {\n sourceId = sourceOrLayers;\n }\n if (!sourceId) {\n return reject(new Error(`No ${type} source found in the glStyle.`));\n }\n\n function assignSource() {\n if (!updateSource) {\n return Promise.resolve();\n }\n if (layer instanceof VectorTileLayer) {\n return setupVectorSource(\n glStyle.sources[sourceId],\n styleUrl,\n options,\n ).then(function (source) {\n const targetSource = layer.getSource();\n if (!targetSource) {\n layer.setSource(source);\n } else if (source !== targetSource) {\n targetSource.setTileUrlFunction(source.getTileUrlFunction());\n if (\n typeof targetSource.setUrls === 'function' &&\n typeof source.getUrls === 'function'\n ) {\n // to get correct keys for tile cache and queue\n targetSource.setUrls(source.getUrls());\n }\n //@ts-ignore\n if (!targetSource.format_) {\n //@ts-ignore\n targetSource.format_ = source.format_;\n }\n if (!targetSource.getAttributions()) {\n targetSource.setAttributions(source.getAttributions());\n }\n if (\n targetSource.getTileLoadFunction() === defaultLoadFunction\n ) {\n targetSource.setTileLoadFunction(\n source.getTileLoadFunction(),\n );\n }\n if (\n equivalent(\n targetSource.getProjection(),\n source.getProjection(),\n )\n ) {\n targetSource.tileGrid = source.getTileGrid();\n }\n }\n const tileGrid = layer.getSource().getTileGrid();\n if (\n !isFinite(layer.getMaxResolution()) &&\n !isFinite(layer.getMinZoom()) &&\n tileGrid.getMinZoom() > 0\n ) {\n layer.setMaxResolution(\n getResolutionForZoom(\n Math.max(0, tileGrid.getMinZoom() - 1e-12),\n tileGrid.getResolutions(),\n ),\n );\n }\n });\n }\n const glSource = glStyle.sources[sourceId];\n let source = layer.getSource();\n if (!source || source.get('mapbox-source') !== glSource) {\n source = setupGeoJSONSource(glSource, styleUrl, options);\n }\n const targetSource = /** @type {VectorSource} */ (layer.getSource());\n if (!targetSource) {\n layer.setSource(source);\n } else if (source !== targetSource) {\n if (!targetSource.getAttributions()) {\n targetSource.setAttributions(source.getAttributions());\n }\n //@ts-ignore\n if (!targetSource.format_) {\n //@ts-ignore\n targetSource.format_ = source.getFormat();\n }\n //@ts-ignore\n targetSource.url_ = source.getUrl();\n }\n return Promise.resolve();\n }\n\n let spriteScale, spriteData, spriteImageUrl, style;\n function onChange() {\n if (!style && (!glStyle.sprite || spriteData)) {\n if (options.projection && !resolutions) {\n const projection = getProjection(options.projection);\n const units = projection.getUnits();\n if (units !== 'm') {\n resolutions = defaultResolutions.map(\n (resolution) => resolution / METERS_PER_UNIT[units],\n );\n }\n }\n style = applyStylefunction(\n layer,\n glStyle,\n sourceOrLayers,\n resolutions,\n spriteData,\n spriteImageUrl,\n (fonts, templateUrl = options.webfonts) =>\n getFonts(fonts, templateUrl),\n options.getImage,\n );\n if (!layer.getStyle()) {\n reject(new Error(`Nothing to show for source [${sourceId}]`));\n } else {\n assignSource().then(resolve).catch(reject);\n }\n } else if (style) {\n layer.setStyle(style);\n assignSource().then(resolve).catch(reject);\n } else {\n reject(new Error('Something went wrong trying to apply style.'));\n }\n }\n\n if (glStyle.sprite) {\n const sprite = new URL(\n normalizeSpriteUrl(\n glStyle.sprite,\n options.accessToken,\n styleUrl || location.href,\n ),\n );\n spriteScale = window.devicePixelRatio >= 1.5 ? 0.5 : 1;\n const sizeFactor = spriteScale == 0.5 ? '@2x' : '';\n let spriteUrl =\n sprite.origin +\n sprite.pathname +\n sizeFactor +\n '.json' +\n sprite.search;\n\n new Promise(function (resolve, reject) {\n fetchResource('Sprite', spriteUrl, options)\n .then(resolve)\n .catch(function (error) {\n spriteUrl =\n sprite.origin + sprite.pathname + '.json' + sprite.search;\n fetchResource('Sprite', spriteUrl, options)\n .then(resolve)\n .catch(reject);\n });\n })\n .then(function (spritesJson) {\n if (spritesJson === undefined) {\n reject(new Error('No sprites found.'));\n }\n spriteData = spritesJson;\n spriteImageUrl =\n sprite.origin +\n sprite.pathname +\n sizeFactor +\n '.png' +\n sprite.search;\n if (options.transformRequest) {\n const transformed =\n options.transformRequest(spriteImageUrl, 'SpriteImage') ||\n spriteImageUrl;\n if (\n transformed instanceof Request ||\n transformed instanceof Promise\n ) {\n spriteImageUrl = transformed;\n }\n }\n onChange();\n })\n .catch(function (err) {\n reject(\n new Error(\n `Sprites cannot be loaded: ${spriteUrl}: ${err.message}`,\n ),\n );\n });\n } else {\n onChange();\n }\n })\n .catch(reject);\n });\n}\n\nconst emptyObj = {};\n\nfunction setFirstBackground(mapOrLayer, glStyle, options) {\n glStyle.layers.some(function (layer) {\n if (layer.type === 'background') {\n if (mapOrLayer instanceof Layer) {\n mapOrLayer.setBackground(function (resolution) {\n return getBackgroundColor(layer, resolution, options, {});\n });\n return true;\n }\n if (mapOrLayer instanceof Map || mapOrLayer instanceof LayerGroup) {\n mapOrLayer\n .getLayers()\n .insertAt(0, setupBackgroundLayer(layer, options, {}));\n return true;\n }\n }\n });\n}\n\n/**\n * Applies properties of the Mapbox/MapLibre Style's first `background` layer to the\n * provided map or layer (group).\n *\n * **Example:**\n * ```js\n * import {applyBackground} from 'ol-mapbox-style';\n * import {Map} from 'ol';\n *\n * const map = new Map({target: 'map'});\n * applyBackground(map, 'https://api.maptiler.com/maps/basic/style.json?key=YOUR_OPENMAPTILES_TOKEN');\n * ```\n * @param {Map|import(\"ol/layer/Base.js\").default} mapOrLayer OpenLayers Map or layer (group).\n * @param {Object|string} glStyle Mapbox/MapLibre Style object or url.\n * @param {Options} options Options.\n * @return {Promise} Promise that resolves when the background is applied.\n */\nexport function applyBackground(mapOrLayer, glStyle, options = {}) {\n return getGlStyle(glStyle, options).then(function (glStyle) {\n setFirstBackground(mapOrLayer, glStyle, options);\n });\n}\n\nfunction getSourceIdByRef(layers, ref) {\n let sourceId;\n layers.some(function (layer) {\n if (layer.id == ref) {\n sourceId = layer.source;\n return true;\n }\n });\n return sourceId;\n}\n\nfunction extentFromTileJSON(tileJSON, projection) {\n const bounds = tileJSON.bounds;\n if (bounds) {\n const ll = fromLonLat([bounds[0], bounds[1]], projection);\n const tr = fromLonLat([bounds[2], bounds[3]], projection);\n return [ll[0], ll[1], tr[0], tr[1]];\n }\n return getProjection(projection).getExtent();\n}\n\nfunction sourceOptionsFromTileJSON(glSource, tileJSON, options) {\n const tileJSONSource = new TileJSON({\n tileJSON: tileJSON,\n tileSize: glSource.tileSize || tileJSON.tileSize || 512,\n });\n const tileJSONDoc = tileJSONSource.getTileJSON();\n const tileGrid = tileJSONSource.getTileGrid();\n const projection = getProjection(options.projection || 'EPSG:3857');\n const extent = extentFromTileJSON(tileJSONDoc, projection);\n const projectionExtent = projection.getExtent();\n const minZoom = tileJSONDoc.minzoom || 0;\n const maxZoom = tileJSONDoc.maxzoom || 22;\n /** @type {import(\"ol/source/VectorTile.js\").Options} */\n const sourceOptions = {\n attributions: tileJSONSource.getAttributions(),\n projection: projection,\n tileGrid: new TileGrid({\n origin: projectionExtent\n ? getTopLeft(projectionExtent)\n : tileGrid.getOrigin(0),\n extent: extent || tileGrid.getExtent(),\n minZoom: minZoom,\n resolutions: getTileResolutions(projection, tileJSON.tileSize).slice(\n 0,\n maxZoom + 1,\n ),\n tileSize: tileGrid.getTileSize(0),\n }),\n };\n if (Array.isArray(tileJSONDoc.tiles)) {\n sourceOptions.urls = tileJSONDoc.tiles;\n } else {\n sourceOptions.url = tileJSONDoc.tiles;\n }\n return sourceOptions;\n}\n\nfunction getBackgroundColor(glLayer, resolution, options, functionCache) {\n const background = {\n id: glLayer.id,\n type: glLayer.type,\n };\n const layout = glLayer.layout || {};\n const paint = glLayer.paint || {};\n background['paint'] = paint;\n const zoom = getZoomForResolution(\n resolution,\n options.resolutions || defaultResolutions,\n );\n let opacity;\n const bg = getValue(\n background,\n 'paint',\n 'background-color',\n zoom,\n emptyObj,\n functionCache,\n );\n if (paint['background-opacity'] !== undefined) {\n opacity = getValue(\n background,\n 'paint',\n 'background-opacity',\n zoom,\n emptyObj,\n functionCache,\n );\n }\n return layout.visibility == 'none'\n ? undefined\n : _colorWithOpacity(bg, opacity);\n}\n\n/**\n * @param {Object} glLayer Mapbox/MapLibre Style layer object.\n * @param {Options} options Options.\n * @param {Object} functionCache Cache for functions.\n * @return {Layer} OpenLayers layer.\n */\nfunction setupBackgroundLayer(glLayer, options, functionCache) {\n const div = document.createElement('div');\n div.className = 'ol-mapbox-style-background';\n div.style.position = 'absolute';\n div.style.width = '100%';\n div.style.height = '100%';\n return new Layer({\n source: new Source({}),\n render(frameState) {\n const color = getBackgroundColor(\n glLayer,\n frameState.viewState.resolution,\n options,\n functionCache,\n );\n div.style.backgroundColor = color;\n return div;\n },\n });\n}\n\n/**\n * Creates an OpenLayers VectorTile source for a gl source entry.\n * @param {Object} glSource \"source\" entry from a Mapbox/MapLibre Style object.\n * @param {string|undefined} styleUrl URL to use for the source. This is expected to be the complete http(s) url,\n * with access key applied.\n * @param {Options} options Options.\n * @return {Promise} Promise resolving to a VectorTile source.\n * @private\n */\nexport function setupVectorSource(glSource, styleUrl, options) {\n return new Promise(function (resolve, reject) {\n getTileJson(glSource, styleUrl, options)\n .then(function ({tileJson, tileLoadFunction}) {\n const sourceOptions = sourceOptionsFromTileJSON(\n glSource,\n tileJson,\n options,\n );\n sourceOptions.tileLoadFunction = tileLoadFunction;\n sourceOptions.format = new MVT();\n resolve(new VectorTileSource(sourceOptions));\n })\n .catch(reject);\n });\n}\n\nfunction setupVectorLayer(glSource, styleUrl, options) {\n const layer = new VectorTileLayer({\n declutter: true,\n visible: false,\n });\n setupVectorSource(glSource, styleUrl, options)\n .then(function (source) {\n source.set('mapbox-source', glSource);\n layer.setSource(source);\n })\n .catch(function (error) {\n layer.setSource(undefined);\n });\n return layer;\n}\n\nfunction getBboxTemplate(projection) {\n const projCode = projection ? projection.getCode() : 'EPSG:3857';\n return `{bbox-${projCode.toLowerCase().replace(/[^a-z0-9]/g, '-')}}`;\n}\n\nfunction setupRasterSource(glSource, styleUrl, options) {\n return new Promise(function (resolve, reject) {\n getTileJson(glSource, styleUrl, options)\n .then(function ({tileJson, tileLoadFunction}) {\n const source = new TileJSON({\n interpolate:\n options.interpolate === undefined ? true : options.interpolate,\n transition: 0,\n crossOrigin: 'anonymous',\n tileJSON: tileJson,\n });\n source.tileGrid = sourceOptionsFromTileJSON(\n glSource,\n tileJson,\n options,\n ).tileGrid;\n if (options.projection) {\n //@ts-ignore\n source.projection = getProjection(options.projection);\n }\n const getTileUrl = source.getTileUrlFunction();\n if (tileLoadFunction) {\n source.setTileLoadFunction(tileLoadFunction);\n }\n source.setTileUrlFunction(function (tileCoord, pixelRatio, projection) {\n const bboxTemplate = getBboxTemplate(projection);\n let src = getTileUrl(tileCoord, pixelRatio, projection);\n if (src.indexOf(bboxTemplate) != -1) {\n const bbox = source.getTileGrid().getTileCoordExtent(tileCoord);\n src = src.replace(bboxTemplate, bbox.toString());\n }\n return src;\n });\n source.set('mapbox-source', glSource);\n resolve(source);\n })\n .catch(function (error) {\n reject(error);\n });\n });\n}\n\nfunction setupRasterLayer(glSource, styleUrl, options) {\n const layer = new TileLayer();\n setupRasterSource(glSource, styleUrl, options)\n .then(function (source) {\n layer.setSource(source);\n })\n .catch(function () {\n layer.setSource(undefined);\n });\n return layer;\n}\n\n/**\n *\n * @param {Object} glSource \"source\" entry from a Mapbox/MapLibre Style object.\n * @param {string} styleUrl Style url\n * @param {Options} options ol-mapbox-style options.\n * @return {ImageLayer} The raster layer\n */\nfunction setupHillshadeLayer(glSource, styleUrl, options) {\n const tileLayer = setupRasterLayer(glSource, styleUrl, options);\n /** @type {ImageLayer} */\n const layer = new ImageLayer({\n source: new Raster({\n operationType: 'image',\n operation: hillshade,\n sources: [tileLayer],\n }),\n });\n return layer;\n}\n\n/**\n * @param {Object} glSource glStyle source.\n * @param {string} styleUrl Style URL.\n * @param {Options} options Options.\n * @return {VectorSource} Configured vector source.\n */\nfunction setupGeoJSONSource(glSource, styleUrl, options) {\n const geoJsonFormat = options.projection\n ? new GeoJSON({dataProjection: options.projection})\n : new GeoJSON();\n const data = glSource.data;\n const sourceOptions = {};\n if (typeof data == 'string') {\n const [geoJsonUrl] = normalizeSourceUrl(\n data,\n options.accessToken,\n options.accessTokenParam || 'access_token',\n styleUrl || location.href,\n );\n if (/\\{bbox-[0-9a-z-]+\\}/.test(geoJsonUrl)) {\n const extentUrl = (extent, resolution, projection) => {\n const bboxTemplate = getBboxTemplate(projection);\n return geoJsonUrl.replace(bboxTemplate, `${extent.join(',')}`);\n };\n const source = new VectorSource({\n attributions: glSource.attribution,\n format: geoJsonFormat,\n loader: (extent, resolution, projection, success, failure) => {\n const url =\n typeof extentUrl === 'function'\n ? extentUrl(extent, resolution, projection)\n : extentUrl;\n fetchResource('GeoJSON', url, options)\n .then((json) => {\n const features = /** @type {*} */ (\n source\n .getFormat()\n .readFeatures(json, {featureProjection: projection})\n );\n source.addFeatures(features);\n success(features);\n })\n .catch((response) => {\n source.removeLoadedExtent(extent);\n failure();\n });\n },\n strategy: bboxStrategy,\n });\n source.set('mapbox-source', glSource);\n return source;\n }\n const source = new VectorSource({\n attributions: glSource.attribution,\n format: geoJsonFormat,\n url: geoJsonUrl,\n loader: (extent, resolution, projection, success, failure) => {\n fetchResource('GeoJSON', geoJsonUrl, options)\n .then((json) => {\n const features = /** @type {*} */ (\n source\n .getFormat()\n .readFeatures(json, {featureProjection: projection})\n );\n source.addFeatures(features);\n success(features);\n })\n .catch((response) => {\n source.removeLoadedExtent(extent);\n failure();\n });\n },\n });\n return source;\n }\n sourceOptions.features = geoJsonFormat.readFeatures(data, {\n featureProjection: getUserProjection() || 'EPSG:3857',\n });\n\n const source = new VectorSource(\n Object.assign(\n {\n attributions: glSource.attribution,\n format: geoJsonFormat,\n },\n sourceOptions,\n ),\n );\n source.set('mapbox-source', glSource);\n return /** @type {VectorSource} */ (source);\n}\n\nfunction setupGeoJSONLayer(glSource, styleUrl, options) {\n return new VectorLayer({\n declutter: true,\n source: setupGeoJSONSource(glSource, styleUrl, options),\n visible: false,\n });\n}\n\nfunction prerenderRasterLayer(glLayer, layer, functionCache) {\n let zoom = null;\n return function (event) {\n if (\n glLayer.paint &&\n 'raster-opacity' in glLayer.paint &&\n event.frameState.viewState.zoom !== zoom\n ) {\n zoom = event.frameState.viewState.zoom;\n delete functionCache[glLayer.id];\n updateRasterLayerProperties(glLayer, layer, zoom, functionCache);\n }\n };\n}\n\nfunction updateRasterLayerProperties(glLayer, layer, zoom, functionCache) {\n const opacity = getValue(\n glLayer,\n 'paint',\n 'raster-opacity',\n zoom,\n emptyObj,\n functionCache,\n );\n layer.setOpacity(opacity);\n}\n\nfunction manageVisibility(layer, mapOrGroup) {\n function onChange() {\n const glStyle = mapOrGroup.get('mapbox-style');\n if (!glStyle) {\n return;\n }\n const mapboxLayers = derefLayers(glStyle.layers);\n const layerMapboxLayerids = layer.get('mapbox-layers');\n const visible = mapboxLayers\n .filter(function (mapboxLayer) {\n return layerMapboxLayerids.includes(mapboxLayer.id);\n })\n .some(function (mapboxLayer) {\n return (\n !mapboxLayer.layout ||\n !mapboxLayer.layout.visibility ||\n mapboxLayer.layout.visibility === 'visible'\n );\n });\n if (layer.get('visible') !== visible) {\n layer.setVisible(visible);\n }\n }\n layer.on('change', onChange);\n onChange();\n}\n\nexport function setupLayer(glStyle, styleUrl, glLayer, options) {\n const functionCache = getFunctionCache(glStyle);\n const glLayers = glStyle.layers;\n const type = glLayer.type;\n\n const id = glLayer.source || getSourceIdByRef(glLayers, glLayer.ref);\n const glSource = glStyle.sources[id];\n let layer;\n if (type == 'background') {\n layer = setupBackgroundLayer(glLayer, options, functionCache);\n } else if (glSource.type == 'vector') {\n layer = setupVectorLayer(glSource, styleUrl, options);\n } else if (glSource.type == 'raster') {\n layer = setupRasterLayer(glSource, styleUrl, options);\n layer.setVisible(\n glLayer.layout ? glLayer.layout.visibility !== 'none' : true,\n );\n layer.on('prerender', prerenderRasterLayer(glLayer, layer, functionCache));\n } else if (glSource.type == 'geojson') {\n layer = setupGeoJSONLayer(glSource, styleUrl, options);\n } else if (glSource.type == 'raster-dem' && glLayer.type == 'hillshade') {\n const hillshadeLayer = setupHillshadeLayer(glSource, styleUrl, options);\n layer = hillshadeLayer;\n hillshadeLayer.getSource().on('beforeoperations', function (event) {\n const data = event.data;\n data.resolution = getPointResolution(\n options.projection || 'EPSG:3857',\n event.resolution,\n getCenter(event.extent),\n 'm',\n );\n const zoom = getZoomForResolution(\n event.resolution,\n options.resolutions || defaultResolutions,\n );\n data.encoding = glSource.encoding;\n data.vert =\n 5 *\n getValue(\n glLayer,\n 'paint',\n 'hillshade-exaggeration',\n zoom,\n emptyObj,\n functionCache,\n );\n data.sunAz = getValue(\n glLayer,\n 'paint',\n 'hillshade-illumination-direction',\n zoom,\n emptyObj,\n functionCache,\n );\n data.sunEl = 35;\n data.opacity = 0.3;\n data.highlightColor = getValue(\n glLayer,\n 'paint',\n 'hillshade-highlight-color',\n zoom,\n emptyObj,\n functionCache,\n );\n data.shadowColor = getValue(\n glLayer,\n 'paint',\n 'hillshade-shadow-color',\n zoom,\n emptyObj,\n functionCache,\n );\n data.accentColor = getValue(\n glLayer,\n 'paint',\n 'hillshade-accent-color',\n zoom,\n emptyObj,\n functionCache,\n );\n });\n layer.setVisible(\n glLayer.layout ? glLayer.layout.visibility !== 'none' : true,\n );\n }\n const glSourceId = id;\n if (layer) {\n layer.set('mapbox-source', glSourceId);\n }\n return layer;\n}\n\n/**\n * @param {*} glStyle Mapbox/MapLibre Style.\n * @param {Map|LayerGroup} mapOrGroup Map or layer group.\n * @param {string} styleUrl Style URL.\n * @param {Options} options Options.\n * @return {Promise} Promise that resolves when the style is loaded.\n */\nfunction processStyle(glStyle, mapOrGroup, styleUrl, options) {\n const promises = [];\n\n let view = null;\n if (mapOrGroup instanceof Map) {\n view = mapOrGroup.getView();\n if (!view.isDef() && !view.getRotation() && !view.getResolutions()) {\n const projection = options.projection\n ? getProjection(options.projection)\n : view.getProjection();\n view = new View(\n Object.assign(view.getProperties(), {\n maxResolution:\n defaultResolutions[0] / METERS_PER_UNIT[projection.getUnits()],\n projection: options.projection || view.getProjection(),\n }),\n );\n mapOrGroup.setView(view);\n }\n\n if ('center' in glStyle && !view.getCenter()) {\n view.setCenter(fromLonLat(glStyle.center, view.getProjection()));\n }\n if ('zoom' in glStyle && view.getZoom() === undefined) {\n view.setResolution(\n defaultResolutions[0] /\n METERS_PER_UNIT[view.getProjection().getUnits()] /\n Math.pow(2, glStyle.zoom),\n );\n }\n if (!view.getCenter() || view.getZoom() === undefined) {\n view.fit(view.getProjection().getExtent(), {\n nearest: true,\n size: mapOrGroup.getSize(),\n });\n }\n }\n mapOrGroup.set('mapbox-style', glStyle);\n mapOrGroup.set('mapbox-metadata', {styleUrl, options});\n\n const glLayers = glStyle.layers;\n let layerIds = [];\n\n let layer, glSourceId, id;\n for (let i = 0, ii = glLayers.length; i < ii; ++i) {\n const glLayer = glLayers[i];\n const type = glLayer.type;\n if (type == 'heatmap') {\n //FIXME Unsupported layer type\n // eslint-disable-next-line no-console\n console.debug(`layers[${i}].type \"${type}\" not supported`);\n continue;\n } else {\n id = glLayer.source || getSourceIdByRef(glLayers, glLayer.ref);\n // this technique assumes gl layers will be in a particular order\n if (!id || id != glSourceId) {\n if (layerIds.length) {\n promises.push(\n finalizeLayer(\n layer,\n layerIds,\n glStyle,\n styleUrl,\n mapOrGroup,\n options,\n ),\n );\n layerIds = [];\n }\n\n layer = setupLayer(glStyle, styleUrl, glLayer, options);\n if (\n !(layer instanceof VectorLayer || layer instanceof VectorTileLayer)\n ) {\n layerIds = [];\n }\n glSourceId = layer.get('mapbox-source');\n }\n layerIds.push(glLayer.id);\n }\n }\n promises.push(\n finalizeLayer(layer, layerIds, glStyle, styleUrl, mapOrGroup, options),\n );\n return Promise.all(promises);\n}\n\n/**\n * Loads and applies a Mapbox/MapLibre Style object into an OpenLayers Map or LayerGroup.\n * This includes the map background, the layers, and for Map instances that did not\n * have a View defined yet also the center and the zoom.\n *\n * **Example:**\n * ```js\n * import apply from 'ol-mapbox-style';\n *\n * apply('map', 'mapbox://styles/mapbox/bright-v9', {accessToken: 'YOUR_MAPBOX_TOKEN'});\n * ```\n *\n * The center and zoom will only be set if present in the Mapbox/MapLibre Style document,\n * and if not already set on the OpenLayers map.\n *\n * Layers will be added to the OpenLayers map, without affecting any layers that\n * might already be set on the map.\n *\n * Layers added by `apply()` will have two additional properties:\n *\n * * `mapbox-source`: The `id` of the Mapbox/MapLibre Style document's source that the\n * OpenLayers layer was created from. Usually `apply()` creates one\n * OpenLayers layer per Mapbox/MapLibre Style source, unless the layer stack has\n * layers from different sources in between.\n * * `mapbox-layers`: The `id`s of the Mapbox/MapLibre Style document's layers that are\n * included in the OpenLayers layer.\n *\n * This function sets an additional `mapbox-style` property on the OpenLayers\n * Map or LayerGroup instance, which holds the Mapbox/MapLibre Style object.\n *\n * @param {Map|HTMLElement|string|LayerGroup} mapOrGroupOrElement Either an existing\n * OpenLayers Map instance, or a HTML element, or the id of a HTML element that will be\n * the target of a new OpenLayers Map, or a layer group. If layer group, styles\n * releated to the map and view will be ignored.\n * @param {string|Object} style JSON style object or style url pointing to a\n * Mapbox/MapLibre Style object. When using Mapbox APIs, the url is the `styleUrl`\n * shown in Mapbox Studio's \"share\" panel. In addition, the `accessToken` option\n * (see below) must be set.\n * When passed as JSON style object, all OpenLayers layers created by `apply()`\n * will be immediately available, but they may not have a source yet (i.e. when\n * they are defined by a TileJSON url in the Mapbox/MapLibre Style document). When passed\n * as style url, layers will be added to the map when the Mapbox/MapLibre Style document\n * is loaded and parsed.\n * @param {Options} options Options.\n * @return {Promise} A promise that resolves after all layers have been added to\n * the OpenLayers Map instance or LayerGroup, their sources set, and their styles applied. The\n * `resolve` callback will be called with the OpenLayers Map instance or LayerGroup as\n * argument.\n */\nexport function apply(mapOrGroupOrElement, style, options = {}) {\n let promise;\n /** @type {Map|LayerGroup} */\n let mapOrGroup;\n if (\n typeof mapOrGroupOrElement === 'string' ||\n mapOrGroupOrElement instanceof HTMLElement\n ) {\n mapOrGroup = new Map({\n target: mapOrGroupOrElement,\n });\n } else {\n mapOrGroup = mapOrGroupOrElement;\n }\n\n if (typeof style === 'string') {\n const styleUrl = style.startsWith('data:')\n ? location.href\n : normalizeStyleUrl(style, options.accessToken);\n options = completeOptions(styleUrl, options);\n\n promise = new Promise(function (resolve, reject) {\n getGlStyle(style, options)\n .then(function (glStyle) {\n processStyle(glStyle, mapOrGroup, styleUrl, options)\n .then(function () {\n resolve(mapOrGroup);\n })\n .catch(reject);\n })\n .catch(function (err) {\n reject(new Error(`Could not load ${style}: ${err.message}`));\n });\n });\n } else {\n promise = new Promise(function (resolve, reject) {\n processStyle(\n style,\n mapOrGroup,\n !options.styleUrl || options.styleUrl.startsWith('data:')\n ? location.href\n : normalizeStyleUrl(options.styleUrl, options.accessToken),\n options,\n )\n .then(function () {\n resolve(mapOrGroup);\n })\n .catch(reject);\n });\n }\n\n return promise;\n}\n\n/**\n * If layerIds is not empty, applies the style specified in glStyle to the layer,\n * and adds the layer to the map.\n *\n * The layer may not yet have a source when the function is called. If so, the style\n * is applied to the layer via a once listener on the 'change:source' event.\n *\n * @param {Layer} layer An OpenLayers layer instance.\n * @param {Array} layerIds Array containing layer ids of already-processed layers.\n * @param {Object} glStyle Style as a JSON object.\n * @param {string|undefined} styleUrl The original style URL. Only required\n * when a relative path is used with the `\"sprite\"` property of the style.\n * @param {Map|LayerGroup} mapOrGroup OpenLayers Map.\n * @param {Options} options Options.\n * @return {Promise} Returns a promise that resolves after the source has\n * been set on the specified layer, and the style has been applied.\n */\nexport function finalizeLayer(\n layer,\n layerIds,\n glStyle,\n styleUrl,\n mapOrGroup,\n options = {},\n) {\n let minZoom = 24;\n let maxZoom = 0;\n const glLayers = glStyle.layers;\n for (let i = 0, ii = glLayers.length; i < ii; ++i) {\n const glLayer = glLayers[i];\n if (layerIds.indexOf(glLayer.id) !== -1) {\n minZoom = Math.min('minzoom' in glLayer ? glLayer.minzoom : 0, minZoom);\n maxZoom = Math.max('maxzoom' in glLayer ? glLayer.maxzoom : 24, maxZoom);\n }\n }\n return new Promise(function (resolve, reject) {\n const setStyle = function () {\n const source = layer.getSource();\n if (!source || source.getState() === 'error') {\n reject(\n new Error(\n 'Error accessing data for source ' + layer.get('mapbox-source'),\n ),\n );\n return;\n }\n if ('getTileGrid' in source) {\n const tileGrid =\n /** @type {import(\"ol/source/Tile.js\").default|import(\"ol/source/VectorTile.js\").default} */ (\n source\n ).getTileGrid();\n if (tileGrid) {\n const sourceMinZoom = tileGrid.getMinZoom();\n if (minZoom > 0 || sourceMinZoom > 0) {\n layer.setMaxResolution(\n Math.min(\n getResolutionForZoom(\n Math.max(0, minZoom - 1e-12),\n defaultResolutions,\n ),\n getResolutionForZoom(\n Math.max(0, sourceMinZoom - 1e-12),\n tileGrid.getResolutions(),\n ),\n ),\n );\n }\n if (maxZoom < 24) {\n layer.setMinResolution(\n getResolutionForZoom(maxZoom, defaultResolutions),\n );\n }\n }\n } else {\n if (minZoom > 0) {\n layer.setMaxResolution(\n getResolutionForZoom(\n Math.max(0, minZoom - 1e-12),\n defaultResolutions,\n ),\n );\n }\n }\n if (\n source instanceof VectorSource ||\n source instanceof VectorTileSource\n ) {\n applyStyle(\n /** @type {import(\"ol/layer/Vector\").default|import(\"ol/layer/VectorTile\").default} */ (\n layer\n ),\n glStyle,\n layerIds,\n Object.assign({styleUrl: styleUrl}, options),\n )\n .then(function () {\n manageVisibility(layer, mapOrGroup);\n resolve();\n })\n .catch(reject);\n } else {\n resolve();\n }\n };\n\n layer.set('mapbox-layers', layerIds);\n const layers = mapOrGroup.getLayers();\n if (layers.getArray().indexOf(layer) === -1) {\n layers.push(layer);\n }\n\n if (layer.getSource()) {\n setStyle();\n } else {\n layer.once('change:source', setStyle);\n }\n });\n}\n\n/**\n * Get the Mapbox Layer object for the provided `layerId`.\n * @param {Map|LayerGroup} mapOrGroup Map or LayerGroup.\n * @param {string} layerId Mapbox Layer id.\n * @return {Object} Mapbox Layer object.\n */\nexport function getMapboxLayer(mapOrGroup, layerId) {\n const style = mapOrGroup.get('mapbox-style');\n const layerStyle = style.layers.find(function (layer) {\n return layer.id === layerId;\n });\n return layerStyle;\n}\n\n/**\n * Add a new Mapbox Layer object to the style. The map will be re-rendered.\n * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on.\n * @param {Object} mapboxLayer Mapbox Layer object.\n * @param {string} [beforeLayerId] Optional id of the Mapbox Layer before the new layer that will be added.\n * @return {Promise} Resolves when the added layer is available.\n */\nexport function addMapboxLayer(mapOrGroup, mapboxLayer, beforeLayerId) {\n const glStyle = mapOrGroup.get('mapbox-style');\n const mapboxLayers = glStyle.layers;\n let spliceIndex;\n let sourceIndex = -1;\n if (beforeLayerId !== undefined) {\n const beforeMapboxLayer = getMapboxLayer(mapOrGroup, beforeLayerId);\n if (beforeMapboxLayer === undefined) {\n throw new Error(`Layer with id \"${beforeLayerId}\" not found.`);\n }\n spliceIndex = mapboxLayers.indexOf(beforeMapboxLayer);\n } else {\n spliceIndex = mapboxLayers.length;\n }\n let sourceOffset;\n if (\n spliceIndex > 0 &&\n mapboxLayers[spliceIndex - 1].source === mapboxLayer.source\n ) {\n sourceIndex = spliceIndex - 1;\n sourceOffset = -1;\n } else if (\n spliceIndex < mapboxLayers.length &&\n mapboxLayers[spliceIndex].source === mapboxLayer.source\n ) {\n sourceIndex = spliceIndex;\n sourceOffset = 0;\n }\n if (sourceIndex === -1) {\n const {options, styleUrl} = mapOrGroup.get('mapbox-metadata');\n const layer = setupLayer(glStyle, styleUrl, mapboxLayer, options);\n if (beforeLayerId) {\n const beforeLayer = getLayer(mapOrGroup, beforeLayerId);\n const beforeLayerIndex = mapOrGroup\n .getLayers()\n .getArray()\n .indexOf(beforeLayer);\n mapOrGroup.getLayers().insertAt(beforeLayerIndex, layer);\n }\n mapboxLayers.splice(spliceIndex, 0, mapboxLayer);\n return finalizeLayer(\n layer,\n [mapboxLayer.id],\n glStyle,\n styleUrl,\n mapOrGroup,\n options,\n );\n }\n\n if (mapboxLayers.some((layer) => layer.id === mapboxLayer.id)) {\n throw new Error(`Layer with id \"${mapboxLayer.id}\" already exists.`);\n }\n const sourceLayerId = mapboxLayers[sourceIndex].id;\n const args =\n styleFunctionArgs[\n getStyleFunctionKey(\n mapOrGroup.get('mapbox-style'),\n getLayer(mapOrGroup, sourceLayerId),\n )\n ];\n mapboxLayers.splice(spliceIndex, 0, mapboxLayer);\n if (args) {\n const [\n olLayer,\n glStyle,\n sourceOrLayers,\n resolutions,\n spriteData,\n spriteImageUrl,\n getFonts,\n getImage,\n ] = args;\n if (Array.isArray(sourceOrLayers)) {\n const layerIndex = sourceOrLayers.indexOf(sourceLayerId) + sourceOffset;\n sourceOrLayers.splice(layerIndex, 0, mapboxLayer.id);\n }\n applyStylefunction(\n olLayer,\n glStyle,\n sourceOrLayers,\n resolutions,\n spriteData,\n spriteImageUrl,\n getFonts,\n getImage,\n );\n } else {\n getLayer(mapOrGroup, mapboxLayers[sourceIndex].id).changed();\n }\n return Promise.resolve();\n}\n\n/**\n * Update a Mapbox Layer object in the style. The map will be re-rendered with the new style.\n * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on.\n * @param {Object} mapboxLayer Updated Mapbox Layer object.\n */\nexport function updateMapboxLayer(mapOrGroup, mapboxLayer) {\n const glStyle = mapOrGroup.get('mapbox-style');\n const mapboxLayers = glStyle.layers;\n const index = mapboxLayers.findIndex(function (layer) {\n return layer.id === mapboxLayer.id;\n });\n if (index === -1) {\n throw new Error(`Layer with id \"${mapboxLayer.id}\" not found.`);\n }\n const oldLayer = mapboxLayers[index];\n if (oldLayer.source !== mapboxLayer.source) {\n throw new Error(\n 'Updated layer and previous version must use the same source.',\n );\n }\n delete getFunctionCache(glStyle)[mapboxLayer.id];\n delete getFilterCache(glStyle)[mapboxLayer.id];\n mapboxLayers[index] = mapboxLayer;\n const args =\n styleFunctionArgs[\n getStyleFunctionKey(\n mapOrGroup.get('mapbox-style'),\n getLayer(mapOrGroup, mapboxLayer.id),\n )\n ];\n if (args) {\n applyStylefunction.apply(undefined, args);\n } else {\n getLayer(mapOrGroup, mapboxLayer.id).changed();\n }\n}\n\n/**\n * Updates a Mapbox source object in the style. The according OpenLayers source will be replaced\n * and the map will be re-rendered.\n * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on.\n * @param {string} id Key of the source in the `sources` object literal.\n * @param {Object} mapboxSource Mapbox source object.\n * @return {Promise} Promise that resolves when the source has been updated.\n */\nexport function updateMapboxSource(mapOrGroup, id, mapboxSource) {\n const currentSource = getSource(mapOrGroup, id);\n const layers = /** @type {Array} */ (\n mapOrGroup\n .getLayers()\n .getArray()\n .filter(function (layer) {\n return (\n (layer instanceof VectorLayer ||\n layer instanceof TileLayer ||\n layer instanceof VectorTileLayer) &&\n layer.getSource() === currentSource\n );\n })\n );\n const metadata = mapOrGroup.get('mapbox-metadata');\n let newSourcePromise;\n switch (mapboxSource.type) {\n case 'vector':\n newSourcePromise = setupVectorSource(\n mapboxSource,\n metadata.styleUrl,\n metadata.options,\n );\n break;\n case 'geojson':\n newSourcePromise = Promise.resolve(\n setupGeoJSONSource(mapboxSource, metadata.styleUrl, metadata.options),\n );\n break;\n case 'raster':\n case 'raster-dem':\n newSourcePromise = setupRasterSource(\n mapboxSource,\n metadata.styleUrl,\n metadata.options,\n );\n break;\n default:\n return Promise.reject(\n new Error('Unsupported source type ' + mapboxSource.type),\n );\n }\n newSourcePromise.then(function (newSource) {\n layers.forEach(function (layer) {\n layer.setSource(newSource);\n });\n });\n return newSourcePromise;\n}\n\n/**\n * Remove a Mapbox Layer object from the style. The map will be re-rendered.\n * @param {Map|LayerGroup} mapOrGroup The Map or LayerGroup `apply` was called on.\n * @param {string|Object} mapboxLayerIdOrLayer Mapbox Layer id or Mapbox Layer object.\n */\nexport function removeMapboxLayer(mapOrGroup, mapboxLayerIdOrLayer) {\n const mapboxLayerId =\n typeof mapboxLayerIdOrLayer === 'string'\n ? mapboxLayerIdOrLayer\n : mapboxLayerIdOrLayer.id;\n const layer = getLayer(mapOrGroup, mapboxLayerId);\n /** @type {Array} */\n const layerMapboxLayers = layer.get('mapbox-layers');\n if (layerMapboxLayers.length === 1) {\n throw new Error(\n 'Cannot remove last Mapbox layer from an OpenLayers layer.',\n );\n }\n layerMapboxLayers.splice(layerMapboxLayers.indexOf(mapboxLayerId), 1);\n const glStyle = mapOrGroup.get('mapbox-style');\n const layers = glStyle.layers;\n layers.splice(\n layers.findIndex((layer) => layer.id === mapboxLayerId),\n 1,\n );\n const args = styleFunctionArgs[getStyleFunctionKey(glStyle, layer)];\n if (args) {\n const [\n olLayer,\n glStyle,\n sourceOrLayers,\n resolutions,\n spriteData,\n spriteImageUrl,\n getFonts,\n getImage,\n ] = args;\n if (Array.isArray(sourceOrLayers)) {\n sourceOrLayers.splice(\n sourceOrLayers.findIndex((layer) => layer === mapboxLayerId),\n 1,\n );\n }\n applyStylefunction(\n olLayer,\n glStyle,\n sourceOrLayers,\n resolutions,\n spriteData,\n spriteImageUrl,\n getFonts,\n getImage,\n );\n } else {\n getLayer(mapOrGroup, mapboxLayerId).changed();\n }\n}\n\n/**\n * Get the OpenLayers layer instance that contains the provided Mapbox/MapLibre Style\n * `layer`. Note that multiple Mapbox/MapLibre Style layers are combined in a single\n * OpenLayers layer instance when they use the same Mapbox/MapLibre Style `source`.\n * @param {Map|LayerGroup} map OpenLayers Map or LayerGroup.\n * @param {string} layerId Mapbox/MapLibre Style layer id.\n * @return {Layer} OpenLayers layer instance.\n */\nexport function getLayer(map, layerId) {\n const layers = map.getLayers().getArray();\n for (let i = 0, ii = layers.length; i < ii; ++i) {\n const mapboxLayers = layers[i].get('mapbox-layers');\n if (mapboxLayers && mapboxLayers.indexOf(layerId) !== -1) {\n return /** @type {Layer} */ (layers[i]);\n }\n }\n return undefined;\n}\n\n/**\n * Get the OpenLayers layer instances for the provided Mapbox/MapLibre Style `source`.\n * @param {Map|LayerGroup} map OpenLayers Map or LayerGroup.\n * @param {string} sourceId Mapbox/MapLibre Style source id.\n * @return {Array} OpenLayers layer instances.\n */\nexport function getLayers(map, sourceId) {\n const result = [];\n const layers = map.getLayers().getArray();\n for (let i = 0, ii = layers.length; i < ii; ++i) {\n if (layers[i].get('mapbox-source') === sourceId) {\n result.push(/** @type {Layer} */ (layers[i]));\n }\n }\n return result;\n}\n\n/**\n * Get the OpenLayers source instance for the provided Mapbox/MapLibre Style `source`.\n * @param {Map|LayerGroup} map OpenLayers Map or LayerGroup.\n * @param {string} sourceId Mapbox/MapLibre Style source id.\n * @return {Source} OpenLayers source instance.\n */\nexport function getSource(map, sourceId) {\n const layers = map.getLayers().getArray();\n for (let i = 0, ii = layers.length; i < ii; ++i) {\n const source = /** @type {Layer} */ (layers[i]).getSource();\n if (layers[i].get('mapbox-source') === sourceId) {\n return source;\n }\n }\n return undefined;\n}\n\n/**\n * Sets or removes a feature state. The feature state is taken into account for styling,\n * just like the feature's properties, and can be used e.g. to conditionally render selected\n * features differently.\n *\n * The feature state will be stored on the OpenLayers layer matching the feature identifier, in the\n * `mapbox-featurestate` property.\n * @param {Map|VectorLayer|VectorTileLayer} mapOrLayer OpenLayers Map or layer to set the feature\n * state on.\n * @param {FeatureIdentifier} feature Feature identifier.\n * @param {Object|null} state Feature state. Set to `null` to remove the feature state.\n */\nexport function setFeatureState(mapOrLayer, feature, state) {\n const layers =\n 'getLayers' in mapOrLayer\n ? getLayers(mapOrLayer, feature.source)\n : [mapOrLayer];\n for (let i = 0, ii = layers.length; i < ii; ++i) {\n const featureState = layers[i].get('mapbox-featurestate');\n if (featureState) {\n if (state) {\n featureState[feature.id] = state;\n } else {\n delete featureState[feature.id];\n }\n layers[i].changed();\n } else {\n throw new Error(`Map or layer for source \"${feature.source}\" not found.`);\n }\n }\n}\n\n/**\n * Sets or removes a feature state. The feature state is taken into account for styling,\n * just like the feature's properties, and can be used e.g. to conditionally render selected\n * features differently.\n * @param {Map|VectorLayer|VectorTileLayer} mapOrLayer Map or layer to set the feature state on.\n * @param {FeatureIdentifier} feature Feature identifier.\n * @return {Object|null} Feature state or `null` when no feature state is set for the given\n * feature identifier.\n */\nexport function getFeatureState(mapOrLayer, feature) {\n const layers =\n 'getLayers' in mapOrLayer\n ? getLayers(mapOrLayer, feature.source)\n : [mapOrLayer];\n for (let i = 0, ii = layers.length; i < ii; ++i) {\n const featureState = layers[i].get('mapbox-featurestate');\n if (featureState && featureState[feature.id]) {\n return featureState[feature.id];\n }\n }\n return undefined;\n}\n","import BaseEvent from 'ol/events/Event.js';\nimport EventType from 'ol/events/EventType.js';\nimport MVT from 'ol/format/MVT.js';\nimport VectorTileLayer from 'ol/layer/VectorTile.js';\nimport VectorTileSource from 'ol/source/VectorTile.js';\nimport {applyBackground, applyStyle} from './apply.js';\n\n/** @typedef {import(\"ol/Map.js\").default} Map */\n\n/**\n * @classdesc\n * Event emitted on configuration or loading error.\n */\nclass ErrorEvent extends BaseEvent {\n /**\n * @param {Error} error error object.\n */\n constructor(error) {\n super(EventType.ERROR);\n\n /**\n * @type {Error}\n */\n this.error = error;\n }\n}\n\n/**\n * @typedef {Object} Options\n * @property {string} styleUrl The URL of the Mapbox/MapLibre Style object to use for this layer. For a\n * style created with Mapbox Studio and hosted on Mapbox, this will look like\n * 'mapbox://styles/you/your-style'.\n * @property {string} [accessToken] The access token for your Mapbox/MapLibre style. This has to be provided\n * for `mapbox://` style urls. For `https://` and other urls, any access key must be the last query\n * parameter of the style url.\n * @property {string} [source] If your style uses more than one source, you need to use either the\n * `source` property or the `layers` property to limit rendering to a single vector source. The\n * `source` property corresponds to the id of a vector source in your Mapbox/MapLibre style.\n * @property {Array} [layers] Limit rendering to the list of included layers. All layers\n * must share the same vector source. If your style uses more than one source, you need to use\n * either the `source` property or the `layers` property to limit rendering to a single vector\n * source.\n * @property {boolean} [declutter=true] Declutter images and text. Decluttering is applied to all\n * image and text styles of all Vector and VectorTile layers that have set this to `true`. The priority\n * is defined by the z-index of the layer, the `zIndex` of the style and the render order of features.\n * Higher z-index means higher priority. Within the same z-index, a feature rendered before another has\n * higher priority.\n *\n * As an optimization decluttered features from layers with the same `className` are rendered above\n * the fill and stroke styles of all of those layers regardless of z-index. To opt out of this\n * behavior and place declutterd features with their own layer configure the layer with a `className`\n * other than `ol-layer`.\n * @property {import(\"ol/layer/Base.js\").BackgroundColor|false} [background] Background color for the layer.\n * If not specified, the background from the Mapbox/MapLibre Style object will be used. Set to `false` to prevent\n * the Mapbox/MapLibre style's background from being used.\n * @property {string} [className='ol-layer'] A CSS class name to set to the layer element.\n * @property {number} [opacity=1] Opacity (0, 1).\n * @property {boolean} [visible=true] Visibility.\n * @property {import(\"ol/extent.js\").Extent} [extent] The bounding extent for layer rendering. The layer will not be\n * rendered outside of this extent.\n * @property {number} [zIndex] The z-index for layer rendering. At rendering time, the layers\n * will be ordered, first by Z-index and then by position. When `undefined`, a `zIndex` of 0 is assumed\n * for layers that are added to the map's `layers` collection, or `Infinity` when the layer's `setMap()`\n * method was used.\n * @property {number} [minResolution] The minimum resolution (inclusive) at which this layer will be\n * visible.\n * @property {number} [maxResolution] The maximum resolution (exclusive) below which this layer will\n * be visible. If neither `maxResolution` nor `minZoom` are defined, the layer's `maxResolution` will\n * match the style source's `minzoom`.\n * @property {number} [minZoom] The minimum view zoom level (exclusive) above which this layer will\n * be visible. If neither `maxResolution` nor `minZoom` are defined, the layer's `minZoom` will match\n * the style source's `minzoom`.\n * @property {number} [maxZoom] The maximum view zoom level (inclusive) at which this layer will\n * be visible.\n * @property {import(\"ol/render.js\").OrderFunction} [renderOrder] Render order. Function to be used when sorting\n * features before rendering. By default features are drawn in the order that they are created. Use\n * `null` to avoid the sort, but get an undefined draw order.\n * @property {number} [renderBuffer=100] The buffer in pixels around the tile extent used by the\n * renderer when getting features from the vector tile for the rendering or hit-detection.\n * Recommended value: Vector tiles are usually generated with a buffer, so this value should match\n * the largest possible buffer of the used tiles. It should be at least the size of the largest\n * point symbol or line width.\n * @property {import(\"ol/layer/VectorTile.js\").VectorTileRenderType} [renderMode='hybrid'] Render mode for vector tiles:\n * * `'hybrid'`: Polygon and line elements are rendered as images, so pixels are scaled during zoom\n * animations. Point symbols and texts are accurately rendered as vectors and can stay upright on\n * rotated views.\n * * `'vector'`: Everything is rendered as vectors. Use this mode for improved performance on vector\n * tile layers with only a few rendered features (e.g. for highlighting a subset of features of\n * another layer with the same source).\n * @property {import(\"ol/Map.js\").default} [map] Sets the layer as overlay on a map. The map will not manage\n * this layer in its layers collection, and the layer will be rendered on top. This is useful for\n * temporary layers. The standard way to add a layer to a map and have it managed by the map is to\n * use `map.addLayer()`.\n * @property {boolean} [updateWhileAnimating=false] When set to `true`, feature batches will be\n * recreated during animations. This means that no vectors will be shown clipped, but the setting\n * will have a performance impact for large amounts of vector data. When set to `false`, batches\n * will be recreated when no animation is active.\n * @property {boolean} [updateWhileInteracting=false] When set to `true`, feature batches will be\n * recreated during interactions. See also `updateWhileAnimating`.\n * @property {number} [preload=0] Preload. Load low-resolution tiles up to `preload` levels. `0`\n * means no preloading.\n * @property {boolean} [useInterimTilesOnError=true] Use interim tiles on error.\n * @property {Object} [properties] Arbitrary observable properties. Can be accessed with `#get()` and `#set()`.\n */\n\n/**\n * @classdesc\n * ```js\n * import {MapboxVectorLayer} from 'ol-mapbox-style';\n * ```\n * A vector tile layer based on a Mapbox/MapLibre style that uses a single vector source. Configure\n * the layer with the `styleUrl` and `accessToken` shown in Mapbox Studio's share panel.\n * If the style uses more than one source, use the `source` property to choose a single\n * vector source. If you want to render a subset of the layers in the style, use the `layers`\n * property (all layers must share the same vector source). See the constructor options for\n * more detail.\n *\n * const map = new Map({\n * view: new View({\n * center: [0, 0],\n * zoom: 1,\n * }),\n * layers: [\n * new MapboxVectorLayer({\n * styleUrl: 'mapbox://styles/mapbox/bright-v9',\n * accessToken: 'your-mapbox-access-token-here',\n * }),\n * ],\n * target: 'map',\n * });\n *\n * On configuration or loading error, the layer will trigger an `'error'` event. Listeners\n * will receive an object with an `error` property that can be used to diagnose the problem.\n *\n * **Note for users of the full build**: The `MapboxVectorLayer` requires the\n * [ol-mapbox-style](https://github.com/openlayers/ol-mapbox-style) library to be loaded as well.\n *\n * @param {Options} options Options.\n * @extends {VectorTileLayer}\n * @fires module:ol/events/Event~BaseEvent#event:error\n * @api\n */\nexport default class MapboxVectorLayer extends VectorTileLayer {\n /**\n * @param {Options} options Layer options. At a minimum, `styleUrl` and `accessToken`\n * must be provided.\n */\n constructor(options) {\n const declutter = 'declutter' in options ? options.declutter : true;\n const source = new VectorTileSource({\n state: 'loading',\n format: new MVT(),\n });\n\n super({\n source: source,\n background: options.background === false ? null : options.background,\n declutter: declutter,\n className: options.className,\n opacity: options.opacity,\n visible: options.visible,\n zIndex: options.zIndex,\n minResolution: options.minResolution,\n maxResolution: options.maxResolution,\n minZoom: options.minZoom,\n maxZoom: options.maxZoom,\n renderOrder: options.renderOrder,\n renderBuffer: options.renderBuffer,\n renderMode: options.renderMode,\n map: options.map,\n updateWhileAnimating: options.updateWhileAnimating,\n updateWhileInteracting: options.updateWhileInteracting,\n preload: options.preload,\n useInterimTilesOnError: options.useInterimTilesOnError,\n properties: options.properties,\n });\n\n if (options.accessToken) {\n this.accessToken = options.accessToken;\n }\n const url = options.styleUrl;\n const promises = [\n applyStyle(this, url, options.layers || options.source, {\n accessToken: this.accessToken,\n }),\n ];\n if (this.getBackground() === undefined) {\n promises.push(\n applyBackground(this, options.styleUrl, {\n accessToken: this.accessToken,\n }),\n );\n }\n Promise.all(promises)\n .then(() => {\n source.setState('ready');\n })\n .catch((error) => {\n this.dispatchEvent(new ErrorEvent(error));\n const source = this.getSource();\n source.setState('error');\n });\n }\n}\n"],"names":["kCSSColorTable","transparent","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgreen","darkgrey","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","green","greenyellow","grey","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgreen","lightgrey","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","tan","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","clamp_css_byte","i","Math","round","clamp_css_float","f","parse_css_int","str","length","parseFloat","parseInt","parse_css_float","css_hue_to_rgb","m1","m2","h","exports","css_str","iv","replace","toLowerCase","slice","substr","op","indexOf","ep","fname","params","split","alpha","pop","s","l","e","Color","constructor","r","g","b","a","this","parse","input","rgba","parseCSSColor","toString","toArray","toArray01","toArray01PremultipliedAlpha","Color$1","convertLiteral","value","convertFunction","parameters","propertySpec","stops","get","property","undefined","default","type","Object","keys","values","expression","splice","convertIdentityFunction","zoomAndFeatureDependent","featureDependent","zoomDependent","map","stop","tokens","convertTokenString","featureFunctionParameters","featureFunctionStops","zoomStops","zoom","push","functionType","getFunctionType","getInterpolateOperator","z","appendStopPair","convertPropertyFunction","fixupDegenerateStepCurve","convertZoomAndPropertyFunction","isStep","Error","base","convertZoomFunction","colorSpace","getFallback","defaultValue","curve","output","interpolated","result","re","pos","match","exec","literal","lastIndex","ParsingError","key","message","super","ParsingError$1","Scope","parent","bindings","name","concat","has","Scope$1","NullType","kind","NumberType","StringType","BooleanType","ColorType","ObjectType","ValueType","CollatorType","FormattedType","ResolvedImageType","array","itemType","N","valueMemberTypes","checkSubtype","expected","t","memberType","isValidType","provided","allowedTypes","some","isValidNativeType","Array","isArray","Collator","caseSensitive","diacriticSensitive","locale","sensitivity","collator","Intl","usage","compare","lhs","rhs","resolvedLocale","resolvedOptions","FormattedSection","text","image","scale","fontStack","textColor","normalize","Formatted","sections","fromString","unformatted","isEmpty","section","factory","join","serialize","serialized","options","ResolvedImage","available","validateRGBA","isValue","mixed","item","typeOf","String","JSON","stringify","Literal","args","context","error","expectedType","evaluate","eachChild","outputDefined","Literal$1","RuntimeError$1","toJSON","types","string","number","boolean","object","Assertion","floor","parsed","ctx","RuntimeError","fn","forEach","every","arg","Assertion$1","FormatExpression","firstArg","nextTokenMayBeObject","font","lastExpression","content","evaluatedContent","ImageExpression","evaluatedImageName","availableImages","Coercion","Boolean","c","parseColor","num","Number","isNaN","valueToString","child","Coercion$1","geometryTypes","EvaluationContext$1","globals","feature","featureState","formattedSection","_parseColorCache","canonical","featureTileCoord","featureDistanceData","id","geometryType","geometry","canonicalID","properties","distanceFromCenter","center","x","y","dX","dY","bearing","cached","CompoundExpression","_evaluate","definition","definitions","availableOverloads","overloads","filter","signature","signatureContext","ParsingContext","registry","path","scope","parsedArgs","argParseFailed","errors","signatures","stringifySignature","actualTypes","register","CompoundExpression$1","CollatorExpression","EXTENT","updateBBox","bbox","coord","min","max","boxWithinBox","bbox1","bbox2","getTileCoordinates","p","lng","lat","PI","log","tilesAtZoom","pow","onBoundary","p1","p2","x1","y1","x2","y2","pointWithinPolygon","point","rings","inside","len","ring","j","len2","pointWithinPolygons","polygons","twoSided","q1","q2","x3","y3","det1","det2","lineIntersectLine","d","vectorP","vectorQ","v1","v2","lineIntersectPolygon","polygon","lineStringWithinPolygon","line","lineStringWithinPolygons","getTilePolygon","coordinates","getTilePolygons","updatePoint","polyBBox","worldSize","halfWorldSize","shift","getTilePoints","pointBBox","shifts","tilePoints","points","getTileLines","lineBBox","tileLines","tileLine","Infinity","Within","geojson","geometries","features","polygonGeometry","tilePolygon","tilePolygons","pointsWithinPolygons","linesWithinPolygons","Within$1","isFeatureConstant","test","isStateConstant","isGlobalPropertyConstant","Var","boundExpression","Var$1","part","expr","index","_parse","annotate","typeAnnotation","Expr","actual","isConstant","ec","EvaluationContext","k","ParsingContext$1","isTypeAnnotation","childrenConstant","findStopLessThanOrEqualTo","currentValue","nextValue","lowerIndex","upperIndex","currentIndex","Step","labels","outputs","label","outputType","labelKey","valueKey","stopCount","out","Step$1","module","UnitBezier","p1x","p1y","p2x","p2y","cx","bx","ax","cy","by","ay","prototype","sampleCurveX","sampleCurveY","sampleCurveDerivativeX","solveCurveX","epsilon","t0","t1","t2","abs","d2","solve","from","to","Xn","Yn","Zn","t3","deg2rad","rad2deg","xyz2lab","lab2xyz","xyz2rgb","rgb2xyz","rgbToLab","rgbColor","labToRgb","labColor","interpolateHue","lab","forward","reverse","interpolate","interpolateNumber","hcl","atan2","sqrt","hclColor","cos","sin","Interpolate","operator","interpolation","interpolationFactor","lower","upper","exponentialInterpolation","controlPoints","rest","outputLower","outputUpper","lowerValue","upperValue","difference","progress","Interpolate$1","Coalesce","needsAnnotation","firstImage","argCount","Coalesce$1","Let","binding","Let$1","At","At$1","In","needle","haystack","In$1","IndexOf","fromIndex","IndexOf$1","Match","inputType","cases","otherwise","labelContext","MAX_SAFE_INTEGER","sortedLabels","sort","groupedByOutput","outputLookup","outputIndex","coerceLabel","Match$1","Case","branches","_","Case$1","Slice","beginIndex","endIndex","Slice$1","isComparableType","eqCollate","makeComparison","compareBasic","compareWithCollator","isOrderComparison","Comparison","hasUntypedArgument","lt","rt","Equals","NotEquals","LessThan","GreaterThan","LessThanOrEqual","GreaterThanOrEqual","NumberFormat","currency","unit","minFractionDigits","maxFractionDigits","style","minimumFractionDigits","maximumFractionDigits","format","Length","expressions","at","case","coalesce","in","let","step","var","within","obj","v","varargs","typeof","typeToString","rgb","pitch","heatmapDensity","lineProgress","skyRadialProgress","accumulated","ln2","LN2","pi","E","log10","n","LN10","ln","log2","asin","acos","atan","ceil","m","binarySearch","all","any","isSupportedScript","upcase","toUpperCase","downcase","success","isFunction","StyleExpression","_warningHistory","_evaluator","_defaultValue","spec","getDefaultValue","_enumValues","evaluateWithoutErrorHandling","val","console","warn","createExpression","parser","color","enum","formatted","resolvedImage","getExpectedType","ZoomConstantExpression","_styleExpression","isStateDependent","ZoomDependentExpression","interpolationType","createPropertyExpression","supportsPropertyExpression","isZoomConstant","supportsZoomExpression","zoomCurve","findZoomCurve","supportsInterpolation","childResult","deepUnbundle","unbundledValue","valueOf","unbundle","$version","$root","version","required","metadata","period","units","light","terrain","fog","sources","sprite","glyphs","transition","projection","layers","source","source_vector","vector","url","tiles","bounds","scheme","xyz","tms","minzoom","maxzoom","attribution","promoteId","volatile","source_raster","raster","tileSize","source_raster_dem","encoding","terrarium","mapbox","source_geojson","data","buffer","maximum","minimum","tolerance","cluster","clusterRadius","clusterMaxZoom","clusterMinPoints","clusterProperties","lineMetrics","generateId","source_video","video","urls","source_image","layer","fill","symbol","circle","heatmap","hillshade","background","sky","layout","paint","layout_background","visibility","visible","none","layout_sky","layout_fill","layout_circle","layout_heatmap","private","layout_line","butt","square","bevel","miter","requires","layout_symbol","auto","viewport","width","height","both","left","right","top","bottom","horizontal","vertical","uppercase","lowercase","layout_raster","layout_hillshade","filter_symbol","filter_fill","filter_line","filter_circle","filter_heatmap","filter_operator","geometry_type","Point","LineString","Polygon","function","identity","exponential","interval","categorical","function_stop","expression_name","group","distance","range","anchor","position","intensity","albers","equalEarth","equirectangular","lambertConformalConic","mercator","naturalEarth","winkelTripel","globe","parallels","exaggeration","paint_fill","paint_line","paint_circle","paint_heatmap","paint_symbol","overridable","paint_raster","linear","nearest","paint_hillshade","paint_background","paint_sky","gradient","atmosphere","duration","delay","constant","isExpressionFilter","createFilter","layerType","needGeometry","needFeature","convertFilter","filterExp","staticFilter","isDynamicFilter","unionDynamicBranches","collapseDynamicBooleanExpressions","extractStaticFilter","filterSpec","latest","compiledStaticFilter","filterFunc","err","globalProperties","dynamicFilterFunc","compiledDynamicFilter","dynamicFilter","geometryNeeded","collapsed","dynamicConditionExpressions","collapsedExpression","subExpression","isBranchingDynamically","Set","filters","convertComparisonOp","convertNegation","convertInOp","convertHasOp","refProperties","deref","derefLayers","create","ref","fontWeights","thin","hairline","book","regular","normal","plain","roman","standard","medium","bold","heavy","fat","poster","sp","italicRE","fontCache","fonts","size","lineHeight","cssData","haveWeight","haveStyle","weight","fontFamilies","ii","parts","maybeWeight","w","previousPart","startsWith","fontFamily","mapboxBaseUrl","getMapboxPath","normalizeStyleUrl","token","mapboxPath","decodeURI","URL","location","href","mapboxSubdomains","normalizeSourceUrl","tokenParam","styleUrl","urlObject","searchParams","set","sizeFactor","window","devicePixelRatio","sub","functionCacheByStyleId","filterCacheByStyleId","styleId","getStyleId","glStyle","getStyleFunctionKey","olLayer","getUid","getFunctionCache","functionCache","getFilterCache","filterCache","degrees","defaultResolutions","resolutions","res","createCanvas","WorkerGlobalScope","self","OffscreenCanvas","canvas","document","createElement","getZoomForResolution","resolution","zoomFactor","getResolutionForZoom","factor","pendingRequests","fetchResource","resourceType","request","transformedRequest","transformRequest","pendingRequest","toPromise","then","Request","headers","fetch","response","ok","json","Promise","reject","catch","getGlStyle","glStyleOrUrl","resolve","trim","accessToken","tilejsonCache","getTileJson","glSource","cacheKey","promise","tileLoadFunction","tile","src","VectorTile","setLoader","extent","arrayBuffer","getFormat","readFeatures","featureProjection","setFeatures","setState","TileState","ERROR","img","getImage","blob","createObjectURL","addEventListener","revokeObjectURL","normalizedSourceUrl","accessTokenParam","tileJson","assign","tileUrl","drawIconHalo","spriteImage","spriteImageData","haloWidth","haloColor","imgSize","pixelRatio","imageCanvas","imageContext","getContext","drawImage","imageData","getImageData","globalCompositeOperation","fillStyle","jj","arc","smoothstep","drawSDF","area","gamma","putImageData","hairSpacePool","applyLetterSpacing","letterSpacing","textWithLetterSpacing","lines","joinSpaceString","ll","measureContext","getMeasureContext","measureText","measureCache","wrapText","em","hardLines","wrappedText","words","maxWidth","word","testLine","prevWidth","nextWidth","next","lineWords","lastWord","fontFamilyRegEx","stripQuotesRegEx","loadedFontFamilies","hasFontFamily","family","styleSheets","styleSheet","cssRules","rules","cssRule","cssText","processedFontFamilies","MultiPoint","MultiLineString","MultiPolygon","expressionData","rawExpression","compiledExpression","emptyObj","zoomObj","renderFeatureCoordinates","renderFeature","getValue","layoutOrPaint","layerId","functions","isExpr","bind","getDeclutterMode","prefix","evaluateFilter","renderTransparentEnabled","colorWithOpacity","opacity","templateRegEx","fromTemplate","recordLayer","styleFunctionArgs","stylefunction","sourceOrLayers","spriteData","spriteImageUrl","getFonts","spriteImageSize","spriteImageUnSDFed","arguments","Image","blobUrl","crossOrigin","onload","changed","worker","postMessage","action","event","allLayers","layersBySourceLayer","mapboxLayers","iconImageCache","patternCache","mapboxSource","sourceLayer","textHalo","Stroke","Fill","styles","styleFunction","onlyLayer","getProperties","getGeometry","getType","getId","featureBelongsToLayer","stylesLength","layerData","stroke","strokeColor","fillIcon","icon","getFill","getStroke","getText","Style","setZIndex","icon_cache_key","pattern","globalAlpha","createPattern","setColor","setWidth","setLineCap","setLineJoin","setMiterLimit","setLineDash","iconImg","skipLabel","textLineHeight","textSize","maxTextWidth","hasImage","placementAngle","iconImage","styleGeom","imageElement","iconRotationAlignment","geom","getFlatMidpoint","getFlatMidpoints","getExtent","midpoint","NaN","RenderFeature","stride","getStride","getFlatCoordinates","minX","maxX","xM","dotProduct","iconSize","iconColor","iconCacheKey","declutterMode","displacement","iconOptions","rotateWithView","Icon","offset","sdf","setGeometry","setRotation","setOpacity","setAnchor","setImage","setText","circleRadius","circleStrokeColor","circleTranslate","circleColor","circleStrokeWidth","cache_key","Circle","radius","fontArray","mb2css","includes","textField","reduce","acc","chunk","chunkFont","Text","padding","textTransform","wrappedLabel","setFont","setKeepUpright","keepUpright","textAnchor","placement","textAlign","setPlacement","setRepeat","symbolSpacing","setOverflow","textHaloWidth","textOffset","textTranslate","vOffset","hOffset","textRotationAlignment","setRotateWithView","setMaxAngle","setTextAlign","textBaseline","setTextBaseline","textJustify","setJustify","setOffsetX","setOffsetY","setFill","halfTextSize","setStroke","textPadding","getPadding","setStyle","inputs","elevationImage","elevationData","shadeData","Uint8ClampedArray","dp","maxY","pixel","twoPi","halfPi","sunEl","sunAz","cosSunEl","sinSunEl","highlightColor","shadowColor","accentColor","pixelX","pixelY","x0","y0","z0","z1","dzdx","dzdy","slope","aspect","accent","scaled","shade","scaledAccentColor","compositeShadeColor","clamp","slopeScaleBase","scaledSlope","cosIncidence","calculateElevation","vert","ImageData","getTileResolutions","createXYZ","maxZoom","getResolutions","completeOptions","applyStyle","sourceOrLayersOrOptions","optionsOrPath","sourceId","updateSource","VectorLayer","VectorTileLayer","find","assignSource","setupVectorSource","targetSource","getSource","setTileUrlFunction","getTileUrlFunction","setUrls","getUrls","format_","getAttributions","setAttributions","getTileLoadFunction","defaultLoadFunction","setTileLoadFunction","equivalent","getProjection","tileGrid","getTileGrid","setSource","isFinite","getMaxResolution","getMinZoom","setMaxResolution","setupGeoJSONSource","url_","getUrl","spriteScale","onChange","getUnits","METERS_PER_UNIT","applyStylefunction","templateUrl","webfonts","fontsKey","fontDescriptions","cssFont","registerFont","fontDescription","checkedFonts","fontUrl","querySelector","markup","rel","head","appendChild","getStyle","normalizeSpriteUrl","spriteUrl","origin","pathname","search","spritesJson","transformed","applyBackground","mapOrLayer","Layer","setBackground","getBackgroundColor","Map","LayerGroup","getLayers","insertAt","setupBackgroundLayer","setFirstBackground","getSourceIdByRef","sourceOptionsFromTileJSON","tileJSON","tileJSONSource","TileJSON","tileJSONDoc","getTileJSON","fromLonLat","tr","extentFromTileJSON","projectionExtent","minZoom","sourceOptions","attributions","TileGrid","getTopLeft","getOrigin","getTileSize","glLayer","bg","_colorWithOpacity","div","className","Source","render","frameState","viewState","backgroundColor","MVT","VectorTileSource","getBboxTemplate","getCode","setupRasterSource","getTileUrl","tileCoord","bboxTemplate","getTileCoordExtent","setupRasterLayer","TileLayer","geoJsonFormat","GeoJSON","dataProjection","geoJsonUrl","extentUrl","VectorSource","loader","failure","addFeatures","removeLoadedExtent","strategy","bboxStrategy","getUserProjection","prerenderRasterLayer","updateRasterLayerProperties","setupLayer","glLayers","declutter","setupVectorLayer","setVisible","on","setupGeoJSONLayer","hillshadeLayer","tileLayer","ImageLayer","Raster","operationType","operation","setupHillshadeLayer","getPointResolution","getCenter","glSourceId","processStyle","mapOrGroup","promises","view","getView","isDef","getRotation","View","maxResolution","setView","setCenter","getZoom","setResolution","fit","getSize","layerIds","finalizeLayer","debug","apply","mapOrGroupOrElement","HTMLElement","target","getState","sourceMinZoom","setMinResolution","layerMapboxLayerids","mapboxLayer","manageVisibility","getArray","once","getMapboxLayer","getLayer","ErrorEvent","BaseEvent","EventType","MapboxVectorLayer","state","zIndex","minResolution","renderOrder","renderBuffer","renderMode","updateWhileAnimating","updateWhileInteracting","preload","useInterimTilesOnError","getBackground","dispatchEvent","beforeLayerId","spliceIndex","sourceOffset","sourceIndex","beforeMapboxLayer","beforeLayer","beforeLayerIndex","sourceLayerId","layerIndex","evaluateStyle","getStyleFunction","record","mapboxLayerIdOrLayer","mapboxLayerId","layerMapboxLayers","findIndex","enabled","clearFunctionCache","currentSource","newSourcePromise","newSource"],"mappings":"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"} \ No newline at end of file diff --git a/dist/shaders.d.ts b/dist/shaders.d.ts new file mode 100644 index 00000000..c8bc67cc --- /dev/null +++ b/dist/shaders.d.ts @@ -0,0 +1,8 @@ +/** + * Generates a shaded relief image given elevation data. Uses a 3x3 + * neighborhood for determining slope and aspect. + * @param {Array} inputs Array of input images. + * @param {Object} data Data added in the "beforeoperations" event. + * @return {ImageData} Output image. + */ +export function hillshade(inputs: Array, data: any): ImageData; diff --git a/dist/stylefunction.d.ts b/dist/stylefunction.d.ts new file mode 100644 index 00000000..4896731a --- /dev/null +++ b/dist/stylefunction.d.ts @@ -0,0 +1,136 @@ +/** + * @private + * @param {Object} layer Gl object layer. + * @param {string} layoutOrPaint 'layout' or 'paint'. + * @param {string} property Feature property. + * @param {number} zoom Zoom. + * @param {Object} feature Gl feature. + * @param {Object} [functionCache] Function cache. + * @param {Object} [featureState] Feature state. + * @return {?} Value. + */ +export function getValue(layer: any, layoutOrPaint: string, property: string, zoom: number, feature: any, functionCache?: any, featureState?: any): unknown; +/** + * Configure whether features with a transparent style should be rendered. When + * set to `true`, it will be possible to hit detect content that is not visible, + * like transparent fills of polygons, using `ol/layer/Layer#getFeatures()` or + * `ol/Map#getFeaturesAtPixel()` + * @param {boolean} enabled Rendering of transparent elements is enabled. + * Default is `false`. + */ +export function renderTransparent(enabled: boolean): void; +/** + * Turns recording of the Mapbox/MapLibre Style's `layer` on and off. When turned on, + * the layer that a rendered feature belongs to will be set as the feature's + * `mapbox-layer` property. + * @param {boolean} record Recording of the style layer is on. + */ +export function recordStyleLayer(record?: boolean): void; +/** + * Creates a style function from the `glStyle` object for all layers that use + * the specified `source`, which needs to be a `"type": "vector"` or + * `"type": "geojson"` source and applies it to the specified OpenLayers layer. + * + * Two additional properties will be set on the provided layer: + * + * * `mapbox-source`: The `id` of the Mapbox/MapLibre Style document's source that the + * OpenLayers layer was created from. Usually `apply()` creates one + * OpenLayers layer per Mapbox/MapLibre Style source, unless the layer stack has + * layers from different sources in between. + * * `mapbox-layers`: The `id`s of the Mapbox/MapLibre Style document's layers that are + * included in the OpenLayers layer. + * + * This function also works in a web worker. In worker mode, the main thread needs + * to listen to messages from the worker and respond with another message to make + * sure that sprite image loading works: + * + * ```js + * worker.addEventListener('message', event => { + * if (event.data.action === 'loadImage') { + * const image = new Image(); + * image.crossOrigin = 'anonymous'; + * image.addEventListener('load', function() { + * createImageBitmap(image, 0, 0, image.width, image.height).then(imageBitmap => { + * worker.postMessage({ + * action: 'imageLoaded', + * image: imageBitmap, + * src: event.data.src + * }, [imageBitmap]); + * }); + * }); + * image.src = event.data.src; + * } + * }); + * ``` + * + * @param {VectorLayer|VectorTileLayer} olLayer OpenLayers layer to + * apply the style to. In addition to the style, the layer will get two + * properties: `mapbox-source` will be the `id` of the `glStyle`'s source used + * for the layer, and `mapbox-layers` will be an array of the `id`s of the + * `glStyle`'s layers. + * @param {string|Object} glStyle Mapbox/MapLibre Style object. + * @param {string|Array} sourceOrLayers `source` key or an array of layer `id`s + * from the Mapbox/MapLibre Style object. When a `source` key is provided, all layers for + * the specified source will be included in the style function. When layer `id`s + * are provided, they must be from layers that use the same source. + * @param {Array} resolutions + * Resolutions for mapping resolution to zoom level. + * @param {Object} spriteData Sprite data from the url specified in + * the Mapbox/MapLibre Style object's `sprite` property. Only required if a `sprite` + * property is specified in the Mapbox/MapLibre Style object. + * @param {string|Request|Promise} spriteImageUrl Sprite image url for the sprite + * specified in the Mapbox/MapLibre Style object's `sprite` property. Only required if a + * `sprite` property is specified in the Mapbox/MapLibre Style object. + * @param {function(Array, string=):Array} getFonts Function that + * receives a font stack and the url template from the GL style's `metadata['ol:webfonts']` + * property (if set) as arguments, and returns a (modified) font stack that + * is available. Font names are the names used in the Mapbox/MapLibre Style object. If + * not provided, the font stack will be used as-is. This function can also be + * used for loading web fonts. + * @param {function(VectorLayer|VectorTileLayer, string):HTMLImageElement|HTMLCanvasElement|string|undefined} [getImage=undefined] + * Function that returns an image or a URL for an image name. If the result is an HTMLImageElement, it must already be + * loaded. The layer can be used to call layer.changed() when the loading and processing of the image has finished. + * This function can be used for icons not in the sprite or to override sprite icons. + * @return {StyleFunction} Style function for use in + * `ol.layer.Vector` or `ol.layer.VectorTile`. + */ +export function stylefunction(olLayer: VectorLayer | VectorTileLayer, glStyle: string | any, sourceOrLayers: string | Array, resolutions?: Array, spriteData?: any, spriteImageUrl?: string | Request | Promise, getFonts?: (arg0: Array, arg1: string | undefined) => Array, getImage?: ((arg0: VectorLayer | VectorTileLayer, arg1: string) => HTMLImageElement | HTMLCanvasElement | string | undefined) | undefined, ...args: any[]): StyleFunction; +/** + * Get the the style for a specific Mapbox layer only. This can be useful for creating a legend. + * @param {import("ol/Feature").default|import("ol/render/Feature").default} feature OpenLayers feature. + * @param {number} resolution View resolution. + * @param {import("ol/layer").Vector|import("ol/layer").VectorTile} olLayer OpenLayers layer. + * @param {string} layerId Id of the Mapbox layer to get the style for + * @return {Array} Styles for the provided Mapbox layer. + */ +export function getStyleForLayer(feature: import("ol/Feature").default | import("ol/render/Feature").default, resolution: number, olLayer: import("ol/layer").Vector | import("ol/layer").VectorTile, layerId: string): Array; +export const styleFunctionArgs: {}; +export type VectorLayer = import("ol/layer/Vector").default; +export type VectorTileLayer = import("ol/layer/VectorTile").default; +export type StyleFunction = import("ol/style/Style").StyleFunction; +export type ResourceType = import('./util.js').ResourceType; +/** + * @private + * @param {?} color Color. + * @param {number} [opacity] Opacity. + * @return {string} Color. + */ +declare function colorWithOpacity(color: unknown, opacity?: number | undefined): string; +/** + * @private + * @param {string} layerId Layer id. + * @param {?} filter Filter. + * @param {Object} feature Feature. + * @param {number} zoom Zoom. + * @param {Object} [filterCache] Filter cache. + * @return {boolean} Filter result. + */ +declare function evaluateFilter(layerId: string, filter: unknown, feature: any, zoom: number, filterCache?: any): boolean; +/** + * @private + * @param {string} text Text. + * @param {Object} properties Properties. + * @return {string} Text. + */ +declare function fromTemplate(text: string, properties: any): string; +export { colorWithOpacity as _colorWithOpacity, evaluateFilter as _evaluateFilter, fromTemplate as _fromTemplate, getValue as _getValue }; diff --git a/dist/text.d.ts b/dist/text.d.ts new file mode 100644 index 00000000..2e57444a --- /dev/null +++ b/dist/text.d.ts @@ -0,0 +1,9 @@ +export function applyLetterSpacing(text: any, letterSpacing: any): any; +export function wrapText(text: any, font: any, em: any, letterSpacing: any): any; +/** + * @param {Array} fonts Fonts. + * @param {string} [templateUrl] Template URL. + * @return {Array} Processed fonts. + * @private + */ +export function getFonts(fonts: any[], templateUrl?: string | undefined): any[]; diff --git a/dist/util.d.ts b/dist/util.d.ts new file mode 100644 index 00000000..62293fe0 --- /dev/null +++ b/dist/util.d.ts @@ -0,0 +1,90 @@ +export function getStyleId(glStyle: any): any; +export function getStyleFunctionKey(glStyle: any, olLayer: any): string; +/** + * @param {Object} glStyle Mapboox style object. + * @return {Object} Function cache. + */ +export function getFunctionCache(glStyle: any): any; +export function clearFunctionCache(): void; +/** + * @param {Object} glStyle Mapboox style object. + * @return {Object} Filter cache. + */ +export function getFilterCache(glStyle: any): any; +export function deg2rad(degrees: any): number; +/** + * @param {number} width Width of the canvas. + * @param {number} height Height of the canvas. + * @return {HTMLCanvasElement} Canvas. + */ +export function createCanvas(width: number, height: number): HTMLCanvasElement; +export function getZoomForResolution(resolution: any, resolutions: any): number; +export function getResolutionForZoom(zoom: any, resolutions: any): number; +/** + * @param {ResourceType} resourceType Type of resource to load. + * @param {string} url Url of the resource. + * @param {Options} [options={}] Options. + * @param {{request?: Request}} [metadata] Object to be filled with the request. + * @return {Promise} Promise that resolves with the loaded resource + * or rejects with the Response object. + * @private + */ +export function fetchResource(resourceType: ResourceType, url: string, options?: import("./apply.js").Options | undefined, metadata?: { + request?: Request | undefined; +} | undefined): Promise; +export function getGlStyle(glStyleOrUrl: any, options: any): Promise; +/** + * @param {Object} glSource glStyle source object. + * @param {string} styleUrl Style URL. + * @param {Options} options Options. + * @return {Promise<{tileJson: Object, tileLoadFunction: import('ol/Tile.js').LoadFunction}?>} TileJson and load function + */ +export function getTileJson(glSource: any, styleUrl: string, options?: Options): Promise<{ + tileJson: any; + tileLoadFunction: import('ol/Tile.js').LoadFunction; +} | null>; +/** + * @param {HTMLImageElement|HTMLCanvasElement} spriteImage Sprite image id. + * @param {{x: number, y: number, width: number, height: number, pixelRatio: number}} spriteImageData Sprite image data. + * @param {number} haloWidth Halo width. + * @param {{r: number, g: number, b: number, a: number}} haloColor Halo color. + * @return {HTMLCanvasElement} Canvas element with the halo. + */ +export function drawIconHalo(spriteImage: HTMLImageElement | HTMLCanvasElement, spriteImageData: { + x: number; + y: number; + width: number; + height: number; + pixelRatio: number; +}, haloWidth: number, haloColor: { + r: number; + g: number; + b: number; + a: number; +}): HTMLCanvasElement; +/** + * @param {HTMLImageElement} image SDF image + * @param {{x: number, y: number, width: number, height: number}} area Area to unSDF + * @param {{r: number, g: number, b: number, a: number}} color Color to use + * @return {HTMLCanvasElement} Regular image + */ +export function drawSDF(image: HTMLImageElement, area: { + x: number; + y: number; + width: number; + height: number; +}, color: { + r: number; + g: number; + b: number; + a: number; +}): HTMLCanvasElement; +export const defaultResolutions: number[]; +export type ResourceType = 'Style' | 'Source' | 'Sprite' | 'SpriteImage' | 'Tiles' | 'GeoJSON'; +export type Map = import("ol").Map; +export type Layer = import("ol/layer").Layer; +export type LayerGroup = import("ol/layer").Group; +export type VectorLayer = import("ol/layer").Vector; +export type VectorTileLayer = import("ol/layer").VectorTile; +export type Source = import("ol/source").Source; +export type Options = import("./apply.js").Options;